 3c2711102c
			
		
	
	
		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);
 | |
| } |