-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathREADME
159 lines (122 loc) · 7.4 KB
/
README
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
Introduction
============
wtf is the "Wireless Test Framework". It is a collection of test suites for
validating various wifi functionality on various wifi devices. wtf runs on an
Ununtu Linux development machine and makes heavy use of python.
Architecture? Philosophy? You decide.
=======================================
It's something like this: You the user instruct the test driver to run a test,
a test suite, or a bunch of test suites. The test driver finds the test and
runs it. The test is essentially a sequence of platform-independent commands
that set up the nodes involved in the test, run the test, gather the results,
analyze the results, and finally report whether the test passed or failed. The
node maps platform-independent commands such as "scan", "associate", and "ping"
to platform-specific commands such as "iw", "ifconfig", etc. The comm driver
passes the command to the nodes via some interface, such as an ssh connection
or a serial port.
wtf knows which comm drivers to use because you specify each node in the
configuration file, which is typically called wtfconfig.py. The comm driver
is a property of the nodes.
wtf is meant to be reusable for different targets. This is why we bothered to
introduce all of these blocks instead of just having one big block called "test
suite." Suppose you're developing a system comprised of a debian Linux client
STA with a new mac80211 driver for the Fancypants wifi chip, and the latest
stable hostapd AP running on a stable b43 card on a different debian Linux
machine. Perhaps you communicate with these debian machines using familiar
bash command line utilities via openssh connections. You write a test suite
that ensures that the new STA parts successfully communicate with hostapd,
debugging and releasing as you go.
Now suppose that because you did such a fantastic job on the Fancypants driver,
Fancypants' heavyweight customer MegaWorld wants to pay you solid money to make
the driver work on their ancient embedded Linux distribution (AEL). AEL uses
busybox's sh instead of bash and dropbear ssh instead of openssh. You want to
reuse the tests that you wrote for the Fancypants project. You think: "I know!
I'll fork the tests and hack them to work with dropbear and sh." Wrong answer!
The correct answer is: "In know! I'll inherit the linux STA node to create the
busybox/sh node, and override the functions that don't work. Next, I'll
inherit the ssh com driver and override as necessary to work with dropbear."
Correct!
Because you chose to re-use your existing tests, the AEL port not only goes
smoothly, it goes quickly. MegaWorld management is so happy with your work
that they send you for a week-long vacation in Hawaii using only a fraction of
the money that you saved them. And then they hire you to make ad-hoc mode work
with AEL and the Fancypants wifi chip. You humbly accept the job, and then
think about how you will test this. At first you say: "I know! I'll fork the
tests and hack them so that they test ad-hoc mode." Wrong answer! The correct
answer is: "I know! First I'll add suitable commands to start and stop ad-hoc
mode to the busybox/sh node. Then I'll make an ad-hoc mode test suite. Oooh
look! I can factor out this iperf test from the STA-AP tests and share it with
the ad-hoc mode test suite. Fun!" Be sure to document the new
platform-independent ad-hoc API that you just introduced.
MegaWorld cannot get enough! They double your engineering budget and your
co-worker Luisca joins the project. Luisca has a PhD in bacterial networking,
and you're not quite sure what it is that he is going to be doing. But he
needs a work environment similar to yours. And his code is going in the same
repository as yours. And you want to ensure that he doesn't break your nice,
stable contribution. So you direct him to two places: the first is this
README, so that he knows how to run the tests. This diminishes the chance that
he breaks your stuff. You also direct him to the platform-specific bring-up
instructions in platform/mega-world-ael/README, and to the sample wtfconf.py
file in platform/mega-world-ael/. Luisca is up and running with minimal help
from you because he has everything he needs to duplicate your work.
How to acutally use wtf
=======================
1. Set up test nodes
The first thing you need is an idea about what your testing. For example,
suppose you're testing an AP that is based on hostapd. You'll need a way to
configure the AP from your development machine, such as SSH or serial port.
You'll also need a client STA to test against. This node should also be
accessible from your dev machine. So collect nodes that will play all the
roles for the test scenario, set them up, and be sure that you can connect to
them from your dev machine.
2. Identify which test suite(s) you will be running.
Each test suite is in its own file in the tests directory. Snoop around there
and decide which test suite you want to run. If you don't see a test suite
that matches what you are trying to test, you can write a new one.
3. Create a wtfconfig.py file.
This file should be in the directory from which you will run the test suite.
You're best bet is to base it on a sample wtfconfig.py file in one of the
platforms directory. If you don't want to call your wtfconfig.py file by that
name, you can call it something else and tell wtf the name with the -c
argument. The important details are these:
-- set the variable "wtf.conf" to be the configuration that you want wtf to
run.
-- wtf.conf simply extends wtf.config. It is constructed with an optional test
suite to run, various lists of nodes (e.g., a list of aps, a list of stas,
etc.), and a name. You must ensure that your configuration has all of the
nodes that will be required by the test suite that you specify. For
example, the ap_sta test suite requires one ap and one sta.
Note that if you have some specific set up or tear down steps, you can add
these by overriding the config's setUp and tearDown functions. These will
be run before the test suite.
-- each node that you add to a config must be created using a supported node.
Some existing nodes include ap.Hostapd, and sta.LinuxSTA.
-- each node must have a comm driver. The comm driver is passed to the node
constructor. Existing drivers are comm.Serial and comm.SSH.
If your node or comm driver is not supported, consider adding it.
4. Run wtf
./wtf.py
Wanna see the actual names of the tests that are being run? Then:
./wtf.py -v
Wanna see all the commands and stdio flying around? Then:
./wtf.py -v -s
Wanna just run a single test? Then:
./wtf.py -v -s ./tests/ap_sta.py:TestAPSTA.test_open_associate
Other Notes
===========
-- wtf uses intermezzo coding style:
http://docs.python.org/tutorial/controlflow.html#intermezzo-coding-style
References
==========
nosetests is what we use for test discovery. It's quite capable. Here's a
more gentle intro than the actual docs:
http://ivory.idyll.org/articles/nose-intro.html
TODO
====
-- The wtf stuff is not laid out very nicely. Some stuff is in the __init__.py
files, the comm stuff probably doesn't really need to be so far removed from
the node stuff, etc. This needs to be cleaned up so it's easier to read.
It might even make sense just to put the whole mess into a wtf/node.py,
wtf/comm.py, etc.
-- Allow config file to specify multiple test suites.
-- Allow config file and command line to specify multiple configurations.