93707cbabc
This should be a general test architecture, and yet allow specific tests to be done. Introduce a plugin architecture. An individual test has 4 stages, setup/execute/verify/teardown. Each plugin gets a chance to run a function at each stage, plus one call before all the tests are called ("pre" suite) and one after all the tests are called ("post" suite). In addition, just before each command is executed, the plugin gets a chance to modify the command using the "adjust_command" hook. This makes the test suite quite flexible. Future patches will take some functionality out of the tdc.py script and place it in plugins. To use the plugins, place the implementation in the plugins directory and run tdc.py. It will notice the plugins and use them. Signed-off-by: Brenda J. Butler <bjb@mojatatu.com> Acked-by: Lucas Bates <lucasb@mojatatu.com> Signed-off-by: David S. Miller <davem@davemloft.net>
28 lines
837 B
Plaintext
28 lines
837 B
Plaintext
tdc.py will look for plugins in a directory plugins off the cwd.
|
|
Make a set of numbered symbolic links from there to the actual plugins.
|
|
Eg:
|
|
|
|
tdc.py
|
|
plugin-lib/
|
|
plugins/
|
|
__init__.py
|
|
10-rootPlugin.py -> ../plugin-lib/rootPlugin.py
|
|
20-valgrindPlugin.py -> ../plugin-lib/valgrindPlugin.py
|
|
30-nsPlugin.py -> ../plugin-lib/nsPlugin.py
|
|
|
|
|
|
tdc.py will find them and use them.
|
|
|
|
|
|
rootPlugin
|
|
Check if the uid is root. If not, bail out.
|
|
|
|
valgrindPlugin
|
|
Run the command under test with valgrind, and produce an extra set of TAP results for the memory tests.
|
|
This plugin will write files to the cwd, called vgnd-xxx.log. These will contain
|
|
the valgrind output for test xxx. Any file matching the glob 'vgnd-*.log' will be
|
|
deleted at the end of the run.
|
|
|
|
nsPlugin
|
|
Run all the commands in a network namespace.
|