diff options
| author | Lotte Steenbrink <lotte.steenbrink@ferrous-systems.com> | 2021-08-26 10:58:59 +0200 |
|---|---|---|
| committer | Lotte Steenbrink <lotte.steenbrink@ferrous-systems.com> | 2021-09-16 16:31:30 +0200 |
| commit | d172df6f0a9e105fbb501dc2c044ab685a269246 (patch) | |
| tree | ea1c11397becd56e25d69cdd148d73506101e9c5 /xtask/src/build.rs | |
| parent | bf9df9fe73e9c1442a7a31ae93a91e7a8288f6f3 (diff) | |
implement run-pass tests as xtasks
`
Diffstat (limited to 'xtask/src/build.rs')
| -rw-r--r-- | xtask/src/build.rs | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/xtask/src/build.rs b/xtask/src/build.rs new file mode 100644 index 0000000..11666ad --- /dev/null +++ b/xtask/src/build.rs @@ -0,0 +1,37 @@ +use std::path::PathBuf; + +use crate::{command::BuildMode, TestRunError}; + +pub fn build_hexpath( + example: &str, + features: Option<&str>, + build_mode: BuildMode, + build_num: u32, +) -> anyhow::Result<String> { + let features = match features { + Some(f) => f, + None => "", + }; + + let filename = format!("{}_{}_{}_{}.hex", example, features, build_mode, build_num); + ["ci", "builds", &filename] + .iter() + .collect::<PathBuf>() + .into_os_string() + .into_string() + .map_err(|e| anyhow::Error::new(TestRunError::PathConversionError(e))) +} + +pub fn compare_builds(file_1: String, file_2: String) -> anyhow::Result<()> { + let buf_1 = std::fs::read_to_string(file_1.clone())?; + let buf_2 = std::fs::read_to_string(file_2.clone())?; + + if buf_1 != buf_2 { + return Err(anyhow::Error::new(TestRunError::FileCmpError { + file_1, + file_2, + })); + } + + Ok(()) +} |
