2020-07-23 15:19:35 +02:00
|
|
|
|
# Graphics / NXWidgets / Unit Tests
|
2012-03-22 22:22:59 +01:00
|
|
|
|
|
|
|
|
|
This directory contains a collection of Unit Tests that can be used to verify
|
|
|
|
|
NXWidgets.:
|
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
## Contents
|
|
|
|
|
|
|
|
|
|
**Installing and Building the Unit Tests**
|
2012-03-22 22:22:59 +01:00
|
|
|
|
|
|
|
|
|
1. Setup NuttX
|
2020-07-23 15:19:35 +02:00
|
|
|
|
1. Configure NuttX
|
|
|
|
|
2. Enable C++ Support
|
|
|
|
|
3. Enable Debug Options
|
|
|
|
|
4. Special configuration requirements for the nxwm unit test
|
|
|
|
|
5. Other `.config` file changes – NSH configurations only
|
|
|
|
|
6. Other `.config` file changes – NON-NSH configurations only
|
|
|
|
|
2. Adjust the Stack Size
|
|
|
|
|
3. Build NuttX including the unit test and the NXWidgets library
|
|
|
|
|
|
|
|
|
|
**Work-Arounds**
|
2012-03-22 22:22:59 +01:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
1. Build Issues
|
2012-03-22 22:22:59 +01:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
**Unit Test Directories**
|
|
|
|
|
|
|
|
|
|
## Installing and Building the Unit Tests
|
|
|
|
|
|
|
|
|
|
1. Setup NuttX
|
2012-03-22 22:22:59 +01:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
1. Configure NuttX
|
2012-05-17 00:43:40 +02:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
Configure NuttX to run one of the target configurations. For example,
|
|
|
|
|
let's assume that you are using the `sim/nsh2` configuration. The
|
|
|
|
|
`sim/nsh2` configuration was specially created for use NXWidgets on the
|
|
|
|
|
simulation platform. A similar, special configuration `stm3210e-eval/nsh2`
|
|
|
|
|
is also for the `STM3210E-EVAL` available. However, the unit test can be
|
|
|
|
|
run on other configurations (see steps d and e below).
|
2012-05-01 22:36:19 +02:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
**Note**: There are some other special configurationsrecommended for
|
|
|
|
|
unit-leveling testing of NxWM because the configuration is more complex in
|
|
|
|
|
that case. These are:
|
2012-03-22 22:22:59 +01:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
1) `sim/nxwmm`, or the simulated platform (no touchscreen), and
|
|
|
|
|
2) `stm3240g-evel`, for the `STM3240G-EVAL` board (with the STMPE11
|
|
|
|
|
touchscreen)
|
2012-03-22 22:22:59 +01:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
We will assume the `sim/nsh2` configuration in this discussion. The
|
|
|
|
|
`sim/nsh2` configuration is installed as follows:
|
2012-03-22 22:22:59 +01:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
```bash
|
|
|
|
|
cd <nuttx-directory-path>
|
|
|
|
|
make distclean
|
|
|
|
|
tools/configure.sh sim:nsh2
|
|
|
|
|
```
|
2014-04-14 00:26:44 +02:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
Where:
|
2012-03-22 22:22:59 +01:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
`<nuttx-directory-path>` is the full, absolute path to the NuttX build
|
|
|
|
|
directory
|
2012-03-22 22:22:59 +01:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
If you are using the `sim/nsh2` or `stm3210e-eval` configurations, then
|
|
|
|
|
skip to step 2 (Hmmm.. better check 1d) too).
|
2014-04-14 00:26:44 +02:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
There may be certain requirements for the configuration that you select...
|
|
|
|
|
for example, certain widget tests may require touchscreen support or
|
|
|
|
|
special font selections. These test-specific requirements are addressed
|
|
|
|
|
below under _Unit Test Directories_
|
2012-03-22 22:22:59 +01:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
2. Enable C++ Support
|
2012-03-22 22:22:59 +01:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
If you are not using the `sim/nsh2` or `stm3210e-eval`, you will need to
|
|
|
|
|
add the following definitions to the NuttX configuration at
|
|
|
|
|
`nuttx/.config` to enable C++ support:
|
2012-03-22 22:22:59 +01:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
```conf
|
|
|
|
|
CONFIG_HAVE_CXX=y
|
|
|
|
|
```
|
2012-03-22 22:22:59 +01:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
Check first, some configurations already have C++ support enabled (As of
|
|
|
|
|
this writing **ONLY** the `sim/nsh2` and `stm321-e-eval` configurations
|
|
|
|
|
have C++ support pre-enabled).
|
2012-03-22 22:22:59 +01:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
3. Enable Debug Options
|
2014-04-14 00:26:44 +02:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
If you are running on a simulated target, then you might also want to
|
|
|
|
|
enable debug symbols:
|
2012-03-22 22:22:59 +01:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
```conf
|
|
|
|
|
CONFIG_DEBUG_SYMBOLS=y
|
|
|
|
|
```
|
2014-04-14 00:26:44 +02:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
Then you can run the simulation using GDB or DDD which is a very powerful
|
|
|
|
|
debugging environment!
|
2012-05-01 22:36:19 +02:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
4. Special configuration requirements for the nxwm unit test.
|
2014-04-14 00:26:44 +02:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
```conf
|
|
|
|
|
CONFIG_NXTERM=y
|
|
|
|
|
```
|
2012-03-22 22:22:59 +01:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
5. Other `.config` file changes – NSH configurations only.
|
2012-03-22 22:22:59 +01:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
If the configuration that you are using supports NSH and NSH built-in
|
|
|
|
|
tasks then all is well. If it is an NSH configuration, then you will have
|
|
|
|
|
to define the following in your `nuttx/.config` file as well (if it is not
|
|
|
|
|
already defined):
|
2012-03-22 22:22:59 +01:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
```conf
|
|
|
|
|
CONFIG_NSH_BUILTIN_APPS=y
|
|
|
|
|
```
|
2012-09-17 20:43:00 +02:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
`sim/nsh2` and `stm3210e-eval/nsh2` already has this setting. You do not
|
|
|
|
|
need to change anything further in the `nuttx/.config` file if you are
|
|
|
|
|
using either of these configurations.
|
2012-09-17 20:43:00 +02:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
6. Other `.config` file changes – NON-NSH configurations only.
|
2012-09-17 20:43:00 +02:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
Entry Point. You will need to set the entry point in the .config file. For
|
|
|
|
|
NSH configurations, the entry point will always be `nsh_main` and you will
|
|
|
|
|
see that setting like:
|
2012-09-17 20:43:00 +02:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
```conf
|
2021-12-25 11:05:15 +01:00
|
|
|
|
CONFIG_INIT_ENTRYPOINT="nsh_main"
|
2020-07-23 15:19:35 +02:00
|
|
|
|
```
|
2012-09-17 20:43:00 +02:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
If you are not using in NSH, then each unit test has a unique entry point.
|
|
|
|
|
That entry point is the name of the unit test directory in all lower case
|
|
|
|
|
plus the suffix `_main`. So, for example, the correct entry for the
|
|
|
|
|
`UnitTests/CButton` would be:
|
2012-09-17 20:43:00 +02:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
```conf
|
2021-12-25 11:05:15 +01:00
|
|
|
|
CONFIG_INIT_ENTRYPOINT="cbutton_main"
|
2020-07-23 15:19:35 +02:00
|
|
|
|
```
|
2012-09-17 20:43:00 +02:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
And the correct entry point for `UnitTests/nxwm` would be:
|
2012-03-22 22:22:59 +01:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
```conf
|
2021-12-25 11:05:15 +01:00
|
|
|
|
CONFIG_INIT_ENTRYPOINT="nxwm_main"
|
2020-07-23 15:19:35 +02:00
|
|
|
|
```
|
2012-03-22 22:22:59 +01:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
etc.
|
|
|
|
|
|
|
|
|
|
For non-NSH configurations (such as the `sim/touchscreen`) you will have
|
|
|
|
|
to remove the configuration setting that provided the `main` function so
|
|
|
|
|
that you use the `main` in the unit test code instead. So, for example,
|
|
|
|
|
with the `sim/touchscreen` configuration you need to remove the following
|
|
|
|
|
from the NuttX configuration file (`.config`):
|
|
|
|
|
|
|
|
|
|
```conf
|
|
|
|
|
CONFIG_EXAMPLES_TOUSCHCREEN=y ## REMOVE (provided "tc_main")
|
|
|
|
|
```
|
2012-03-22 22:22:59 +01:00
|
|
|
|
|
2018-09-16 17:25:32 +02:00
|
|
|
|
2. Adjust the Stack Size
|
2012-03-22 22:22:59 +01:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
If using an simulation configuration (like `sim/nsh2`) and your unit test
|
|
|
|
|
uses X11 as its display device, then you would have to increase the size of
|
|
|
|
|
unit test stack as described below under _Stack Size Issues with the X11
|
|
|
|
|
Simulation_.
|
2012-03-22 22:22:59 +01:00
|
|
|
|
|
2018-09-16 17:25:32 +02:00
|
|
|
|
3. Build NuttX including the unit test and the NXWidgets library
|
2012-03-22 22:22:59 +01:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
```bash
|
|
|
|
|
cd <nuttx-directory-path>
|
|
|
|
|
. ./setenv.sh
|
|
|
|
|
make
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
## Work-Arounds
|
2012-03-22 22:22:59 +01:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
### Build Issues
|
2012-03-22 22:22:59 +01:00
|
|
|
|
|
|
|
|
|
1. I have seen this error on Cygwin building C++ code:
|
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
```
|
2012-03-22 22:22:59 +01:00
|
|
|
|
LD: nuttx.rel
|
|
|
|
|
ld: skipping incompatible /home/patacongo/projects/nuttx/nuttx/trunk/nuttx/libxx//liblibxx.a when searching for -llibxx
|
|
|
|
|
ld: cannot find -llibxx
|
2020-07-23 15:19:35 +02:00
|
|
|
|
```
|
2012-03-22 22:22:59 +01:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
The problem seems to be caused because `gcc` build code for 32-bit mode and
|
|
|
|
|
`g++` builds code for 64-bit mode. Add the `-m32` option to the `g++` command
|
|
|
|
|
line seems to fix the problem. In `Make.defs`:
|
2012-03-22 22:22:59 +01:00
|
|
|
|
|
2020-07-23 15:19:35 +02:00
|
|
|
|
```makefile
|
2012-03-22 22:22:59 +01:00
|
|
|
|
CXXFLAGS = -m32 $(ARCHWARNINGSXX) $(ARCHOPTIMIZATION) \
|
2022-02-20 13:20:19 +01:00
|
|
|
|
$(ARCHCXXFLAGS) $(ARCHINCLUDESXX) $(ARCHDEFINES) $(EXTRADEFINES) -pipe
|
2020-07-23 15:19:35 +02:00
|
|
|
|
```
|
2012-03-22 22:22:59 +01:00
|
|
|
|
|
|
|
|
|
2. Stack Size Issues with the X11 Simulation
|
2014-04-14 00:26:44 +02:00
|
|
|
|
|
2012-03-22 22:22:59 +01:00
|
|
|
|
When you run the NuttX simulation, it uses stacks allocated by NuttX from the
|
2020-07-23 15:19:35 +02:00
|
|
|
|
NuttX heap. The memory management model is exactly the same in the simulation
|
|
|
|
|
as it is real, target system. This is good because this produces a higher
|
2012-03-22 22:22:59 +01:00
|
|
|
|
fidelity simulation.
|
|
|
|
|
|
|
|
|
|
However, when the simulation calls into Linux/Cygwin libraries, it will still
|
2020-07-23 15:19:35 +02:00
|
|
|
|
use these small simulation stacks. This happens, for example, when you call
|
2012-03-22 22:22:59 +01:00
|
|
|
|
into the system to get and put characters to the console window or when you
|
2020-07-23 15:19:35 +02:00
|
|
|
|
make x11 calls into the system. The programming model within those libraries
|
2012-03-22 22:22:59 +01:00
|
|
|
|
will assume a Linux/Cygwin environment where the stack size grows dynamically
|
|
|
|
|
|
|
|
|
|
As a consequence, those system libraries may allocate large data structures
|
2020-07-23 15:19:35 +02:00
|
|
|
|
on the stack and overflow the small NuttX stacks. X11, in particular,
|
|
|
|
|
requires large stacks. If you are using X11 in the simulation, make sure that
|
|
|
|
|
you set aside a "lot" of stack for the X11 system calls (maybe 8 or 16Kb).
|
|
|
|
|
The stack size for the thread that begins with user start is controlled by
|
|
|
|
|
the configuration setting `CONFIG_USERMAIN_STACKSIZE`; you may need to
|
2012-03-22 22:22:59 +01:00
|
|
|
|
increase this value to larger number to survive the X11 system calls.
|
|
|
|
|
|
|
|
|
|
If you are running X11 applications as NSH add-on programs, then the stack
|
2020-07-23 15:19:35 +02:00
|
|
|
|
size of the add-on program is controlled in another way. Here are the steps
|
|
|
|
|
for increasing the stack size in that case:
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
cd ../apps/namedapps # Go to the namedapps directory
|
|
|
|
|
vi namedapps_list.h # Edit this file and increase the stack size of the add-on
|
|
|
|
|
rm .built *.o # This will force the namedapps logic to rebuild
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
## Unit Tests
|
|
|
|
|
|
|
|
|
|
The following provide simple unit tests for each of the NXWidgets. In addition,
|
|
|
|
|
these unit tests provide examples for the use of each widget type.
|
|
|
|
|
|
|
|
|
|
- `CButton`
|
|
|
|
|
- Exercises the `CButton` widget.
|
|
|
|
|
- Depends on `CLabel`.
|
|
|
|
|
- `CButtonArray`
|
|
|
|
|
- Exercises the `CButtonArray` widget.
|
|
|
|
|
- `CCheckBox`
|
|
|
|
|
- Exercises the `CCheckBox` widget.
|
|
|
|
|
- Depends on `CLabel` and `CButton`.
|
|
|
|
|
- `CGlyphButton`
|
|
|
|
|
- Exercises the `CGlyphButton` widget.
|
|
|
|
|
- Depends on `CLabel` and `CButton`.
|
|
|
|
|
- `CImage`
|
|
|
|
|
- Exercises the `CImage` widget.
|
|
|
|
|
- `CLabel`
|
|
|
|
|
- Exercises the `CLabel` widget.
|
|
|
|
|
- `CProgressBar`
|
|
|
|
|
- Exercises the `CProgressBar` widget.
|
|
|
|
|
- `CRadioButton`
|
|
|
|
|
- Exercises the `CRadioButton` and `CRadioButtonGroup` widgets.
|
|
|
|
|
- Depends on `CLabel` and `CButton`.
|
|
|
|
|
- `CScrollBarHorizontal`
|
|
|
|
|
- Exercises the `ScrollbarHorizontal`.
|
|
|
|
|
- Depends on `CSliderHorizontal` and `CGlyphButton`.
|
|
|
|
|
- `CScrollBarVertical`
|
|
|
|
|
- Exercises the `ScrollbarHorizontal`.
|
|
|
|
|
- Depends on `CSliderVertical` and `CGlyphButton`.
|
|
|
|
|
- `CSliderHorizontal`
|
|
|
|
|
- Exercises the `CSliderHorizontal`.
|
|
|
|
|
- Depends on `CSliderHorizontalGrip`.
|
|
|
|
|
- `CSliderVertical`
|
|
|
|
|
- Exercises the `CSliderVertical`.
|
|
|
|
|
- Depends on `CSliderVerticalGrip`.
|
|
|
|
|
- `CTextBox`
|
|
|
|
|
- Exercises the `CTextBox` widget.
|
|
|
|
|
- Depends on `CLabel`.
|