Skip to content

Commit

Permalink
Set up a test harness for the flipperzero crate
Browse files Browse the repository at this point in the history
The tests can be run with `cargo test` from within the `crates/`
directory.
  • Loading branch information
str4d committed Mar 17, 2023
1 parent e632a58 commit 28c780a
Show file tree
Hide file tree
Showing 4 changed files with 67 additions and 1 deletion.
1 change: 1 addition & 0 deletions crates/.cargo/config.toml
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
[target.thumbv7em-none-eabihf]
runner = "../tools/cargo-runner.sh"
rustflags = [
# CPU is Cortex-M4 (STM32WB55)
"-C", "target-cpu=cortex-m4",
Expand Down
2 changes: 1 addition & 1 deletion crates/flipperzero/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ all-features = true

[lib]
bench = false
test = false
harness = false

[dependencies]
flipperzero-sys.workspace = true
Expand Down
54 changes: 54 additions & 0 deletions crates/flipperzero/src/lib.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
//! High-level bindings for the Flipper Zero.
#![no_std]
#![cfg_attr(test, no_main)]

#[cfg(feature = "alloc")]
extern crate alloc;
Expand All @@ -16,3 +17,56 @@ pub mod __internal {
// Re-export for use in macros
pub use ufmt;
}

// Infrastructure for running unit tests.
#[cfg(test)]
mod tests {
// Required for panic handler
extern crate flipperzero_rt;

// Required for allocator
#[cfg(feature = "alloc")]
extern crate flipperzero_alloc;

use core::time::Duration;

use flipperzero_rt::{entry, manifest};
use flipperzero_sys as sys;

use crate::{furi::thread, println};

manifest!(name = "Rust Unit Tests");
entry!(main);

// Test runner entry point
fn main(_args: *mut u8) -> i32 {
let heap_before = unsafe { sys::memmgr_get_free_heap() };
let cycle_counter = unsafe { sys::furi_get_tick() };

// TODO: Collect and run tests
let failed = 0;

println!("");
println!("Failed tests: {}\r", failed);

// Time report
println!(
"Consumed: {} ms\r",
unsafe { sys::furi_get_tick() } - cycle_counter
);

// Wait for tested services and apps to deallocate memory
thread::sleep(Duration::from_millis(200));
let heap_after = unsafe { sys::memmgr_get_free_heap() };
println!("Leaked: {}\r", heap_before - heap_after);

// Final Report
if failed == 0 {
println!("Status: PASSED\r");
0
} else {
println!("Status: FAILED\r");
1
}
}
}
11 changes: 11 additions & 0 deletions tools/cargo-runner.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
#!/usr/bin/env bash

# Figure out where this script is located (which is also where the tools are).
SCRIPT_DIR=$( cd -- "$( dirname -- "${BASH_SOURCE[0]}" )" &> /dev/null && pwd )

# Change directory to the tools directory, to ensure the CWD doesn't contain any
# .cargo/config files that would prevent us from building on the host machine.
cd $SCRIPT_DIR

# Run the given FAP binary on a connected Flipper Zero.
cargo run --quiet --release --bin run-fap -- $@

0 comments on commit 28c780a

Please sign in to comment.