1 <?xml version="1.0" encoding="utf-8"?>
2 <!DOCTYPE article PUBLIC "-//OASIS//DTD Simplified DocBook XML V1.1//EN"
3 "http://docbook.org/xml/simple/1.1/sdocbook.dtd">
8 <title>Rearchitecting ATF: Road trip to 1.0</title>
11 <firstname>Julio</firstname>
12 <surname>Merino</surname>
14 <orgname>The NetBSD Foundation</orgname>
19 <section id="overview">
21 <title>Overview</title>
23 <para>This document describes the major steps to be taken before getting
24 to the first stable release of ATF, 1.0. Some of these steps describe
25 the transition from the old code base to the new ideas documented in the
26 specification (TODO: Add link somehow).</para>
30 <section id="plan-0-8">
32 <title>The plan to 0.8</title>
36 <listitem><para>Add atf-sh interface to build-time tests.</para></listitem>
38 <listitem><para>Properly document the libraries: i.e. one page per
39 module, detailed information of each function and type, etc. At the
40 very least atf-c.</para></listitem>
42 <listitem><para>Add a tool to collect multiple outputs of atf-run (from
43 different machines) and generate a single (XML-only?) log with
44 everything. Must allow easy conversion to HTML for online
45 publishing.</para></listitem>
47 <listitem><para>Allow grouping of test programs in tiers in an Atffile.
48 This is to permit the user specify "dependencies" between test programs:
49 e.g. do not run a specific test program if its dependencies have failed,
50 because it will certainly fail also.</para></listitem>
52 <listitem><para>Provide a kernel-level unit testing API (for NetBSD
53 only, at the moment). This should come in the form of an atf.ko module
54 that provides functions to define and register test cases, functions for
55 results reporting and an interface (a trivial file system?) that
56 transports the application/X-atf-tcs output to user-space, provides
57 information to user-space about the available test cases (a list) and
58 allows user-space to launch the execution of test
59 cases.</para></listitem>
65 <section id="plan-0-9">
67 <title>The plan to 0.9</title>
71 <listitem><para>Add a module to atf-c to manage dynamic memory. Should
72 provide a "mem chunk" object that can only be managed through functions
73 (i.e. not directly) so that access to buffers can be safely controlled.
74 Dealing with strdup and similar functions, for example, might be
77 <para>See these old revisions for a start, but these did not work
78 correctly because the use of (void **) casts brought aliasing
81 <para>78eeacf3b9284493e5e96b7866fc1d163a13bc02
82 8e200683a2b70eadca728c2e0347d4790777b3fc
83 872393ed0177cbcc30ffacede228eb3986c42ab7</para></listitem>
89 <section id="plan-pre-1-0">
91 <title>The plan to 1.0 prereleases</title>
95 <listitem><para>Fix all occurrences of XXX, TODO and
96 FIXME.</para></listitem>
98 <listitem><para>Split the distfile into multiple components. We should
99 have a component for each language binding and a component providing the
100 ATF tools, at the very least. If we had this, external programs using
101 ATF wouldn't need to depend on the tools and/or the C++ binding, because
102 they could just require the user to build the atf-c
103 binding.</para></listitem>
105 <listitem><para>Think of a way to properly add tests for (almost?) all
106 error paths. Most of them are probably broken
107 already.</para></listitem>
109 <listitem><para>Improve error reporting: aside from clarifying error
110 messages, this also implies adding more error cases to give them more
111 semantic meaning at the source code level..</para></listitem>
113 <listitem><para>Make the shell library work with 'set
114 -e'?</para></listitem>
116 <listitem><para>Shell test programs dynamically locate where the shell
117 library is by calling atf-config (done by atf.init.subr). Contrarywise,
118 binary test programs are directly linked against the final location of
119 libatf. It may be nice if the latter loaded the library dynamically
120 based on what atf-config said, so the user could switch atf
121 installations by simply changing its PATH (and effectively making atf
122 relocatable on the file system). Why could this be nice? To painlessly
123 run an older atf test suite against a more recent version of the code
124 base to ensure there are no regressions even with older tests. Just a
125 crazy idea, as maybe what the shell test programs currently do is
126 stupid.</para></listitem>
128 <listitem><para>Allow users to customize the build of atf by defining
129 additional meta-data for test cases. At the moment this is possible
130 because the meta-data is not sanity-checked, but I think it should be.
131 Following the previous item, NetBSD could add a 'netbsd.pr' variable and
132 then use this data when generating reports to add direct links to the
133 appropriate PRs.</para></listitem>
135 <listitem><para>Make sure that the tests in tests/atf have, at the very
136 least, the same coverage as the ones in
137 tests/bootstrap.</para></listitem>
139 <listitem><para>Document the code.</para></listitem>
141 <listitem><para>Possibly add a way to automatically gain or drop
142 privileges when require.user is set.</para></listitem>
144 <listitem><para>Add a way to specify which bug/issue/whatever a given
145 test case is stress-testing. This information is useful when detecting
146 regressions.</para></listitem>
152 <section id="plan-1.0-rc">
154 <title>The plan to 1.0 release candidates</title>
158 <listitem><para>Build libatf as a shared library and set -version-info
159 accordingly.</para></listitem>
161 <listitem><para>Set the DTDs' versions to 1.0.</para></listitem>
167 <section id="plan-unknown">
169 <title>The plan to releases after 1.0</title>
173 <listitem><para>Allow the parallel execution of tests. Achieving this
174 with a test program granularity is easy: only need to change atf-run.
175 Lowering it to a finer granularity (test cases) is harder and maybe not
176 worth it.</para></listitem>