3c2711102c
* Lib: move cube to libs. Firmware: prepare for code base refactoring, detach from cube, port to cmsis_os2. * Firmware, target f2: regenerate project with latest cube package, tim17 for os ticks. * Firmware: unified codebase. * Core: do not include semaphore on old targets. Firmware: dfu uplaod target. * CI: submodules, add firmware build. * CI: proper submodule config. * refactor build system * CI: update chain to use new targets. Documentation: update to match current structure. * CI: clean before rebuild. * Add local test docker-compose exec dev make -C firmware TARGET=local TEST=1 run * Makefile: target specific build directory. CI: updated artifacts path. * Makefile: init git submodules if they don't exists. * Makefile: debug rule now doesn't reset MCU, prevent SIGINT propagation to st-util. * Makefile: proper rebuild sequence in zz and zzz * Makefile: timestamp tracking for flash and upload commands. * Apps: modular build. Input: fix flipper hal inline. * Wiki: proper bootloader link. * Applications: fix broken build for local targets. * add st-flash to docker * fix build * force rebuild app * move app force to firmware part * fix build deps * qrcode build ok * fix example display * add testing routine * update build instruction Co-authored-by: Aleksandr Kutuzov <aku@plooks.com> Co-authored-by: aanper <mail@s3f.ru>
73 lines
2.2 KiB
C
73 lines
2.2 KiB
C
#include <stdio.h>
|
|
#include "flipper.h"
|
|
#include "log.h"
|
|
|
|
// #include "flipper-core.h" TODO: Rust build disabled
|
|
|
|
bool test_furi_ac_create_kill(FuriRecordSubscriber* log);
|
|
bool test_furi_ac_switch_exit(FuriRecordSubscriber* log);
|
|
|
|
bool test_furi_pipe_record(FuriRecordSubscriber* log);
|
|
bool test_furi_holding_data(FuriRecordSubscriber* log);
|
|
bool test_furi_concurrent_access(FuriRecordSubscriber* log);
|
|
bool test_furi_nonexistent_data(FuriRecordSubscriber* log);
|
|
bool test_furi_mute_algorithm(FuriRecordSubscriber* log);
|
|
|
|
void flipper_test_app(void* p) {
|
|
FuriRecordSubscriber* log = get_default_log();
|
|
|
|
if(test_furi_ac_create_kill(log)) {
|
|
fuprintf(log, "[TEST] test_furi_ac_create_kill PASSED\n");
|
|
} else {
|
|
fuprintf(log, "[TEST] test_furi_ac_create_kill FAILED\n");
|
|
}
|
|
|
|
if(test_furi_ac_switch_exit(log)) {
|
|
fuprintf(log, "[TEST] test_furi_ac_switch_exit PASSED\n");
|
|
} else {
|
|
fuprintf(log, "[TEST] test_furi_ac_switch_exit FAILED\n");
|
|
}
|
|
|
|
if(test_furi_pipe_record(log)) {
|
|
fuprintf(log, "[TEST] test_furi_pipe_record PASSED\n");
|
|
} else {
|
|
fuprintf(log, "[TEST] test_furi_pipe_record FAILED\n");
|
|
}
|
|
|
|
if(test_furi_holding_data(log)) {
|
|
fuprintf(log, "[TEST] test_furi_holding_data PASSED\n");
|
|
} else {
|
|
fuprintf(log, "[TEST] test_furi_holding_data FAILED\n");
|
|
}
|
|
|
|
if(test_furi_concurrent_access(log)) {
|
|
fuprintf(log, "[TEST] test_furi_concurrent_access PASSED\n");
|
|
} else {
|
|
fuprintf(log, "[TEST] test_furi_concurrent_access FAILED\n");
|
|
}
|
|
|
|
if(test_furi_nonexistent_data(log)) {
|
|
fuprintf(log, "[TEST] test_furi_nonexistent_data PASSED\n");
|
|
} else {
|
|
fuprintf(log, "[TEST] test_furi_nonexistent_data FAILED\n");
|
|
}
|
|
|
|
if(test_furi_mute_algorithm(log)) {
|
|
fuprintf(log, "[TEST] test_furi_mute_algorithm PASSED\n");
|
|
} else {
|
|
fuprintf(log, "[TEST] test_furi_mute_algorithm FAILED\n");
|
|
}
|
|
|
|
/*
|
|
TODO: Rust build disabled
|
|
if(add(1, 2) == 3) {
|
|
fuprintf(log, "[TEST] Rust add PASSED\n");
|
|
} else {
|
|
fuprintf(log, "[TEST] Rust add FAILED\n");
|
|
}
|
|
|
|
rust_uart_write();
|
|
*/
|
|
|
|
furiac_exit(NULL);
|
|
} |