2021-09-20 17:35:15 +02:00
|
|
|
use std::{
|
|
|
|
fs,
|
|
|
|
path::{Path, PathBuf},
|
|
|
|
};
|
2021-08-26 10:58:59 +02:00
|
|
|
|
|
|
|
use crate::{command::BuildMode, TestRunError};
|
|
|
|
|
2021-09-20 17:35:15 +02:00
|
|
|
const HEX_BUILD_ROOT: &str = "ci/builds";
|
|
|
|
|
|
|
|
/// make sure we're starting with a clean,but existing slate
|
|
|
|
pub fn init_build_dir() -> anyhow::Result<()> {
|
|
|
|
if Path::new(HEX_BUILD_ROOT).exists() {
|
|
|
|
fs::remove_dir_all(HEX_BUILD_ROOT)
|
|
|
|
.map_err(|_| anyhow::anyhow!("Could not clear out directory: {}", HEX_BUILD_ROOT))?;
|
|
|
|
}
|
|
|
|
fs::create_dir_all(HEX_BUILD_ROOT)
|
|
|
|
.map_err(|_| anyhow::anyhow!("Could not create directory: {}", HEX_BUILD_ROOT))
|
|
|
|
}
|
|
|
|
|
2021-08-26 10:58:59 +02:00
|
|
|
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);
|
2021-09-20 17:35:15 +02:00
|
|
|
|
|
|
|
let mut path = PathBuf::from(HEX_BUILD_ROOT);
|
|
|
|
path.push(filename);
|
|
|
|
|
|
|
|
path.into_os_string()
|
2021-08-26 10:58:59 +02:00
|
|
|
.into_string()
|
|
|
|
.map_err(|e| anyhow::Error::new(TestRunError::PathConversionError(e)))
|
|
|
|
}
|
|
|
|
|
2021-09-22 13:22:45 +02:00
|
|
|
pub fn compare_builds(expected: String, got: String) -> anyhow::Result<()> {
|
|
|
|
let buf_1 = std::fs::read_to_string(expected.clone())?;
|
|
|
|
let buf_2 = std::fs::read_to_string(got.clone())?;
|
2021-08-26 10:58:59 +02:00
|
|
|
|
|
|
|
if buf_1 != buf_2 {
|
|
|
|
return Err(anyhow::Error::new(TestRunError::FileCmpError {
|
2021-09-22 13:22:45 +02:00
|
|
|
expected,
|
|
|
|
got,
|
2021-08-26 10:58:59 +02:00
|
|
|
}));
|
|
|
|
}
|
|
|
|
|
|
|
|
Ok(())
|
|
|
|
}
|