GitHub repository:
kernelci-pipeline
Below is the detailed pipeline flow diagram with associated node and pub/sub event:
flowchart
start([Start]) --> trigger_service
subgraph trigger_service[Trigger Service]
kernel_revision{New kernel <br/>revision ?} --> |No| sleep[sleep]
sleep --> kernel_revision
kernel_revision --> |Yes| checkout[Create 'checkout' node <br />state=running, result=None]
end
subgraph tarball_service[Tarball Service]
upload_tarball[Create and upload tarball to the storage]
checkout --> |event: <br />checkout created, state=running| upload_tarball
upload_tarball --> update_checkout_node[Update 'checkout' node <br />state=available, set holdoff <br /> update describe and artifacts]
end
subgraph runner_service[Runner Service]
update_checkout_node --> |event: <br />checkout updated <br />state=available| runner_node[Create build/test node <br />state=running, result=None, holdoff=None]
end
subgraph Run Builds/Tests
runner_node --> runtime[Runtime Environment]
runtime --> set_available[Update node<br />state=available, result=None, set holdoff]
set_available --> run_job[Run build/test job]
run_job --> job_done{Job done?}
job_done --> |Yes| pass_runner_node[Update node<br />state=done, result=pass/fail/skip]
job_done --> |No| run_job
end
subgraph timeout_service[Timeout Service]
get_nodes[Get nodes <br /> with state=running/available/closing] --> node_timedout{Node timed out?}
verify_avilable_nodes{Node state is available?} --> |Yes| hold_off_reached{Hold off reached?}
hold_off_reached --> |Yes| child_nodes_completed{All child <br />nodes completed ?}
child_nodes_completed --> |Yes| set_done[Set parent and child nodes <br /> state=done]
child_nodes_completed --> |No| set_closing[Set node <br />state=closing]
node_timedout --> |Yes| set_done
node_timedout --> |No| verify_avilable_nodes
end
subgraph test_report_service[Test Report Service]
received_tarball{Received checkout node? } --> |Yes| email_report[Generate and <br />email test report]
end
set_done --> |event: <br />updated <br /> state=done| received_tarball
test_report_service --> stop([Stop])
Here’s a description of each client script:
The pipeline starts with the trigger script. The Trigger periodically checks whether a new kernel revision has appeared on a git branch. If so, it firsts checks if API has already created a node with the record. If not, it then pushes one node named “checkout”. The node’s state will be “available” and the result is not defined yet. This will generate pub/sub event of node creation.
When the trigger pushes a new revision node (checkout), the tarball receives a pub/sub event. The tarball then updates a local git checkout of the full kernel source tree. Then it makes a tarball with the source code and pushes it to the API storage. The state of the checkout node will be updated to ‘available’ and the holdoff time will be set. The URL of the tarball is also added to the artifacts of the revision node.
The Runner step listens for pub/sub events about available checkout node. It will then schedule some jobs (it can be any kind of job including build and test) to be run in various runtime environments as defined in the pipeline YAML configuration from the Core tools. A node is pushed to the API with “available” state e.g. “kunit” node. This will generate pub/sub event of build or test node creation.
The jobs added by runner will be run in specified runtime environment i.e. shell, Kubernetes or LAVA lab. Each environment needs to have its own API token set up locally to be able to submit the results to API. It updates the node with state “done” and result (pass, fail, or skip). This will generate pub/sub event of node update.
The timeout service periodically checks all nodes’ state. If a node is not in “done” state, then it checks whether the maximum wait time (timeout) is over. If so, it sets the node and all its child nodes to “done” state. If the node is in “available” state and not timed-out, it will check for holdoff time. If the holdoff reached, and all its child nodes are completed, the node state will be moved to “done”, otherwise the state will be set to “closing”. The parent node with “closing” state can not have any new child nodes. This will generate pub/sub event of node update.
The Test Report in its current state listens for completed checkout node. It then generates a test report along with the child nodes’ details and sends the report over an email.