9. Glossary¶
- BSP
- A board support package supported by a test target
- BSP model
A combination of BSPs on which a test target works.
For example, the Arduino 101 x86 and arc BSPs that can work independently or together, the following BSP models would be supported: x86, arc and x86+arc.
- hash
In the context of tcf run, a hash is a six character code that uniquely identifies the test case name and the target/s where it ran along with its BSP model.
It stays stable across different runs.
- hashid
- Same as hash.
- herd
- Group of TCF servers that are meant to be used together, they all provide redundancy for targets of the same style.
- impromptu testcase driver
A Python test file implementing testcase driver that:
- contains a single class called _driver
- allows executing one or more test cases that have no file representation in the client’s filesystem
More details available.
- RunID
- A unique identifier for a run of testcases that groups the output and results of testcases. When specified, it will be prefixed to testcase output to clarify when it was generated.
- site
- Server herds can be split into sites, which is a subgroup of servers of the same herd that are physically located in the same place and might be sharing physical infrastructure
- static testcase
- A test case that doesn’t run on remote targets but in the local host where the test runner is executing.
- NUT
- Network Under Test or test network, to which test targets are connected. Usually isolated from the test infrastructure itself.
- POS
- Provisioning OS; operating system running on the test target that is used to provision the target’s drive.
- test case
A test case is a flow to evaluate a single requirement, feature or functionality.
A test case can be a program or a script
- testcase driver
A testcase driver is a script that when pointed to a file of any type in the client’s filesystem (not in the target’s), can determine if it can recognize it as something it can execute as a flow for evaluating a test case.
This allows test content written in anything than Python to be exectured by the automation process without modifying it. See
tcfl.tc.tc_c.is_testcase()
.- test target
Something that can be used to run a test case; this can be a group of actual HW units, not just a single one. It can be a computer, a light switch or a toaster.
Each test target has a name, a type and it might support zero or more BSPs (think for example, a board that has an x86 and an ARC processor, like the Arduino 101); as well it has a list of tags and values that describe its capabilities.
- target controller
- A piece of software that understands how to talk to a target
- test target broker
- A service/machine to which one or more test targets are connected. It offers an abstracted API to manipulate and operate them; the API is implemented via target-specific target controllers.
- target broker
- See test target broker.
- target driver
- Same as target controller
- test finder
- A piece of software that locates test cases by looking at tag strings that define them as such.
- test case finder
- Same as test finder
- test runner
- Linux machine that can drive the running and execution of test cases or command a target hardware to execute test cases.
- test case driver
this is the entity that runs on the test runner that understands how different test cases can be run.
eg: knows how to launch a @static test case
eg: knows how to interpret the output of a cetain type of test cases to decide what it is
- ttbd
- See test target broker
- run ID
- An identification tag for a particular run of a sequence of test cases in a set of targets