mirror of
https://github.com/QuantumLeaps/qpc.git
synced 2025-01-14 06:43:19 +08:00
159 lines
9.3 KiB
Plaintext
159 lines
9.3 KiB
Plaintext
/*! @page exa_qutest Examples for QUTest Unit Testing Harness
|
|
|
|
@tableofcontents
|
|
|
|
<p>The examples in the <span class="img folder">qpc/examples/qutest</span> directory demonstrate how to test embedded code with the [<b>QUTest</b>](https://www.state-machine.com/qtools/qutest.html) unit testing harness. Currently, the following examples are provided:
|
|
</p>
|
|
|
|
- <span class="img folder">blinky</span> — Simple "Blinky" single-active-object application
|
|
- <span class="img folder">dpp</span> — DPP application from Chapter 9 of PSiCC2
|
|
- <span class="img folder">evt-par</span> — testing events with parameters
|
|
- <span class="img folder">qhsmtst</span> — Test State Machine based on ::QHsm with QM model
|
|
- <span class="img folder">qmsmtst</span> — Test State Machine based on ::QMsm with QM model
|
|
- <span class="img folder">unity_basic</span> — Comparison of a basic testing with Unity and QUTest
|
|
- <span class="img folder">unity_mock</span> — Comparison of a advanced testing (mocking) with Unity and QUTest
|
|
|
|
|
|
|
|
@section exa_qutest-dir General Code Organization
|
|
The projects within the <span class="img folder">examples/qutest</span> directory have the customary structure used for testing. The production code to be tested is located in the <span class="img folder">src</span> sub-directory. The testing code is located in the <span class="img folder">test_...</span> sub-folder(s). The following directory tree illustrates the structure for the `dpp` example:
|
|
|
|
|
|
<ul class="tag">
|
|
<li><span class="img folder">examples/</span>
|
|
</li>
|
|
<ul class="tag">
|
|
<li><span class="img folder">qutest/</span> — Examples for QUTest unit testing harness
|
|
</li>
|
|
<ul class="tag">
|
|
<li><span class="img folder">dpp/</span> — The simple Blinky example
|
|
</li>
|
|
<ul class="tag">
|
|
<li><span class="img folder">src/</span> — source code under test <span class="tag">A</span>
|
|
</li>
|
|
<ul class="tag">
|
|
<li><span class="img file_h">bsp.h</span> — BSP header
|
|
</li>
|
|
<li><span class="img file_h">dpp.h</span> — DPP header
|
|
</li>
|
|
<li><span class="img file_qm">dpp.qm</span> — DPP model
|
|
</li>
|
|
<li><span class="img file_c">philo.c</span> — `Philo` active object
|
|
</li>
|
|
<li><span class="img file_c">table.c</span> — `Table` active object
|
|
</li>
|
|
</ul>
|
|
</ul>
|
|
<ul class="tag">
|
|
<li><span class="img folder">test_philo/</span> — code for unit testing of `Philo` AO <span class="tag">B</span>
|
|
</li>
|
|
<ul class="tag">
|
|
<li><span class="img file_mak">Makefile</span> — cross-platform makefile (host)
|
|
</li>
|
|
<li><span class="img file_c">test_philo.c</span> — test fixture for `Philo` AO
|
|
</li>
|
|
<li><span class="img file_py">test_philo.py</span> — test script for `Philo` (Python)
|
|
</li>
|
|
<li><span class="img file_tcl">test_philo.tcl</span> — test script for `Philo` (Tcl)
|
|
</li>
|
|
</ul>
|
|
</ul>
|
|
<ul class="tag">
|
|
<li><span class="img folder">test_table/</span> — code for unit testing of `Table` AO <span class="tag">B</span>
|
|
</li>
|
|
<ul class="tag">
|
|
<li><span class="img file_mak">Makefile</span> — cross-platform makefile (host)
|
|
</li>
|
|
<li><span class="img file_c">test_philo.c</span> — test fixture for `Table` AO
|
|
</li>
|
|
<li><span class="img file_py">test_philo.py</span> — test script for `Table` (Python)
|
|
</li>
|
|
<li><span class="img file_tcl">test_philo.tcl</span> — test script for `Table` (Tcl)
|
|
</li>
|
|
</ul>
|
|
</ul>
|
|
<ul class="tag">
|
|
<li><span class="img folder">test_dpp/</span> — code for unit testing of DPP application <span class="tag">C</span>
|
|
</li>
|
|
<ul class="tag">
|
|
<li><span class="img file_mak">Makefile</span> — cross-platform makefile (host)
|
|
</li>
|
|
<li><span class="img file_mak">make_efm32</span> — makefile for the EFM32 **embedded board**
|
|
</li>
|
|
<li><span class="img file_mak">make_tm4c123</span> — makefile for the TM4C123 **embedded board**
|
|
</li>
|
|
<li><span class="img file_c">main.c</span> — `main()` function for DPP application
|
|
</li>
|
|
<li><span class="img file_c">test_dpp.c</span> — test fixture for DPP application
|
|
</li>
|
|
<li><span class="img file_py">test_init.py</span> — test script for DPP initialization (Python)
|
|
</li>
|
|
<li><span class="img file_tcl">test_init.tcl</span> — test script for DPP initialization (Tcl)
|
|
</li>
|
|
<li><span class="img file_py">test_tick.py</span> — test script for DPP tick processing (Python)
|
|
</li>
|
|
<li><span class="img file_tcl">test_tick.tcl</span> — test script for DPP tick processing (Tcl)
|
|
</li>
|
|
</ul>
|
|
</ul>
|
|
<li><span class="img folder">.../</span> — Other QUTest examples...
|
|
</li>
|
|
<li><span class="img folder">target_efm32/</span> — Code for the **embedded target** (EFM32) <span class="tag">D</span>
|
|
</li>
|
|
<li><span class="img folder">target_tm4c123/</span> — Code for the **embedded target** (TM4C123) <span class="tag">D</span>
|
|
</li>
|
|
</ul>
|
|
</ul>
|
|
</ul>
|
|
|
|
<ul class="tag">
|
|
<li><span class="tag">A</span> The <span class="img folder">src</span> sub-directory contains the production code to be tested. This directory contains the <span class="img file_qm">.qm</span> model file as well as the generated code from the model.
|
|
</li>
|
|
|
|
<li><span class="tag">B</span> The <span class="img folder">test_philo</span> sub-directory contains the unit test code for a component, such as `Philo` in this case. Here, you can find the <span class="img file_c">test_*.c</span> **test fixture**, the test scripts <span class="img file_py">test_*.py</span> (Python) and <span class="img file_tcl">test_*.tcl</span> (Tcl) as well as the cross-platform <span class="img file_mak">Makefile</span> to build the code and *run* the tests on the host.
|
|
</li>
|
|
|
|
<li><span class="tag">C</span> The <span class="img folder">test_dpp</span> sub-directory contains integration-test code for the application, such as `DPP` in this case. The objective is to test the initialization and interactions *among* components. Here, you can find the <span class="img file_c">main.c</span> `main()` function as well as the <span class="img file_c">test_dpp.c</span> *test fixture*. This directory also contains <span class="img file_mak">make_*</span> *makefiles* to build and run the code on the **embedded targets**.
|
|
</li>
|
|
|
|
<li><span class="tag">D</span> The <span class="img folder">target_efm32</span> sub-directory contains the Code needed to build and run the test code on the **embedded target**, like EFM32 in this case.
|
|
</li>
|
|
</ul>
|
|
|
|
|
|
|
|
@section exa_qutest-test Building and Running the Tests
|
|
As usual in Test-Driven Development (TDD), the provided <span class="img file_mak">Makefiles</span> both *build* the code and *run* the tests.
|
|
|
|
|
|
|
|
@subsection exa_qutest_host Host Computers
|
|
Typically, you start testing on your host computer. Before building/running the code, you need to open a terminal window and launch the [QSPY host application](https://www.state-machine.com/qtools/qspy.html) with the `-t` [command-line option](https://www.state-machine.com/qtools/qspy.html#qspy_command).
|
|
|
|
Next, you open another terminal window, change directory to the <span class="img folder">test_...</span> folder of interest, and type `make`. This will build the application and run the tests (Python), as shown in the screen shot below:
|
|
|
|
![Testing on the host (Python)](qutest_py.png)
|
|
|
|
To use the Tcl scripts, you invoke the `make` with the `SCRIPT=tcl` symbol:
|
|
|
|
![Testing on the host (Tcl)](qutest_tcl.png)
|
|
|
|
|
|
|
|
@subsection exa_qutest_target Embedded Targets
|
|
The QUTest testing system allows you also to easily test the code directly on the embedded target board. The <span class="img folder">dpp/test_dpp/</span> directory illustrates this option by providing the `makefiles` for embedded boards, such as the TM4C123 (Tiva LaunchPad) <span class="img file_mak">make_tm4c123</span>.
|
|
|
|
To test the code on an embedded board, you need to connect the board to the host computer and launch the and launch the [QSPY host application](https://www.state-machine.com/qtools/qspy.html) with the `-c COM<n>` [command-line option](https://www.state-machine.com/qtools/qspy.html#qspy_command), where `<n>` is the specific COM port number on your host that the board is using.
|
|
|
|
Next, you open another terminal window, change directory to the <span class="img folder">test_...</span> folder of interest, and type `make -f make_tm4c123`. This will build the application and run the tests (Python), as shown in the screen shot below:
|
|
|
|
![Testing on the TM4C123 embedded target (Python)](qutest_tm4c123_py.png)
|
|
|
|
To use the Tcl scripts, you invoke the `make -f make_tm4c123` with the `SCRIPT=tcl` symbol:
|
|
|
|
![Testing on the TM4C123 embedded target (Tcl)](qutest_tm4c123_tcl.png)
|
|
|
|
|
|
@next{exa_os}
|
|
*/
|