1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/tests
Jean Pierre Dudey 1edb8666cb tests/pkg_lvgl: fix sysmon example URL.
Signed-off-by: Jean Pierre Dudey <me@jeandudey.tech>
2020-11-08 15:05:56 +01:00
..
backtrace
bench_msg_pingpong
bench_mutex_pingpong
bench_runtime_coreapis
bench_sched_nop
bench_sizeof_coretypes
bench_sys_base64
bench_thread_flags_pingpong
bench_thread_yield_pingpong
bench_timers tests/*: realign ENABLE_DEBUG 2020-10-23 11:27:48 +02:00
bench_xtimer examples, tests: add feather-m0-lora to low memory boards 2020-11-05 15:08:21 +01:00
bench_xtimer_load
bitarithm_timings tests/*: add missing include of assert.h 2020-10-22 11:13:09 +02:00
blob
bloom_bytes
board_calliope-mini
board_microbit
build_system_cflags_spaces
build_system_utils
buttons
c11_atomics_cpp_compat tests/*: add missing include of assert.h 2020-10-22 11:13:09 +02:00
can_trx
candev tests/*: realign ENABLE_DEBUG 2020-10-23 11:27:48 +02:00
cb_mux
cb_mux_bench
cond_order
conn_can
cortexm_common_ldscript
cpp11_condition_variable
cpp11_mutex
cpp11_thread
cpp_ctors
cpp_exclude
cpp_ext
cpu_cortexm_address_check
cpu_efm32_features
devfs
disp_dev tests/*: remove unused assert.h include 2020-10-22 11:29:27 +02:00
driver_ad7746
driver_adcxx1c
driver_ads101x
driver_adt7310
driver_adxl345
driver_aip31068 tests/driver_aip31068: convert to xtimer_msleep() 2020-11-05 11:32:41 +01:00
driver_apa102
driver_apds99xx
driver_apds99xx_full
driver_at
driver_at24cxxx
driver_at24mac
driver_at25xxx
driver_at30tse75x
driver_at86rf2xx
driver_at86rf2xx_aes
driver_at86rf215 Merge pull request #14959 from benpicco/at86rf215-mr-fsk 2020-11-03 11:26:24 +01:00
driver_ata8520e
driver_atwinc15x0
driver_bh1750
driver_bh1900nux
driver_bme680 tests/driver_bme680: convert to xtimer_msleep() 2020-11-05 11:32:42 +01:00
driver_bmp180
driver_bmx055
driver_bmx280
driver_cc110x
driver_ccs811
driver_ccs811_full
driver_dcf77
driver_dfplayer tests/driver_dfplayer: convert to xtimer_msleep() 2020-11-05 11:32:42 +01:00
driver_dht
driver_dose
driver_ds18
driver_ds75lx
driver_ds1307
driver_ds3234
driver_dsp0401 tests/driver_dsp0401: convert to xtimer_msleep() 2020-11-05 11:32:42 +01:00
driver_dynamixel
driver_edbg_eui
driver_enc28j60
driver_encx24j600
driver_feetech
driver_fxos8700
driver_grove_ledbar
driver_hd44780
driver_hdc1000
driver_hih6130
driver_hmc5883l
driver_hts221
driver_ili9341
driver_ina2xx
driver_ina3221
driver_io1_xplained
driver_isl29020
driver_isl29125
driver_itg320x
driver_jc42 tests/driver_jc42: convert to xtimer_msleep() 2020-11-05 11:32:42 +01:00
driver_kw2xrf
driver_l3g4200d
driver_lc709203f
driver_lis2dh12 tests/*: add missing include of assert.h 2020-10-22 11:13:09 +02:00
driver_lis3dh
driver_lis3mdl
driver_lpd8808
driver_lpsxxx
driver_lsm6dsl
driver_lsm303dlhc
driver_ltc4150
driver_mag3110
driver_mhz19
driver_mma8x5x
driver_mma7660
driver_motor_driver
driver_mpl3115a2
driver_mpu9x50
driver_mpu9150
driver_mq3
driver_mrf24j40
driver_my9221
driver_netdev_common
driver_nrf24l01p_lowlevel
driver_nrfmin
driver_nvram_spi
driver_opt3001
driver_pca9633 tests/driver_pca9633: convert to xtimer_msleep() 2020-11-05 11:32:42 +01:00
driver_pca9685
driver_pcd8544
driver_ph_oem
driver_pir
driver_pn532
driver_pulse_counter
driver_qmc5883l
driver_rn2xx3
driver_scd30
driver_sdcard_spi tests/*: replace #if ENABLE_DEBUG with IS_ACTIVE 2020-11-02 21:49:39 +01:00
driver_sdp3x
driver_sds011
driver_seesaw_soil
driver_servo
driver_sht1x
driver_sht2x
driver_sht3x
driver_shtc1
driver_si70xx tests/driver_si70xx: convert to xtimer_msleep() 2020-11-05 11:32:42 +01:00
driver_si114x
driver_soft_spi
driver_soft_uart
driver_sps30
driver_srf02
driver_srf04
driver_srf08
driver_stmpe811
driver_sx127x
driver_tcs37727
driver_tmp00x
driver_tps6274x
driver_tsl2561
driver_tsl4531x
driver_vcnl40x0
driver_veml6070
driver_w5100
driver_ws281x
driver_xbee
eepreg
embunit
emcute
event_threads
event_wait_timeout tests/event_wait_timeout: convert to xtimer_msleep() 2020-11-05 11:32:42 +01:00
events tests/*: add explicit include of timex.h 2020-10-21 21:47:31 +02:00
evtimer_mbox
evtimer_msg tests/evtimer_msg: convert to xtimer_msleep() 2020-11-05 11:32:42 +01:00
evtimer_underflow
external_board_dirs
external_board_native
external_module_dirs
fault_handler
float
fmt_print
frac-config
gnrc_dhcpv6_client
gnrc_dhcpv6_client_6lbr
gnrc_gomach
gnrc_ipv6_ext
gnrc_ipv6_ext_frag tests/*: add missing include of assert.h 2020-10-22 11:13:09 +02:00
gnrc_ipv6_ext_opt
gnrc_ipv6_fwd_w_sub
gnrc_ipv6_nib tests/*: add explicit include of timex.h 2020-10-21 21:47:31 +02:00
gnrc_ipv6_nib_6ln tests/*: add explicit include of timex.h 2020-10-21 21:47:31 +02:00
gnrc_ipv6_nib_dns
gnrc_lwmac
gnrc_mac_timeout
gnrc_ndp
gnrc_netif tests/gnrc_netif: add tests to join and leave L2 groups 2020-10-29 14:38:52 +01:00
gnrc_netif_ieee802154
gnrc_rpl_p2p
gnrc_rpl_srh
gnrc_sixlowpan
gnrc_sixlowpan_frag
gnrc_sixlowpan_iphc_w_vrb
gnrc_sock_async_event
gnrc_sock_dns
gnrc_sock_ip tests/*: add missing include of assert.h 2020-10-22 11:13:09 +02:00
gnrc_sock_neterr
gnrc_sock_udp tests/*: add missing include of assert.h 2020-10-22 11:13:09 +02:00
gnrc_tcp
gnrc_udp
heap_cmd
ieee802154_hal Merge pull request #15275 from jia200x/pr/radio/config_phy_amendment 2020-10-26 23:28:45 +01:00
ieee802154_submac tests/*: add missing include of assert.h 2020-10-22 11:13:09 +02:00
irq
irq_disable_restore
isr_yield_higher
kconfig
kconfig_features
l2util Merge pull request #15287 from miri64/ethernet/enh/join-leave-mcast-group 2020-10-29 16:03:32 +01:00
leds
libc_newlib
log_color
log_printfnoformat
lua_loader
lwip
lwip_sock_ip tests/*: add missing include of assert.h 2020-10-22 11:13:09 +02:00
lwip_sock_tcp
lwip_sock_udp tests/*: add missing include of assert.h 2020-10-22 11:13:09 +02:00
malloc
mcuboot
memarray
minimal
mpu_noexec_ram
mpu_stack_guard
msg_avail
msg_send_receive
msg_try_receive
mtd_at24cxxx
mtd_at25xxx
mtd_flashpage test/mtd_flashpage: extend test to erase multiple sectors in one go 2020-11-03 12:35:36 +01:00
mtd_mapper
mutex_order
mutex_unlock_and_sleep
nanocoap_cli tests/*: realign ENABLE_DEBUG 2020-10-23 11:27:48 +02:00
netdev_test
netif
netstats_l2
nimble_autoconn_ccnl
nimble_autoconn_gnrc
nimble_l2cap
nimble_l2cap_server
nimble_statconn_gnrc
od
pbkdf2 sys/hashes/pbkdf2: Add PBKDF2-sha256 implementation. 2020-11-04 09:57:32 +01:00
periph_adc tests/periph_*: add Kconfig configuration files 2020-11-06 15:58:00 +01:00
periph_backup_ram tests/periph_*: add Kconfig configuration files 2020-11-06 15:58:00 +01:00
periph_cpuid tests/periph_*: add Kconfig configuration files 2020-11-06 15:58:00 +01:00
periph_dac tests/periph_*: add Kconfig configuration files 2020-11-06 15:58:00 +01:00
periph_dma tests/periph_*: add Kconfig configuration files 2020-11-06 15:58:00 +01:00
periph_eeprom tests/periph_*: add Kconfig configuration files 2020-11-06 15:58:00 +01:00
periph_flashpage tests/periph_*: add Kconfig configuration files 2020-11-06 15:58:00 +01:00
periph_gpio tests/periph_*: add Kconfig configuration files 2020-11-06 15:58:00 +01:00
periph_gpio_arduino tests/periph_*: add Kconfig configuration files 2020-11-06 15:58:00 +01:00
periph_hwrng tests/periph_*: add Kconfig configuration files 2020-11-06 15:58:00 +01:00
periph_i2c tests/periph_*: add Kconfig configuration files 2020-11-06 15:58:00 +01:00
periph_pm tests/periph_*: add Kconfig configuration files 2020-11-06 15:58:00 +01:00
periph_pwm tests/periph_*: add Kconfig configuration files 2020-11-06 15:58:00 +01:00
periph_qdec tests/periph_*: add Kconfig configuration files 2020-11-06 15:58:00 +01:00
periph_rtc tests/periph_*: add Kconfig configuration files 2020-11-06 15:58:00 +01:00
periph_rtt tests/periph_*: add Kconfig configuration files 2020-11-06 15:58:00 +01:00
periph_rtt_min tests/periph_*: add Kconfig configuration files 2020-11-06 15:58:00 +01:00
periph_spi tests/periph_*: add Kconfig configuration files 2020-11-06 15:58:00 +01:00
periph_spi_dma tests/periph_*: add Kconfig configuration files 2020-11-06 15:58:00 +01:00
periph_timer tests/periph_*: add Kconfig configuration files 2020-11-06 15:58:00 +01:00
periph_timer_periodic tests/periph_*: add Kconfig configuration files 2020-11-06 15:58:00 +01:00
periph_timer_short_relative_set tests/periph_*: add Kconfig configuration files 2020-11-06 15:58:00 +01:00
periph_uart tests/periph_*: add Kconfig configuration files 2020-11-06 15:58:00 +01:00
periph_uart_mode tests/periph_*: add Kconfig configuration files 2020-11-06 15:58:00 +01:00
periph_uart_nonblocking tests/periph_*: add Kconfig configuration files 2020-11-06 15:58:00 +01:00
periph_wdt tests/periph_*: add Kconfig configuration files 2020-11-06 15:58:00 +01:00
phydat_dump tests/phydat_dump: use raw strings in expect regexp 2020-11-03 15:50:15 +01:00
pipe
pkg_c25519
pkg_cayenne-lpp
pkg_cifra
pkg_cmsis-dsp
pkg_cmsis-nn
pkg_cn-cbor
pkg_cryptoauthlib_compare_sha256
pkg_cryptoauthlib_internal-tests
pkg_emlearn
pkg_fatfs
pkg_fatfs_vfs tests/pkg_fatfs_vfs: Test for direct stat (as opposed to fstat) 2020-10-25 17:44:32 +01:00
pkg_flatbuffers
pkg_hacl
pkg_heatshrink
pkg_jsmn
pkg_libb2
pkg_libbase58
pkg_libcoap
pkg_libcose
pkg_libfixmath
pkg_libfixmath_unittests
pkg_libhydrogen
pkg_littlefs
pkg_littlefs2
pkg_lora-serialization
pkg_lvgl tests/pkg_lvgl: fix sysmon example URL. 2020-11-08 15:05:56 +01:00
pkg_lvgl_touch
pkg_micro-ecc
pkg_micro-ecc-with-hwrng
pkg_microcoap tests/*: realign ENABLE_DEBUG 2020-10-23 11:27:48 +02:00
pkg_minmea
pkg_monocypher
pkg_nanocbor
pkg_nanopb
pkg_openwsn pkg/openwsn: add ieee802154 hal based radio 2020-10-23 15:31:55 +02:00
pkg_qcbor
pkg_qdsa
pkg_relic tests/*: remove unused assert.h include 2020-10-22 11:29:27 +02:00
pkg_semtech-loramac
pkg_spiffs
pkg_tensorflow-lite
pkg_tiny-asn1
pkg_tinycbor
pkg_tinycrypt tests/pkg_tinycrypt: Drop whitelist 2020-10-19 09:29:37 +02:00
pkg_tinydtls_sock_async tests/*: add explicit include of timex.h 2020-10-21 21:47:31 +02:00
pkg_tweetnacl
pkg_u8g2
pkg_ubasic
pkg_ucglib
pkg_umorse tests/pkg_umorse: convert to xtimer_msleep() 2020-11-05 11:32:42 +01:00
pkg_utensor
pkg_wolfcrypt-ed25519-verify
pkg_wolfssl
pkg_yxml tests/*: realign ENABLE_DEBUG 2020-10-23 11:27:48 +02:00
posix_semaphore
posix_sleep tests/posix_sleep: exclude nucleo-l011k4, too small 2020-10-27 16:49:28 +01:00
prng_sha1prng
prng_sha256prng
progress_bar tests/progress_bar: convert to xtimer_msleep() 2020-11-05 11:32:42 +01:00
ps_schedstatistics
pthread
pthread_barrier
pthread_cleanup
pthread_condition_variable
pthread_cooperation
pthread_flood
pthread_rwlock
pthread_tls
puf_sram
riotboot
riotboot_flashwrite
riotboot_hdr
rmutex
rmutex_cpp
rng
saul
sched_testing
shell tests/shell: fix flake8 errors in Python script 2020-11-03 15:38:27 +01:00
slip
sntp
socket_zep
ssp
stdin
stm32_bootloader
struct_tm_utility
suit_manifest
sys_architecture
sys_arduino
sys_arduino_analog
sys_arduino_lib
sys_crypto
sys_stdio_semihosting
test_tools
thread_basic
thread_cooperation
thread_exit
thread_flags
thread_flags_xtimer
thread_float
thread_flood
thread_msg
thread_msg_block_race
thread_msg_block_w_queue
thread_msg_block_wo_queue
thread_msg_bus Merge pull request #14023 from benpicco/core/msg_bus-bus_flag 2020-11-03 13:51:19 +01:00
thread_msg_seq
thread_priority_inversion tests/thread_priority_inversion: convert to xtimer_msleep() 2020-11-05 11:34:50 +01:00
thread_race
thread_zombie
touch_dev tests/touch_dev: convert to xtimer_msleep() 2020-11-05 11:34:50 +01:00
trace tests/trace: declare expect regexp as raw strings 2020-11-03 14:46:11 +01:00
trickle
unittests tests/unittests/tests-fib_sr: convert to xtimer_msleep() 2020-11-05 11:34:50 +01:00
usbus tests/*: realign ENABLE_DEBUG 2020-10-23 11:27:48 +02:00
usbus_cdc_acm_stdio
usbus_cdc_ecm tests/usbus_cdc_ecm: remove Kconfig file 2020-11-04 09:33:16 +01:00
vfs_plus_stdio
warn_conflict
xtimer_drift
xtimer_hang
xtimer_longterm
xtimer_msg
xtimer_msg_receive_timeout
xtimer_mutex_lock_timeout tests/xtimer_mutex_lock_timeout: clean python automated test 2020-11-03 14:37:57 +01:00
xtimer_now32_overflow
xtimer_now64_continuity
xtimer_now_irq
xtimer_overhead
xtimer_periodic_wakeup
xtimer_remove
xtimer_reset
xtimer_rmutex_lock_timeout
xtimer_usleep
xtimer_usleep_short
ztimer_msg
ztimer_overhead
ztimer_periodic
ztimer_underflow
Makefile.tests_common
README.md

Running and creating tests

There are a number of tests included in RIOT. They are located in the tests folder. These tests allow basic functionality to be verified as well as provide an example of usage.

Implementing automated tests

The goal is to be able to run all tests in a sequential way for as many targets as possible.

As some board can't be reset without a manual trigger tests should be implemented with some kind of synchronization. This can be done in two ways:

  • use test_utils_interactive_sync when uart input/output does not need to be disabled for the test. This is enabled by default.
  • set up the test in a loop so the test script will be able so sync with some kind of start condition in the test.

The module for the first option is test_utils_interactive_sync and is set as a default module in Makefile.tests_common. It can be disabled by setting in the application makefile DISABLE_MODULE += test_utils_interactive_sync. The python test script will adapt to it automatically.

When using the shell module, test_utils_interactive_sync will use the shell itself to synchronize, and will not use test_utils_interactive_sync(); function to synchronize. Some times you will want to synchronize before the start of the script and use test_utils_interactive_sync(); function (e.g.: tests/ps_schedstatistics). For these cases you can disable test_utils_interactive_sync_shell module in the application Makefile: DISABLE_MODULE += test_utils_interactive_sync_shell.

Running automated tests

Some tests can be performed automatically. The test automation scripts are defined in the <test_application>/tests/ folder. They are written in python and interact through the uart with the test application code running on a board to do the validation. It is recommended to flash the board with the test just before running it because some platforms cannot be reset while testing.

From the test application directory run:

BOARD=<board_of_your_choice> make flash test

An automated way of knowing if a test is available is to execute the 'test/available' target from the test application directory. It executes without error if tests run by 'make test' are present.

make test/available

Automated Tests Guidelines

When using pexpect $ is useless for matching the end of a line, instead use \r\n(pexpect end-of-line).

Beware of + and * at the end of patterns. These patterns will always get a minimal match (non-greedy).(pexpect end-of-patterns) This can be an issue when matching groups and using the matched groups to verify some kind of behavior since * could return an empty match and + only a subset.

This is especially prevalent since printf() is buffered so the output might not arrive in a single read to pexpect.

To avoid this make sure to match a non-ambiguous character at the end of the pattern like \r\n, \s, \), etc..

don't:

    child.expect(r'some string: (\d+)')

do:

    child.expect(r'some string: (\d+)\r\n')
    child.expect(r'some string: (\d+)\s')
    child.expect(r'some string: (\d+) ,')

Use expect() instead of assert()

In order to make a test application functional in all cases, use expect() instead of assert(). The former works like the latter, but will still be compiled in if NDEBUG is defined. This is useful to keep a test application working even when compiling with -DNDEBUG, allowing for the code-under-test to be compiled with that flag. Otherwise, the application would force compiling all tested code with assertions enabled. expect() is defined in the header test_utils/expect.h.

Interaction through the uart

Tests implemented with testrunner use the cleanterm target that provides an interaction without adding extra text output or input handling. It can currently be expected to have unmodified line based interaction with the board.

The expected behavior is verified with the test in tests/test_tools.

Tests cannot rely on having on all boards and terminal programs:

  • unbuffered input
  • allowing sending special characters like ctrl+c/ctrl+d