From Fedora Project Wiki

(→‎Test Objects: Getting test results: system_output raises an exception if the command fails)
(Integrated into Writing_AutoQA_Tests)
 
(One intermediate revision by the same user not shown)
Line 1: Line 1:
== Will's notes (to be integrated into main page) ==
=== Control Files ===
The control file is actually interpreted as a Python script. So you can do any of the normal pythonic things you might want to do.


Before it reads the control file, Autotest imports all the symbols from the <code>autotest_lib.client.bin.util</code> module.<ref>http://autotest.kernel.org/browser/branches/0.10.1/client/bin/job.py#L19</ref> This means the control files can use any function defined in <code>common_lib.utils</code> or <code>bin.base_utils</code><ref>http://autotest.kernel.org/browser/branches/0.10.1/client/bin/utils.py</ref>. This lets you do things like:
<pre>arch = get_arch()
baseurl = '%s/development/%s/os/' % (mirror_baseurl, arch)
job.run_test('some_rawhide_test', arch=arch, baseurl=baseurl)</pre>
since <code>get_arch</code> is defined in common_lib.utils.
=== Test Objects: Getting test results ===
For simple tests, the result of the test is determined by the exit code of the command. Usually you'll run the test like this:
<pre>self.results = utils.system_output(cmd, retain_output=True)</pre>
If <code>cmd</code> is successful (i.e. it returns an exit status of 0) then <code>utils.system_output()</code> will return a CmdResult object. Otherwise it will raise <code>error.CmdError</code>. This means that <i>if the test command fails an exception will be raised, and the test will exit immediately unless you handle it.</i>.
Further test-level info can be returned by using <code>test.write_test_keyval(dict)</code>:
<pre>
extrainfo = dict()
for line in self.results.stdout:
    if line.startswith("kernel version "):
        extrainfo['kernelver'] = line.split()[3]
    ...
self.write_test_keyval(extrainfo)
</pre>
* For per-iteration data (performance numbers, etc) there are three methods:
** Just attr: <code>test.write_attr_keyval(attr_dict)</code>
** Just perf: <code>test.write_perf_keyval(perf_dict)</code>
** Both: <code>test.write_iteration_keyval(attr_dict, perf_dict)</code>
=== Test Objects: Attributes for directories ===
<code>test</code> objects have the following attributes available<ref>http://autotest.kernel.org/browser/branches/0.10.1/client/common_lib/test.py#L9</ref>:
<pre>
outputdir      eg. results/<job>/<testname.tag>
resultsdir      eg. results/<job>/<testname.tag>/results
profdir        eg. results/<job>/<testname.tag>/profiling
debugdir        eg. results/<job>/<testname.tag>/debug
bindir          eg. tests/<test>
src            eg. tests/<test>/src
tmpdir          eg. tmp/<tempname>_<testname.tag>
</pre>
<references/>

Latest revision as of 20:57, 25 August 2009