1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-17 19:12:45 +01:00
RIOT/makefiles/tests/feature_resolution
Marian Buschsieweke d29652350b
build system: Improve failure mode for FEAUTRES_REQUIRED_ANY
Failing to provide any of the required features can provide a message
such as:

    There are unsatisfied feature requirements: periph_uart|periph_lpuart

This can be confusing and may hide the actual. E.g. above message
was generated when using SPI on the `msb-430` and `stdio_uart`. However,
the MSB-430 board *does* provide `periph_uart`, so this looks like a bug
in the feature resolution. This changes the failure mode of
`FEATURES_REQUIRED_ANY` to just pick the first of the alternatives
given if none of the alternative is usable, which gives in the example
the following message instead:

    The following features may conflict: periph_spi periph_uart
    Rationale: Both SPI and UART are provided by the same USART
               peripheral

The output is less surprising and can provide non-obvious reasons
why `FEATURES_REQUIRED_ANY` failed to pick a feature. The downside is
that the alternatives are no longer visible. However, that output
likely was so confusing this might be for the best.

Co-authored-by: mguetschow <mikolai.guetschow@tu-dresden.de>
2024-02-22 14:02:53 +01:00
..
Makefile tests/feature_resolution: add build system unit tests 2021-02-10 21:05:38 +01:00
Makefile.test tests/feature_resolution: add build system unit tests 2021-02-10 21:05:38 +01:00
README.md tests/feature_resolution: add build system unit tests 2021-02-10 21:05:38 +01:00
test-blacklist-failure.mk tests/feature_resolution: add build system unit tests 2021-02-10 21:05:38 +01:00
test-blacklist-optional.mk tests/feature_resolution: add build system unit tests 2021-02-10 21:05:38 +01:00
test-blacklist-success.mk tests/feature_resolution: add build system unit tests 2021-02-10 21:05:38 +01:00
test-complex-failure.mk build system: Improve failure mode for FEAUTRES_REQUIRED_ANY 2024-02-22 14:02:53 +01:00
test-complex-success.mk tests/feature_resolution: add build system unit tests 2021-02-10 21:05:38 +01:00
test-conflict-failure.mk tests/feature_resolution: add build system unit tests 2021-02-10 21:05:38 +01:00
test-conflict-optional.mk makefiles/tests: add unit tests for fixed bug 2021-02-22 12:06:27 +01:00
test-conflict-success.mk tests/feature_resolution: add build system unit tests 2021-02-10 21:05:38 +01:00
test-empty.mk tests/feature_resolution: add build system unit tests 2021-02-10 21:05:38 +01:00
test-required-any-corner-case.mk tests/feature_resolution: add build system unit tests 2021-02-10 21:05:38 +01:00
test-required-any-fail.mk build system: Improve failure mode for FEAUTRES_REQUIRED_ANY 2024-02-22 14:02:53 +01:00
test-required-any-order.mk tests/feature_resolution: add build system unit tests 2021-02-10 21:05:38 +01:00
test-required-any-reuse-optional.mk tests/feature_resolution: add build system unit tests 2021-02-10 21:05:38 +01:00
test-required-any-reuse-required.mk tests/feature_resolution: add build system unit tests 2021-02-10 21:05:38 +01:00
test-trivial-failure.mk tests/feature_resolution: add build system unit tests 2021-02-10 21:05:38 +01:00
test-trivial-success.mk tests/feature_resolution: add build system unit tests 2021-02-10 21:05:38 +01:00

Simple Unit Tests for Feature Resolution

This folder contains a Makefile that runs a set of unit tests for the feature resolution logic. Each unit test is defined in a file named tests-<NAME_OF_TEST>.mk in which the inputs and the expected outputs are defined. Finally, the include Makefile.test, which will perform the tests.

The tests can be run simply by typing make. Also, make static-test at the root of the repo will run these tests and, hence, these tests are also executed on each CI run.

Adding new Test Cases

Just create a new tests-<NAME_OF_NEW_TEST>.mk file and start with the contests of an existing test case and change the inputs and expected outputs accordingly.