Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Doc: add job definition schema and how-to guides #143

Merged
merged 5 commits into from
Nov 30, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 8 additions & 0 deletions docs/.wordlist.txt
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ APIs
artifact
artifacts
balancer
BG
CharmHub
CLI
CM3
Expand Down Expand Up @@ -32,11 +33,13 @@ Juju
Kubeflow
Kubernetes
Lenovo
lifecycle
logfile
maas
MaaS
MAAS
Makefile
microservice
MUX
muxpi
MuxPi
Expand Down Expand Up @@ -67,6 +70,7 @@ runtime
SDWire
SecureBoot
SKU
SSID
subdirectories
subfolders
subtree
Expand All @@ -79,7 +83,11 @@ Ubuntu
UI
URI
USB
UUID
VM
webhook
WPA
xenial
yaml
LTS
virtualenv
13 changes: 13 additions & 0 deletions docs/how-to/cancel-job.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
Cancel a job
===============

You can cancel a Testflinger job at any point. However, if the job is in the middle of provisioning, it will finish provisioning before cancelling it completely. This prevents accidentally leaving a system in a bad, partially provisioned state.

To cancel a job, run Testflinger CLI with the ``cancel`` argument and provide the job ID:

.. code-block:: shell

$ testflinger-cli cancel <job_id>


If a job reaches the global timeout or any timeout for a specific operation, such as the output timeout, Testflinger will cancel the job automatically to release resources. In this case, you can resubmit the job or extend the timeout to allow more execution time.
36 changes: 36 additions & 0 deletions docs/how-to/change-server.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
Connect to a different server
==============================

By default, Testflinger CLI uses the default Testflinger server located at ``https://testflinger.canonical.com``. To specify a different server to use, you can either run Testflinger CLI with the ``--server`` parameter, or set an environment variable.


Specify the server in command line
---------------------------------------

Run the Testflinger CLI command with an ``--server <SERVER>`` argument. The server URI must start with either ``http://`` or ``https://``. For example:

.. code-block:: shell

$ testflinger-cli --server https://testflinger.example.com jobs

However, if the environment variable ``TESTFLINGER_SERVER`` is set, this argument will be ignored.


Set an environment variable
-----------------------------

If you want to use a server URI for all operations, you can set the environment variable ``TESTFLINGER_SERVER``. This variable overwrites the default server address and the string specified by the ``--server`` argument.

To set an environment variable on Ubuntu:

.. code-block:: shell

$ export TESTFLINGER_SERVER="https://testflinger.example.com"

If you want to change the environment variable permanently, add the export command to a system-wide or user-specific configuration file.

To verify that the variable has been set, run:

.. code-block:: shell

$ printenv TESTFLINGER_SERVER
11 changes: 10 additions & 1 deletion docs/how-to/index.rst
Original file line number Diff line number Diff line change
@@ -1,6 +1,15 @@
How-to guides
=============
==============

These how-to guides cover key operations and processes in Testflinger.

Work with jobs via Testflinger CLI
-----------------------------------

.. toctree::
:maxdepth: 1

install-cli
change-server
submit-job
cancel-job
33 changes: 33 additions & 0 deletions docs/how-to/install-cli.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
Install Testflinger CLI
========================

The ``testflinger-cli`` client is a command line tool used for interacting with Testflinger servers. You can use the client to submit test jobs to the devices under test (DUT), check the job status and get testing results.

You can either install ``testflinger-cli`` through Snap or check out the code from our GitHub repository and run the tool in a Python virtual environment.


Install via Snap
-----------------
The most convenient way to get the CLI tool is via snap:

.. code-block:: shell

$ sudo snap install testflinger-cli


Install in virtual environment
-------------------------------

If you are using the CLI from an automated test runner, such as Jenkins, you may want to install the tool in a virtual environment instead.

To run it from the source code, please make sure that the ``python3-click`` and ``python3-requests`` packages are installed, and then run the following commands:

.. code-block:: shell

$ git clone https://github.com/canonical/testflinger
$ cd cli
$ virtualenv -p python3 env
$ . env/bin/activate
$ pip install .


21 changes: 21 additions & 0 deletions docs/how-to/submit-job.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
Submit a test job
===================

Once you have a YAML or JSON file with your :doc:`job definition <../reference/job-schema>`, you can submit the job to the main Testflinger server using the CLI:

.. code-block:: shell

$ testflinger-cli submit example-job.yaml


If you want to submit the jobs to a Testflinger server other than the default one, see :doc:`change-server`.

If the job is successful submitted, you will see a ``job_id`` returned by Testflinger:

.. code-block:: shell

Job submitted successfully!
job_id: 2bac1457-0000-0000-0000-15f23f69fd39


You can use the ``job_id`` to further monitor and manager the submitted job.
1 change: 1 addition & 0 deletions docs/reference/index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ Working with device connectors
.. toctree::
:maxdepth: 1

job-schema
device-connector-types
device-connector-conf

Expand Down
73 changes: 73 additions & 0 deletions docs/reference/job-schema.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,73 @@
Test job schema
=================

Test jobs can be defined in either YAML or JSON format.

The following table lists the key elements that a job definition file should contain.

.. list-table:: Test job schema
:header-rows: 1

* - Field
- Type
tang-mm marked this conversation as resolved.
Show resolved Hide resolved
- Default
- Description
* - ``job_queue``
- String
- /
- Name of the job queue to which you want to submit the job. This field is mandatory.
* - ``global_timeout``
- integer
- | 14400
| (4 hours)
- | (Optional) Maximum time (in seconds) a job is allowed to run. If the global timeout is reached while a job is still running, Testflinger will close the job immediately.
| You can set a global timeout larger than the default value, but the per-device configuration might have a more restrict timeout and overwrite the global value.
* - ``output_timeout``
- integer
- | 900
| (15 minutes)
- (Optional) Maximum time (in seconds) Testflinger should wait in the ``test`` phase to get output from the job. If the timeout is reached before the test phase has any output, Testflinger will cancel the job. This value should be smaller than, or equal to, the ``global_timeout``.
* - ``allocation_timeout``
- integer
- | 7200
| (2 hours)
- (Optional) Maximum time (in seconds) Testflinger should wait in the ``allocate`` phase for multi-device jobs to reach the ``allocated`` state. If the timeout is reached before all devices are allocated, Testflinger will cancel the job.
* - ``<phase>_data``
- dictionary
- /
- | (Optional) Sections that define the configurations and commands about how the job should be executed in each of the test phases. If any phase encounters a non-zero exit code, no further phases will be executed.
| Supported test phases include:
| - provision
| - firmware_update
| - test
| - allocate
| - reserve
| For detailed information about how to define the data to include in each test phase, see :doc:`test-phases`.

Example jobs in YAML
----------------------------

The following example YAML file defines a job that provisions the Ubuntu Core 22 system on a Raspberry Pi 4 device. The job retrieves the image from the given URL, provisions the image on the device at IP address ``DEVICE_IP``, and prints the distribution-specific information on the provisioned device:

.. code-block:: yaml

job_queue: rpi4b
global-timeout: 28800
output-timeout: 3600
provision_data:
url: https://cdimage.ubuntu.com/ubuntu-core/22/stable/current/ubuntu-core-22-arm64+raspi.img.xz
test_data:
test_cmds: |
ssh -t ubuntu@DEVICE_IP lsb_release -a

Data specified in the ``provision_data`` section varies on device types. For example, to provision server images on a MAAS device, the ``distro`` field should be used to indicate the system version. The following YAML file defines a job that provisions the Ubuntu 22.04 LTS (Jammy Jellyfish) server install image on a MAAS device and prints the information about its processors and network interface configurations:

.. code-block:: yaml

job_queue: maas-x86-node
provision_data:
distro: jammy
test_data:
test_cmds: |
ssh ubuntu@$DEVICE_IP cat /proc/cpuinfo
ssh ubuntu@$DEVICE_IP ifconfig