rusefi/unit_tests
Andrey 07a7cd746d only: safety trick 2024-01-07 12:49:32 -05:00
..
chibios-mock
googletest@b10fad38c4 update googletest, because why not 2023-11-17 17:47:00 -06:00
native only: docs 2023-11-17 21:46:10 -05:00
test-framework CSV reader progress 2023-12-06 23:02:08 -05:00
test_basic_math
tests only: front to rear axle speed slip rate gauge #5842 2023-12-30 23:51:59 -05:00
.cproject
.gitignore
.project
Makefile
adc_inputs.h
boards.cpp
boards.h
ci_gcov.sh
clean_compile.bat
clean_compile.sh
efifeatures.h AlternatorController unit-tests 2023-11-10 17:13:50 -05:00
global.h only: safety trick 2024-01-07 12:49:32 -05:00
global_mocks.cpp
gmock-all.cpp
gtest-all.cpp
jenkins.sh
logicdata.cpp
logicdata.h
main.cpp
mocks.cpp
mocks.h
readme.md
rules.mk
run_clean_gcov.sh
run_gcov.bat
run_logicdata_sandbox.bat
run_sharded_tests.sh
svnversion.h
test.mk
triggers.txt Trigger wheel definitions 2023-12-26 01:42:15 +00:00
unit_test_rules.mk

readme.md

See https://github.com/rusefi/rusefi/wiki/Dev-Quality-Control

TL, DR: just follow tests folder as examples.

  1. Run 'make' to build desktop binary.
  2. Execute rusefi_test binary on your PC/Mac, it's expected to say SUCCESS and not fail :) Googletest will also print results summary.
  3. To run only one test uncomment and modify main.cpp line ::testing::GTEST_FLAG(filter)

In this folder we have rusEFI unit tests using https://github.com/google/googletest

Unit tests are not aware of ChibiOS or ARM or else, they are just plain C/C++ which you build for your desktop, not your MCU.

Code Coverage Report

See also https://github.com/rusefi/rusefi/wiki/Build-Server-and-Automation

Triggers Images

Trigger images generation is still a two-step manual process:

Step 1: Invoke unit_tests. One of the unit_tests artifacts is triggers.txt

Step 2: Once we have triggers.txt updated by unit_tests we can invoke firmware/gen_trigger_images.bat in order to generate actual trigger images.