Skip to content

Commit

Permalink
Merge branch 'master' of github.com:chmln/sd
Browse files Browse the repository at this point in the history
  • Loading branch information
chmln committed May 2, 2021
2 parents 6f58914 + 479f040 commit bc0a450
Show file tree
Hide file tree
Showing 2 changed files with 61 additions and 51 deletions.
14 changes: 10 additions & 4 deletions .github/workflows/test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -29,10 +29,6 @@ jobs:
target: x86_64-apple-darwin
use-cross: false

- os: macos-latest
target: aarch64-apple-darwin
use-cross: false

steps:
- name: Checkout repository
uses: actions/checkout@v2
Expand All @@ -47,6 +43,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 <<EOF
[target.${{ matrix.target }}]
rustflags = ["--cfg", "sd_cross_compile"]
EOF
- name: Test
uses: actions-rs/cargo@v1
with:
Expand Down
98 changes: 51 additions & 47 deletions tests/cli.rs
Original file line number Diff line number Diff line change
@@ -1,66 +1,70 @@
use anyhow::Result;
use assert_cmd::Command;
use std::io::prelude::*;
#[cfg(test)]
#[cfg(not(sd_cross_compile))] // Cross-compilation does not allow to spawn threads but `command.assert()` would do.
mod cli {
use anyhow::Result;
use assert_cmd::Command;
use std::io::prelude::*;

fn sd() -> 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(())
}
}

0 comments on commit bc0a450

Please sign in to comment.