Skip to main content

Add your description here

Project description

TMT Driver

jumpstarter-driver-tmt provides functionality for running TMT (Test Management Tool) commands locally while connecting to remote devices via SSH network connections. This driver allows you to execute TMT test plans and commands that provision and test remote hardware through SSH connections.

Installation

pip3 install --extra-index-url https://pkg.jumpstarter.dev/simple/ jumpstarter-driver-tmt

Configuration

Example configuration:

export:
  tmt:
    type: jumpstarter_driver_tmt.driver.TMT
    config:
      reboot_cmd: "j power cycle"
      default_username: "root"
      default_password: "somePassword"
    children:
      ssh:
        type: jumpstarter_driver_network.driver.TcpNetwork
        config:
          host: "192.168.1.100"
          port: 22
          enable_address: true

Config parameters

Parameter Description Type Required Default
reboot_cmd Command to reboot the target device str no "j power cycle"
default_username Default username for SSH connections str no ""
default_password Default password for SSH connections str no ""

Required Children

Child Description Required
ssh Network TCP driver instance for SSH connection yes

Usage

CLI Commands

The TMT driver provides a CLI command tmt that allows you to run TMT commands locally while connecting to remote devices:

# assuming that your DUT has a power and storage driver
j power on
j storage flash ....

# Running part of your plan with tmt
j tmt --root . -c tracing=off -c arch=aarch64 -c distro=rhel-9 -c hw_target=rcar_s4 run --workdir-root /tmp/ -a -vv provision .. some other provisioning... plan -vv --name ^/podman/plans/fusa/tests$

# Use SSH port forwarding (if no direct connection to the DUT is possible)
j tmt --forward-ssh ....

# Specify custom username and password
j tmt --tmt-username root --tmt-password mypassword ...

# Raise log level of the tmt wrapper driver
j --log-level DEBUG tmt --root . -c tracing=off -c arch=aarch64 -c distro=rhel-9 -c hw_target=r
car_s4 run --workdir-root /tmp/ -a -vv provision .. some other provisioning... plan -vv --name ^/podman/plans/fusa/te
sts$
[09/22/25 13:27:18] DEBUG    Using direct SSH connection for tmt - host: 127.0.0.1, port: 2222           client.py:64
                    DEBUG    Provision to be replaced: ('provision', '..', 'some', 'other',             client.py:117
                             'provisioning...')                                                                      
                    DEBUG    Will be replaced with: ['provision', '-h', 'connect', '-g', '127.0.0.1',   client.py:118
                             '-P', '2222', '-u', 'root', '-p', '******']                                           
                    DEBUG    Running TMT command: ['tmt', '--root', '.', '-c', 'tracing=off', '-c',      client.py:74
                             'arch=aarch64', '-c', 'distro=rhel-9', '-c', 'hw_target=rcar_s4', 'run',                
                             '--workdir-root', '/tmp/', '-a', '-vv', 'provision', '-h', 'connect', '-g',             
                             '127.0.0.1', '-P', '2222', '-u', 'root', '-p', '******', 'plan', '-vv',               
                             '--name', '^/podman/plans/fusa/tests$']                                                 
/tmp/run-018
...

CLI Options

Option Description Default
--forward-ssh Use SSH port forwarding for connection false
--tmt-username Username for SSH connections from config
--tmt-password Password for SSH connections from config
--tmt-cmd TMT command to execute "tmt"
--tmt-on-exporter Run TMT on the exporter (not implemented) false

Provision Arguments Handling

The driver automatically handles TMT provision arguments by:

  1. Detecting provision sections: Looks for provision or run commands in the TMT arguments
  2. Replacing connection details: Automatically replaces or adds SSH connection parameters (-h connect -g <host> -P <port> -u <username> -p <password>)
  3. Preserving other arguments: Keeps all other TMT arguments intact

Example of how arguments are transformed:

# Input command
j tmt run --name /my/test/plan provision -h connect -g 192.168.1.100 -P 22

# Automatically transformed to use SSH connection
# TMT receives: run --name /my/test/plan provision -h connect -g <forwarded_host> -P <forwarded_port> -u root -p password

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

jumpstarter_driver_tmt-0.7.3.tar.gz (7.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

jumpstarter_driver_tmt-0.7.3-py3-none-any.whl (8.7 kB view details)

Uploaded Python 3

File details

Details for the file jumpstarter_driver_tmt-0.7.3.tar.gz.

File metadata

File hashes

Hashes for jumpstarter_driver_tmt-0.7.3.tar.gz
Algorithm Hash digest
SHA256 e358a2f98d82af405182df26ee57b3b044525d8ee9e07cc47f209b11ccb8ed59
MD5 1c441c0409ff29680bec6838104fb8e4
BLAKE2b-256 4021bb5642bbb4a8b5575ff291c51fd265012db6a6f6964f83a9130d740e751c

See more details on using hashes here.

File details

Details for the file jumpstarter_driver_tmt-0.7.3-py3-none-any.whl.

File metadata

File hashes

Hashes for jumpstarter_driver_tmt-0.7.3-py3-none-any.whl
Algorithm Hash digest
SHA256 dd1ed0f1bc0e742ee080dcd28545f679c1d69c40a9bf9c2a94bfc3c1a4d45b86
MD5 99c8d91c7f95d4163f4712b0d6f71b49
BLAKE2b-256 95e17e7061ff1ce4603d300bbb1e800e610bd1016c671571aa58f37490d6eaac

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page