mirror of
https://github.com/italicsjenga/agb.git
synced 2025-01-11 09:31:34 +11:00
Remove the need for a special test implementation
This commit is contained in:
parent
9231d16071
commit
2e505f9684
|
@ -76,6 +76,7 @@ pub fn entry(args: TokenStream, input: TokenStream) -> TokenStream {
|
||||||
);
|
);
|
||||||
|
|
||||||
quote!(
|
quote!(
|
||||||
|
#[cfg(not(test))]
|
||||||
#[export_name = "main"]
|
#[export_name = "main"]
|
||||||
#(#attrs)*
|
#(#attrs)*
|
||||||
pub fn #fn_name() -> ! {
|
pub fn #fn_name() -> ! {
|
||||||
|
@ -83,6 +84,19 @@ pub fn entry(args: TokenStream, input: TokenStream) -> TokenStream {
|
||||||
|
|
||||||
#(#stmts)*
|
#(#stmts)*
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
#[export_name = "main"]
|
||||||
|
#(#attrs)*
|
||||||
|
pub fn #fn_name() -> ! {
|
||||||
|
let mut #argument_name = unsafe { #argument_type ::new_in_entry() };
|
||||||
|
|
||||||
|
if cfg!(test) {
|
||||||
|
agb::test_runner::agb_start_tests(#argument_name, test_main);
|
||||||
|
} else {
|
||||||
|
#(#stmts)*
|
||||||
|
}
|
||||||
|
}
|
||||||
)
|
)
|
||||||
.into()
|
.into()
|
||||||
}
|
}
|
||||||
|
|
|
@ -265,22 +265,12 @@ impl Gba {
|
||||||
/// #![cfg_attr(test, feature(custom_test_frameworks))]
|
/// #![cfg_attr(test, feature(custom_test_frameworks))]
|
||||||
/// #![cfg_attr(test, reexport_test_harness_main = "test_main")]
|
/// #![cfg_attr(test, reexport_test_harness_main = "test_main")]
|
||||||
/// #![cfg_attr(test, test_runner(agb::test_runner::test_runner))]
|
/// #![cfg_attr(test, test_runner(agb::test_runner::test_runner))]
|
||||||
///
|
|
||||||
/// #[cfg(test)]
|
|
||||||
/// #[agb::entry]
|
|
||||||
/// fn main(mut gba: agb::Gba) -> ! {
|
|
||||||
/// agb::test_runner::agb_start_tests(gba, test_main);
|
|
||||||
/// }
|
|
||||||
/// ```
|
/// ```
|
||||||
///
|
///
|
||||||
/// And ensure that your main does not build if testing, so do something similar to:
|
/// And ensure you add agb with the `testing` feature to your `dev-dependencies`
|
||||||
///
|
/// ```toml
|
||||||
/// ```
|
/// [dev-dependencies]
|
||||||
/// #[cfg(not(test))]
|
/// agb = { version = "<same as in dependencies>", features = ["testing"] }
|
||||||
/// #[agb::entry]
|
|
||||||
/// fn main(mut gba: agb::Gba) -> ! {
|
|
||||||
/// // ...
|
|
||||||
/// }
|
|
||||||
/// ```
|
/// ```
|
||||||
///
|
///
|
||||||
/// With this support, you will be able to write tests which you can run using `mgba-test-runner`.
|
/// With this support, you will be able to write tests which you can run using `mgba-test-runner`.
|
||||||
|
@ -365,6 +355,13 @@ pub mod test_runner {
|
||||||
.unwrap();
|
.unwrap();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// needed to fudge the #[entry] below
|
||||||
|
mod agb {
|
||||||
|
pub mod test_runner {
|
||||||
|
pub use super::super::agb_start_tests;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
#[entry]
|
#[entry]
|
||||||
fn agb_test_main(gba: Gba) -> ! {
|
fn agb_test_main(gba: Gba) -> ! {
|
||||||
|
|
|
@ -4,12 +4,6 @@
|
||||||
#![cfg_attr(test, reexport_test_harness_main = "test_main")]
|
#![cfg_attr(test, reexport_test_harness_main = "test_main")]
|
||||||
#![cfg_attr(test, test_runner(agb::test_runner::test_runner))]
|
#![cfg_attr(test, test_runner(agb::test_runner::test_runner))]
|
||||||
|
|
||||||
#[cfg(test)]
|
|
||||||
#[agb::entry]
|
|
||||||
fn main(mut gba: agb::Gba) -> ! {
|
|
||||||
agb::test_runner::agb_start_tests(gba, test_main);
|
|
||||||
}
|
|
||||||
|
|
||||||
extern crate alloc;
|
extern crate alloc;
|
||||||
|
|
||||||
use agb::{
|
use agb::{
|
||||||
|
|
Loading…
Reference in a new issue