From 7724332232c9c30c5b9d24ab5c92090ad3721e50 Mon Sep 17 00:00:00 2001 From: Danny Moesch Date: Fri, 19 Mar 2021 16:12:55 +0100 Subject: [PATCH 1/2] Ignore integration tests in cross-compiled targets As stated [here](https://github.com/rust-embedded/cross#supported-targets) spawning threads in tests will make them fail or they may not terminate at all. --- .github/workflows/test.yml | 12 ++++- tests/cli.rs | 98 ++++++++++++++++++++------------------ 2 files changed, 62 insertions(+), 48 deletions(-) diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index c6df21d..4775e26 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -31,7 +31,7 @@ jobs: - os: macos-latest target: aarch64-apple-darwin - use-cross: false + use-cross: true steps: - name: Checkout repository @@ -47,6 +47,16 @@ jobs: override: true target: ${{ matrix.target }} + - name: Create .cargo/config.toml + if: ${{ matrix.use-cross == true }} + shell: bash + run: | + mkdir .cargo + cat > .cargo/config.toml < Command { - Command::cargo_bin(env!("CARGO_PKG_NAME")).expect("Error invoking sd") -} + fn sd() -> Command { + Command::cargo_bin(env!("CARGO_PKG_NAME")).expect("Error invoking sd") + } -fn assert_file(path: &std::path::Path, content: &str) { - assert_eq!(content, std::fs::read_to_string(path).unwrap()); -} + fn assert_file(path: &std::path::Path, content: &str) { + assert_eq!(content, std::fs::read_to_string(path).unwrap()); + } -#[test] -fn in_place() -> Result<()> { - let mut file = tempfile::NamedTempFile::new()?; - file.write(b"abc123def")?; - let path = file.into_temp_path(); + #[test] + fn in_place() -> Result<()> { + let mut file = tempfile::NamedTempFile::new()?; + file.write(b"abc123def")?; + let path = file.into_temp_path(); - sd().args(&["abc\\d+", "", path.to_str().unwrap()]) - .assert() - .success(); - assert_file(&path.to_path_buf(), "def"); + sd().args(&["abc\\d+", "", path.to_str().unwrap()]) + .assert() + .success(); + assert_file(&path.to_path_buf(), "def"); - Ok(()) -} + Ok(()) + } -#[test] -fn in_place_with_empty_result_file() -> Result<()> { - let mut file = tempfile::NamedTempFile::new()?; - file.write(b"a7c")?; - let path = file.into_temp_path(); + #[test] + fn in_place_with_empty_result_file() -> Result<()> { + let mut file = tempfile::NamedTempFile::new()?; + file.write(b"a7c")?; + let path = file.into_temp_path(); - sd().args(&["a\\dc", "", path.to_str().unwrap()]) - .assert() - .success(); - assert_file(&path.to_path_buf(), ""); + sd().args(&["a\\dc", "", path.to_str().unwrap()]) + .assert() + .success(); + assert_file(&path.to_path_buf(), ""); - Ok(()) -} + Ok(()) + } -#[test] -fn replace_into_stdout() -> Result<()> { - let mut file = tempfile::NamedTempFile::new()?; - file.write(b"abc123def")?; + #[test] + fn replace_into_stdout() -> Result<()> { + let mut file = tempfile::NamedTempFile::new()?; + file.write(b"abc123def")?; - #[rustfmt::skip] + #[rustfmt::skip] sd().args(&["-p", "abc\\d+", "", file.path().to_str().unwrap()]) .assert() .success() .stdout("def"); - assert_file(file.path(), "abc123def"); + assert_file(file.path(), "abc123def"); - Ok(()) -} + Ok(()) + } -#[test] -fn stdin() -> Result<()> { - sd().args(&["abc\\d+", ""]) - .write_stdin("abc123def") - .assert() - .success() - .stdout("def"); + #[test] + fn stdin() -> Result<()> { + sd().args(&["abc\\d+", ""]) + .write_stdin("abc123def") + .assert() + .success() + .stdout("def"); - Ok(()) + Ok(()) + } } From 71cb0d834af634bc842371c3960db56473d37bee Mon Sep 17 00:00:00 2001 From: Danny Moesch Date: Fri, 19 Mar 2021 18:18:50 +0100 Subject: [PATCH 2/2] Remove macOS Aarch64 target This target requires cross-compilation on the default (x86_64) `macos-latest` platform. However, `cross` does [not yet](https://github.com/rust-embedded/cross/issues/508) provide the right target. If tests can be skipped a build solution outside of `cross` is already discussed [here](https://github.com/BurntSushi/ripgrep/issues/1737). --- .github/workflows/test.yml | 4 ---- 1 file changed, 4 deletions(-) diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 4775e26..acd6608 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -29,10 +29,6 @@ jobs: target: x86_64-apple-darwin use-cross: false - - os: macos-latest - target: aarch64-apple-darwin - use-cross: true - steps: - name: Checkout repository uses: actions/checkout@v2