2019-01-19 17:15:56 +02:00
|
|
|
use crate::hay::SHERLOCK;
|
2020-02-18 01:08:47 +02:00
|
|
|
use crate::util::{cmd_exists, sort_lines, Dir, TestCommand};
|
2018-08-07 02:11:58 +02:00
|
|
|
|
|
|
|
// This file contains "miscellaneous" tests that were either written before
|
|
|
|
// features were tracked more explicitly, or were simply written without
|
|
|
|
// linking them to a specific issue number. We should try to minimize the
|
|
|
|
// addition of more tests in this file and instead add them to either the
|
|
|
|
// regression test suite or the feature test suite (found in regression.rs and
|
|
|
|
// feature.rs, respectively).
|
|
|
|
|
|
|
|
rgtest!(single_file, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.arg("Sherlock").arg("sherlock").stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(dir, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
sherlock:For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
sherlock:be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.arg("Sherlock").stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(line_numbers, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
1:For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
3:be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.arg("-n").arg("Sherlock").arg("sherlock").stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(columns, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
cmd.arg("--column").arg("Sherlock").arg("sherlock");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
1:57:For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
3:49:be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(with_filename, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
cmd.arg("-H").arg("Sherlock").arg("sherlock");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
sherlock:For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
sherlock:be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(with_heading, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
cmd.args(&[
|
|
|
|
// This forces the issue since --with-filename is disabled by default
|
|
|
|
// when searching one file.
|
2020-02-18 01:08:47 +02:00
|
|
|
"--with-filename",
|
|
|
|
"--heading",
|
|
|
|
"Sherlock",
|
|
|
|
"sherlock",
|
2018-08-07 02:11:58 +02:00
|
|
|
]);
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
sherlock
|
|
|
|
For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(with_heading_default, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
// Search two or more and get --with-filename enabled by default.
|
|
|
|
// Use -j1 to get deterministic results.
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
dir.create("foo", "Sherlock Holmes lives on Baker Street.");
|
|
|
|
cmd.arg("-j1").arg("--heading").arg("Sherlock");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
foo
|
|
|
|
Sherlock Holmes lives on Baker Street.
|
|
|
|
|
|
|
|
sherlock
|
|
|
|
For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
";
|
|
|
|
eqnice!(sort_lines(expected), sort_lines(&cmd.stdout()));
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(inverted, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
cmd.arg("-v").arg("Sherlock").arg("sherlock");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
Holmeses, success in the province of detective work must always
|
|
|
|
can extract a clew from a wisp of straw or a flake of cigar ash;
|
|
|
|
but Doctor Watson has to have it taken out for him and dusted,
|
|
|
|
and exhibited clearly, with a label attached.
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(inverted_line_numbers, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
cmd.arg("-n").arg("-v").arg("Sherlock").arg("sherlock");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
2:Holmeses, success in the province of detective work must always
|
|
|
|
4:can extract a clew from a wisp of straw or a flake of cigar ash;
|
|
|
|
5:but Doctor Watson has to have it taken out for him and dusted,
|
|
|
|
6:and exhibited clearly, with a label attached.
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(case_insensitive, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
cmd.arg("-i").arg("sherlock").arg("sherlock");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(word, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
cmd.arg("-w").arg("as").arg("sherlock");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(line, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
cmd.args(&[
|
|
|
|
"-x",
|
|
|
|
"Watson|and exhibited clearly, with a label attached.",
|
|
|
|
"sherlock",
|
|
|
|
]);
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
and exhibited clearly, with a label attached.
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(literal, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
dir.create("file", "blib\n()\nblab\n");
|
|
|
|
cmd.arg("-F").arg("()").arg("file");
|
|
|
|
|
|
|
|
eqnice!("()\n", cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(quiet, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
cmd.arg("-q").arg("Sherlock").arg("sherlock");
|
|
|
|
|
|
|
|
assert!(cmd.stdout().is_empty());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(replace, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
cmd.arg("-r").arg("FooBar").arg("Sherlock").arg("sherlock");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
For the Doctor Watsons of this world, as opposed to the FooBar
|
|
|
|
be, to a very large extent, the result of luck. FooBar Holmes
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(replace_groups, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
2020-02-18 01:08:47 +02:00
|
|
|
cmd.args(&["-r", "$2, $1", "([A-Z][a-z]+) ([A-Z][a-z]+)", "sherlock"]);
|
2018-08-07 02:11:58 +02:00
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
For the Watsons, Doctor of this world, as opposed to the Sherlock
|
|
|
|
be, to a very large extent, the result of luck. Holmes, Sherlock
|
|
|
|
but Watson, Doctor has to have it taken out for him and dusted,
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(replace_named_groups, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
cmd.args(&[
|
2020-02-18 01:08:47 +02:00
|
|
|
"-r",
|
|
|
|
"$last, $first",
|
2018-08-07 02:11:58 +02:00
|
|
|
"(?P<first>[A-Z][a-z]+) (?P<last>[A-Z][a-z]+)",
|
|
|
|
"sherlock",
|
|
|
|
]);
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
For the Watsons, Doctor of this world, as opposed to the Sherlock
|
|
|
|
be, to a very large extent, the result of luck. Holmes, Sherlock
|
|
|
|
but Watson, Doctor has to have it taken out for him and dusted,
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(replace_with_only_matching, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
cmd.arg("-o").arg("-r").arg("$1").arg(r"of (\w+)").arg("sherlock");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
this
|
|
|
|
detective
|
|
|
|
luck
|
|
|
|
straw
|
|
|
|
cigar
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(file_types, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
dir.create("file.py", "Sherlock");
|
|
|
|
dir.create("file.rs", "Sherlock");
|
|
|
|
cmd.arg("-t").arg("rust").arg("Sherlock");
|
|
|
|
|
|
|
|
eqnice!("file.rs:Sherlock\n", cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(file_types_all, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
dir.create("file.py", "Sherlock");
|
|
|
|
cmd.arg("-t").arg("all").arg("Sherlock");
|
|
|
|
|
|
|
|
eqnice!("file.py:Sherlock\n", cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(file_types_negate, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
dir.remove("sherlock");
|
|
|
|
dir.create("file.py", "Sherlock");
|
|
|
|
dir.create("file.rs", "Sherlock");
|
|
|
|
cmd.arg("-T").arg("rust").arg("Sherlock");
|
|
|
|
|
|
|
|
eqnice!("file.py:Sherlock\n", cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(file_types_negate_all, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
dir.create("file.py", "Sherlock");
|
|
|
|
cmd.arg("-T").arg("all").arg("Sherlock");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
sherlock:For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
sherlock:be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(file_type_clear, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
dir.create("file.py", "Sherlock");
|
|
|
|
dir.create("file.rs", "Sherlock");
|
|
|
|
cmd.arg("--type-clear").arg("rust").arg("-t").arg("rust").arg("Sherlock");
|
|
|
|
|
|
|
|
cmd.assert_non_empty_stderr();
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(file_type_add, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
dir.create("file.py", "Sherlock");
|
|
|
|
dir.create("file.rs", "Sherlock");
|
|
|
|
dir.create("file.wat", "Sherlock");
|
2020-02-18 01:08:47 +02:00
|
|
|
cmd.args(&["--type-add", "wat:*.wat", "-t", "wat", "Sherlock"]);
|
2018-08-07 02:11:58 +02:00
|
|
|
|
|
|
|
eqnice!("file.wat:Sherlock\n", cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(file_type_add_compose, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
dir.create("file.py", "Sherlock");
|
|
|
|
dir.create("file.rs", "Sherlock");
|
|
|
|
dir.create("file.wat", "Sherlock");
|
|
|
|
cmd.args(&[
|
2020-02-18 01:08:47 +02:00
|
|
|
"--type-add",
|
|
|
|
"wat:*.wat",
|
|
|
|
"--type-add",
|
|
|
|
"combo:include:wat,py",
|
|
|
|
"-t",
|
|
|
|
"combo",
|
2018-08-07 02:11:58 +02:00
|
|
|
"Sherlock",
|
|
|
|
]);
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
file.py:Sherlock
|
|
|
|
file.wat:Sherlock
|
|
|
|
";
|
|
|
|
eqnice!(expected, sort_lines(&cmd.stdout()));
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(glob, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
dir.create("file.py", "Sherlock");
|
|
|
|
dir.create("file.rs", "Sherlock");
|
|
|
|
cmd.arg("-g").arg("*.rs").arg("Sherlock");
|
|
|
|
|
|
|
|
eqnice!("file.rs:Sherlock\n", cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(glob_negate, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
dir.remove("sherlock");
|
|
|
|
dir.create("file.py", "Sherlock");
|
|
|
|
dir.create("file.rs", "Sherlock");
|
|
|
|
cmd.arg("-g").arg("!*.rs").arg("Sherlock");
|
|
|
|
|
|
|
|
eqnice!("file.py:Sherlock\n", cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(glob_case_insensitive, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
dir.create("file.HTML", "Sherlock");
|
|
|
|
cmd.arg("--iglob").arg("*.html").arg("Sherlock");
|
|
|
|
|
|
|
|
eqnice!("file.HTML:Sherlock\n", cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(glob_case_sensitive, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
dir.create("file1.HTML", "Sherlock");
|
|
|
|
dir.create("file2.html", "Sherlock");
|
|
|
|
cmd.arg("--glob").arg("*.html").arg("Sherlock");
|
|
|
|
|
|
|
|
eqnice!("file2.html:Sherlock\n", cmd.stdout());
|
|
|
|
});
|
|
|
|
|
2019-08-01 23:08:58 +02:00
|
|
|
rgtest!(glob_always_case_insensitive, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
dir.create("file.HTML", "Sherlock");
|
|
|
|
cmd.args(&["--glob-case-insensitive", "--glob", "*.html", "Sherlock"]);
|
|
|
|
|
|
|
|
eqnice!("file.HTML:Sherlock\n", cmd.stdout());
|
|
|
|
});
|
|
|
|
|
2018-08-07 02:11:58 +02:00
|
|
|
rgtest!(byte_offset_only_matching, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
cmd.arg("-b").arg("-o").arg("Sherlock");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
sherlock:56:Sherlock
|
|
|
|
sherlock:177:Sherlock
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(count, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
cmd.arg("--count").arg("Sherlock");
|
|
|
|
|
|
|
|
let expected = "sherlock:2\n";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(count_matches, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
cmd.arg("--count-matches").arg("the");
|
|
|
|
|
|
|
|
let expected = "sherlock:4\n";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(count_matches_inverted, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
cmd.arg("--count-matches").arg("--invert-match").arg("Sherlock");
|
|
|
|
|
|
|
|
let expected = "sherlock:4\n";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(count_matches_via_only, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
cmd.arg("--count").arg("--only-matching").arg("the");
|
|
|
|
|
|
|
|
let expected = "sherlock:4\n";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
2019-10-17 04:03:00 +02:00
|
|
|
rgtest!(include_zero, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
2020-02-18 01:08:47 +02:00
|
|
|
cmd.args(&["--count", "--include-zero", "nada"]);
|
2019-10-17 04:03:00 +02:00
|
|
|
cmd.assert_err();
|
|
|
|
|
|
|
|
let output = cmd.cmd().output().unwrap();
|
|
|
|
let stdout = String::from_utf8_lossy(&output.stdout);
|
|
|
|
let expected = "sherlock:0\n";
|
|
|
|
|
|
|
|
eqnice!(expected, stdout);
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(include_zero_override, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
2020-02-18 01:08:47 +02:00
|
|
|
cmd.args(&["--count", "--include-zero", "--no-include-zero", "nada"]);
|
2019-10-17 04:03:00 +02:00
|
|
|
cmd.assert_err();
|
|
|
|
|
|
|
|
let output = cmd.cmd().output().unwrap();
|
|
|
|
let stdout = String::from_utf8_lossy(&output.stdout);
|
|
|
|
assert!(stdout.is_empty());
|
|
|
|
});
|
|
|
|
|
2018-08-07 02:11:58 +02:00
|
|
|
rgtest!(files_with_matches, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
cmd.arg("--files-with-matches").arg("Sherlock");
|
|
|
|
|
|
|
|
let expected = "sherlock\n";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(files_without_match, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
dir.create("file.py", "foo");
|
|
|
|
cmd.arg("--files-without-match").arg("Sherlock");
|
|
|
|
|
|
|
|
let expected = "file.py\n";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(after_context, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
cmd.arg("-A").arg("1").arg("Sherlock").arg("sherlock");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
Holmeses, success in the province of detective work must always
|
|
|
|
be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
can extract a clew from a wisp of straw or a flake of cigar ash;
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(after_context_line_numbers, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
cmd.arg("-A").arg("1").arg("-n").arg("Sherlock").arg("sherlock");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
1:For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
2-Holmeses, success in the province of detective work must always
|
|
|
|
3:be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
4-can extract a clew from a wisp of straw or a flake of cigar ash;
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(before_context, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
cmd.arg("-B").arg("1").arg("Sherlock").arg("sherlock");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
Holmeses, success in the province of detective work must always
|
|
|
|
be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(before_context_line_numbers, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
cmd.arg("-B").arg("1").arg("-n").arg("Sherlock").arg("sherlock");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
1:For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
2-Holmeses, success in the province of detective work must always
|
|
|
|
3:be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(context, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
cmd.arg("-C").arg("1").arg("world|attached").arg("sherlock");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
Holmeses, success in the province of detective work must always
|
|
|
|
--
|
|
|
|
but Doctor Watson has to have it taken out for him and dusted,
|
|
|
|
and exhibited clearly, with a label attached.
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(context_line_numbers, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
cmd.arg("-C").arg("1").arg("-n").arg("world|attached").arg("sherlock");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
1:For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
2-Holmeses, success in the province of detective work must always
|
|
|
|
--
|
|
|
|
5-but Doctor Watson has to have it taken out for him and dusted,
|
|
|
|
6:and exhibited clearly, with a label attached.
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
2020-03-22 13:43:16 +02:00
|
|
|
rgtest!(max_filesize_parse_error_length, |_: Dir, mut cmd: TestCommand| {
|
2018-08-07 02:11:58 +02:00
|
|
|
cmd.arg("--max-filesize").arg("44444444444444444444");
|
|
|
|
cmd.assert_non_empty_stderr();
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(max_filesize_parse_error_suffix, |_: Dir, mut cmd: TestCommand| {
|
|
|
|
cmd.arg("--max-filesize").arg("45k");
|
|
|
|
cmd.assert_non_empty_stderr();
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(max_filesize_parse_no_suffix, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create_size("foo", 40);
|
|
|
|
dir.create_size("bar", 60);
|
|
|
|
cmd.arg("--max-filesize").arg("50").arg("--files");
|
|
|
|
|
|
|
|
eqnice!("foo\n", cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(max_filesize_parse_k_suffix, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create_size("foo", 3048);
|
|
|
|
dir.create_size("bar", 4100);
|
|
|
|
cmd.arg("--max-filesize").arg("4K").arg("--files");
|
|
|
|
|
|
|
|
eqnice!("foo\n", cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(max_filesize_parse_m_suffix, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create_size("foo", 1000000);
|
|
|
|
dir.create_size("bar", 1400000);
|
|
|
|
cmd.arg("--max-filesize").arg("1M").arg("--files");
|
|
|
|
|
|
|
|
eqnice!("foo\n", cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(max_filesize_suffix_overflow, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create_size("foo", 1000000);
|
|
|
|
|
|
|
|
// 2^35 * 2^30 would otherwise overflow
|
|
|
|
cmd.arg("--max-filesize").arg("34359738368G").arg("--files");
|
|
|
|
cmd.assert_non_empty_stderr();
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(ignore_hidden, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create(".sherlock", SHERLOCK);
|
|
|
|
cmd.arg("Sherlock").assert_err();
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(no_ignore_hidden, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create(".sherlock", SHERLOCK);
|
|
|
|
cmd.arg("--hidden").arg("Sherlock");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
.sherlock:For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
.sherlock:be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(ignore_git, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
dir.create_dir(".git");
|
|
|
|
dir.create(".gitignore", "sherlock\n");
|
|
|
|
cmd.arg("Sherlock");
|
|
|
|
|
|
|
|
cmd.assert_err();
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(ignore_generic, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
dir.create(".ignore", "sherlock\n");
|
|
|
|
cmd.arg("Sherlock");
|
|
|
|
|
|
|
|
cmd.assert_err();
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(ignore_ripgrep, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
dir.create(".rgignore", "sherlock\n");
|
|
|
|
cmd.arg("Sherlock");
|
|
|
|
|
|
|
|
cmd.assert_err();
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(no_ignore, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
dir.create(".gitignore", "sherlock\n");
|
|
|
|
cmd.arg("--no-ignore").arg("Sherlock");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
sherlock:For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
sherlock:be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(ignore_git_parent, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create_dir(".git");
|
|
|
|
dir.create(".gitignore", "sherlock\n");
|
|
|
|
dir.create_dir("foo");
|
|
|
|
dir.create("foo/sherlock", SHERLOCK);
|
|
|
|
cmd.arg("Sherlock");
|
|
|
|
|
|
|
|
// Even though we search in foo/, which has no .gitignore, ripgrep will
|
|
|
|
// traverse parent directories and respect the gitignore files found.
|
|
|
|
cmd.current_dir(dir.path().join("foo"));
|
|
|
|
cmd.assert_err();
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(ignore_git_parent_stop, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
// This tests that searching parent directories for .gitignore files stops
|
|
|
|
// after it sees a .git directory. To test this, we create this directory
|
|
|
|
// hierarchy:
|
|
|
|
//
|
|
|
|
// .gitignore (contains `sherlock`)
|
|
|
|
// foo/
|
|
|
|
// .git/
|
|
|
|
// bar/
|
|
|
|
// sherlock
|
|
|
|
//
|
|
|
|
// And we perform the search inside `foo/bar/`. ripgrep will stop looking
|
|
|
|
// for .gitignore files after it sees `foo/.git/`, and therefore not
|
|
|
|
// respect the top-level `.gitignore` containing `sherlock`.
|
|
|
|
dir.create(".gitignore", "sherlock\n");
|
|
|
|
dir.create_dir("foo");
|
|
|
|
dir.create_dir("foo/.git");
|
|
|
|
dir.create_dir("foo/bar");
|
|
|
|
dir.create("foo/bar/sherlock", SHERLOCK);
|
|
|
|
cmd.arg("Sherlock");
|
|
|
|
cmd.current_dir(dir.path().join("foo").join("bar"));
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
sherlock:For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
sherlock:be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
// Like ignore_git_parent_stop, but with a .git file instead of a .git
|
|
|
|
// directory.
|
|
|
|
rgtest!(ignore_git_parent_stop_file, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
// This tests that searching parent directories for .gitignore files stops
|
|
|
|
// after it sees a .git *file*. A .git file is used for submodules. To test
|
|
|
|
// this, we create this directory hierarchy:
|
|
|
|
//
|
|
|
|
// .gitignore (contains `sherlock`)
|
|
|
|
// foo/
|
|
|
|
// .git
|
|
|
|
// bar/
|
|
|
|
// sherlock
|
|
|
|
//
|
|
|
|
// And we perform the search inside `foo/bar/`. ripgrep will stop looking
|
|
|
|
// for .gitignore files after it sees `foo/.git`, and therefore not
|
|
|
|
// respect the top-level `.gitignore` containing `sherlock`.
|
|
|
|
dir.create(".gitignore", "sherlock\n");
|
|
|
|
dir.create_dir("foo");
|
|
|
|
dir.create("foo/.git", "");
|
|
|
|
dir.create_dir("foo/bar");
|
|
|
|
dir.create("foo/bar/sherlock", SHERLOCK);
|
|
|
|
cmd.arg("Sherlock");
|
|
|
|
cmd.current_dir(dir.path().join("foo").join("bar"));
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
sherlock:For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
sherlock:be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(ignore_ripgrep_parent_no_stop, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
// This is like the `ignore_git_parent_stop` test, except it checks that
|
|
|
|
// ripgrep *doesn't* stop checking for .rgignore files.
|
|
|
|
dir.create(".rgignore", "sherlock\n");
|
|
|
|
dir.create_dir("foo");
|
|
|
|
dir.create_dir("foo/.git");
|
|
|
|
dir.create_dir("foo/bar");
|
|
|
|
dir.create("foo/bar/sherlock", SHERLOCK);
|
|
|
|
cmd.arg("Sherlock");
|
|
|
|
cmd.current_dir(dir.path().join("foo").join("bar"));
|
|
|
|
|
|
|
|
// The top-level .rgignore applies.
|
|
|
|
cmd.assert_err();
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(no_parent_ignore_git, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
// Set up a directory hierarchy like this:
|
|
|
|
//
|
|
|
|
// .git/
|
|
|
|
// .gitignore
|
|
|
|
// foo/
|
|
|
|
// .gitignore
|
|
|
|
// sherlock
|
|
|
|
// watson
|
|
|
|
//
|
|
|
|
// Where `.gitignore` contains `sherlock` and `foo/.gitignore` contains
|
|
|
|
// `watson`.
|
|
|
|
//
|
|
|
|
// Now *do the search* from the foo directory. By default, ripgrep will
|
|
|
|
// search parent directories for .gitignore files. The --no-ignore-parent
|
|
|
|
// flag should prevent that. At the same time, the `foo/.gitignore` file
|
|
|
|
// will still be respected (since the search is happening in `foo/`).
|
|
|
|
//
|
|
|
|
// In other words, we should only see results from `sherlock`, not from
|
|
|
|
// `watson`.
|
|
|
|
dir.create_dir(".git");
|
|
|
|
dir.create(".gitignore", "sherlock\n");
|
|
|
|
dir.create_dir("foo");
|
|
|
|
dir.create("foo/.gitignore", "watson\n");
|
|
|
|
dir.create("foo/sherlock", SHERLOCK);
|
|
|
|
dir.create("foo/watson", SHERLOCK);
|
|
|
|
cmd.arg("--no-ignore-parent").arg("Sherlock");
|
|
|
|
cmd.current_dir(dir.path().join("foo"));
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
sherlock:For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
sherlock:be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(symlink_nofollow, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create_dir("foo");
|
|
|
|
dir.create_dir("foo/bar");
|
|
|
|
dir.link_dir("foo/baz", "foo/bar/baz");
|
|
|
|
dir.create_dir("foo/baz");
|
|
|
|
dir.create("foo/baz/sherlock", SHERLOCK);
|
|
|
|
cmd.arg("Sherlock");
|
|
|
|
cmd.current_dir(dir.path().join("foo/bar"));
|
|
|
|
|
|
|
|
cmd.assert_err();
|
|
|
|
});
|
|
|
|
|
|
|
|
#[cfg(not(windows))]
|
|
|
|
rgtest!(symlink_follow, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create_dir("foo");
|
|
|
|
dir.create_dir("foo/bar");
|
|
|
|
dir.create_dir("foo/baz");
|
|
|
|
dir.create("foo/baz/sherlock", SHERLOCK);
|
|
|
|
dir.link_dir("foo/baz", "foo/bar/baz");
|
|
|
|
cmd.arg("-L").arg("Sherlock");
|
|
|
|
cmd.current_dir(dir.path().join("foo/bar"));
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
baz/sherlock:For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
baz/sherlock:be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(unrestricted1, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
dir.create(".gitignore", "sherlock\n");
|
|
|
|
cmd.arg("-u").arg("Sherlock");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
sherlock:For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
sherlock:be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(unrestricted2, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create(".sherlock", SHERLOCK);
|
|
|
|
cmd.arg("-uu").arg("Sherlock");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
.sherlock:For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
.sherlock:be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(unrestricted3, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
binary: rejigger ripgrep's handling of binary files
This commit attempts to surface binary filtering in a slightly more
user friendly way. Namely, before, ripgrep would silently stop
searching a file if it detected a NUL byte, even if it had previously
printed a match. This can lead to the user quite reasonably assuming
that there are no more matches, since a partial search is fairly
unintuitive. (ripgrep has this behavior by default because it really
wants to NOT search binary files at all, just like it doesn't search
gitignored or hidden files.)
With this commit, if a match has already been printed and ripgrep detects
a NUL byte, then it will print a warning message indicating that the search
stopped prematurely.
Moreover, this commit adds a new flag, --binary, which causes ripgrep to
stop filtering binary files, but in a way that still avoids dumping
binary data into terminals. That is, the --binary flag makes ripgrep
behave more like grep's default behavior.
For files explicitly specified in a search, e.g., `rg foo some-file`,
then no binary filtering is applied (just like no gitignore and no
hidden file filtering is applied). Instead, ripgrep behaves as if you
gave the --binary flag for all explicitly given files.
This was a fairly invasive change, and potentially increases the UX
complexity of ripgrep around binary files. (Before, there were two
binary modes, where as now there are three.) However, ripgrep is now a
bit louder with warning messages when binary file detection might
otherwise be hiding potential matches, so hopefully this is a net
improvement.
Finally, the `-uuu` convenience now maps to `--no-ignore --hidden
--binary`, since this is closer to the actualy intent of the
`--unrestricted` flag, i.e., to reduce ripgrep's smart filtering. As a
consequence, `rg -uuu foo` should now search roughly the same number of
bytes as `grep -r foo`, and `rg -uuua foo` should search roughly the
same number of bytes as `grep -ra foo`. (The "roughly" weasel word is
used because grep's and ripgrep's binary file detection might differ
somewhat---perhaps based on buffer sizes---which can impact exactly what
is and isn't searched.)
See the numerous tests in tests/binary.rs for intended behavior.
Fixes #306, Fixes #855
2019-04-09 01:28:38 +02:00
|
|
|
dir.create("hay", "foo\x00bar\nfoo\x00baz\n");
|
2018-08-07 02:11:58 +02:00
|
|
|
cmd.arg("-uuu").arg("foo");
|
|
|
|
|
|
|
|
let expected = "\
|
2020-11-02 17:37:49 +02:00
|
|
|
hay: binary file matches (found \"\\0\" byte around offset 3)
|
2018-08-07 02:11:58 +02:00
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(vimgrep, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
cmd.arg("--vimgrep").arg("Sherlock|Watson");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
sherlock:1:16:For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
sherlock:1:57:For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
sherlock:3:49:be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
sherlock:5:12:but Doctor Watson has to have it taken out for him and dusted,
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(vimgrep_no_line, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
cmd.arg("--vimgrep").arg("-N").arg("Sherlock|Watson");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
sherlock:16:For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
sherlock:57:For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
sherlock:49:be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
sherlock:12:but Doctor Watson has to have it taken out for him and dusted,
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(vimgrep_no_line_no_column, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
cmd.arg("--vimgrep").arg("-N").arg("--no-column").arg("Sherlock|Watson");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
sherlock:For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
sherlock:For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
sherlock:be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
sherlock:but Doctor Watson has to have it taken out for him and dusted,
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(preprocessing, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
if !cmd_exists("xzcat") {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
dir.create_bytes("sherlock.xz", include_bytes!("./data/sherlock.xz"));
|
|
|
|
cmd.arg("--pre").arg("xzcat").arg("Sherlock").arg("sherlock.xz");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
2018-09-05 04:45:24 +02:00
|
|
|
rgtest!(preprocessing_glob, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
if !cmd_exists("xzcat") {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
dir.create("sherlock", SHERLOCK);
|
|
|
|
dir.create_bytes("sherlock.xz", include_bytes!("./data/sherlock.xz"));
|
|
|
|
cmd.args(&["--pre", "xzcat", "--pre-glob", "*.xz", "Sherlock"]);
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
sherlock.xz:For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
sherlock.xz:be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
sherlock:For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
sherlock:be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
";
|
|
|
|
eqnice!(sort_lines(expected), sort_lines(&cmd.stdout()));
|
|
|
|
});
|
|
|
|
|
2018-08-07 02:11:58 +02:00
|
|
|
rgtest!(compressed_gzip, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
if !cmd_exists("gzip") {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
dir.create_bytes("sherlock.gz", include_bytes!("./data/sherlock.gz"));
|
|
|
|
cmd.arg("-z").arg("Sherlock").arg("sherlock.gz");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(compressed_bzip2, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
if !cmd_exists("bzip2") {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
dir.create_bytes("sherlock.bz2", include_bytes!("./data/sherlock.bz2"));
|
|
|
|
cmd.arg("-z").arg("Sherlock").arg("sherlock.bz2");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(compressed_xz, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
if !cmd_exists("xz") {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
dir.create_bytes("sherlock.xz", include_bytes!("./data/sherlock.xz"));
|
|
|
|
cmd.arg("-z").arg("Sherlock").arg("sherlock.xz");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(compressed_lz4, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
if !cmd_exists("lz4") {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
dir.create_bytes("sherlock.lz4", include_bytes!("./data/sherlock.lz4"));
|
|
|
|
cmd.arg("-z").arg("Sherlock").arg("sherlock.lz4");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(compressed_lzma, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
if !cmd_exists("xz") {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
dir.create_bytes("sherlock.lzma", include_bytes!("./data/sherlock.lzma"));
|
|
|
|
cmd.arg("-z").arg("Sherlock").arg("sherlock.lzma");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
2018-11-03 22:50:27 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(compressed_brotli, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
if !cmd_exists("brotli") {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
dir.create_bytes("sherlock.br", include_bytes!("./data/sherlock.br"));
|
|
|
|
cmd.arg("-z").arg("Sherlock").arg("sherlock.br");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(compressed_zstd, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
if !cmd_exists("zstd") {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
dir.create_bytes("sherlock.zst", include_bytes!("./data/sherlock.zst"));
|
|
|
|
cmd.arg("-z").arg("Sherlock").arg("sherlock.zst");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
2018-08-07 02:11:58 +02:00
|
|
|
});
|
|
|
|
|
2020-04-10 11:19:25 +02:00
|
|
|
rgtest!(compressed_uncompress, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
if !cmd_exists("uncompress") {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
dir.create_bytes("sherlock.Z", include_bytes!("./data/sherlock.Z"));
|
|
|
|
cmd.arg("-z").arg("Sherlock").arg("sherlock.Z");
|
|
|
|
|
|
|
|
let expected = "\
|
|
|
|
For the Doctor Watsons of this world, as opposed to the Sherlock
|
|
|
|
be, to a very large extent, the result of luck. Sherlock Holmes
|
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
2018-08-07 02:11:58 +02:00
|
|
|
rgtest!(compressed_failing_gzip, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
if !cmd_exists("gzip") {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
dir.create("sherlock.gz", SHERLOCK);
|
|
|
|
cmd.arg("-z").arg("Sherlock").arg("sherlock.gz");
|
|
|
|
|
|
|
|
cmd.assert_non_empty_stderr();
|
|
|
|
});
|
|
|
|
|
binary: rejigger ripgrep's handling of binary files
This commit attempts to surface binary filtering in a slightly more
user friendly way. Namely, before, ripgrep would silently stop
searching a file if it detected a NUL byte, even if it had previously
printed a match. This can lead to the user quite reasonably assuming
that there are no more matches, since a partial search is fairly
unintuitive. (ripgrep has this behavior by default because it really
wants to NOT search binary files at all, just like it doesn't search
gitignored or hidden files.)
With this commit, if a match has already been printed and ripgrep detects
a NUL byte, then it will print a warning message indicating that the search
stopped prematurely.
Moreover, this commit adds a new flag, --binary, which causes ripgrep to
stop filtering binary files, but in a way that still avoids dumping
binary data into terminals. That is, the --binary flag makes ripgrep
behave more like grep's default behavior.
For files explicitly specified in a search, e.g., `rg foo some-file`,
then no binary filtering is applied (just like no gitignore and no
hidden file filtering is applied). Instead, ripgrep behaves as if you
gave the --binary flag for all explicitly given files.
This was a fairly invasive change, and potentially increases the UX
complexity of ripgrep around binary files. (Before, there were two
binary modes, where as now there are three.) However, ripgrep is now a
bit louder with warning messages when binary file detection might
otherwise be hiding potential matches, so hopefully this is a net
improvement.
Finally, the `-uuu` convenience now maps to `--no-ignore --hidden
--binary`, since this is closer to the actualy intent of the
`--unrestricted` flag, i.e., to reduce ripgrep's smart filtering. As a
consequence, `rg -uuu foo` should now search roughly the same number of
bytes as `grep -r foo`, and `rg -uuua foo` should search roughly the
same number of bytes as `grep -ra foo`. (The "roughly" weasel word is
used because grep's and ripgrep's binary file detection might differ
somewhat---perhaps based on buffer sizes---which can impact exactly what
is and isn't searched.)
See the numerous tests in tests/binary.rs for intended behavior.
Fixes #306, Fixes #855
2019-04-09 01:28:38 +02:00
|
|
|
rgtest!(binary_convert, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("file", "foo\x00bar\nfoo\x00baz\n");
|
|
|
|
cmd.arg("--no-mmap").arg("foo").arg("file");
|
|
|
|
|
|
|
|
let expected = "\
|
2020-11-02 17:37:49 +02:00
|
|
|
binary file matches (found \"\\0\" byte around offset 3)
|
binary: rejigger ripgrep's handling of binary files
This commit attempts to surface binary filtering in a slightly more
user friendly way. Namely, before, ripgrep would silently stop
searching a file if it detected a NUL byte, even if it had previously
printed a match. This can lead to the user quite reasonably assuming
that there are no more matches, since a partial search is fairly
unintuitive. (ripgrep has this behavior by default because it really
wants to NOT search binary files at all, just like it doesn't search
gitignored or hidden files.)
With this commit, if a match has already been printed and ripgrep detects
a NUL byte, then it will print a warning message indicating that the search
stopped prematurely.
Moreover, this commit adds a new flag, --binary, which causes ripgrep to
stop filtering binary files, but in a way that still avoids dumping
binary data into terminals. That is, the --binary flag makes ripgrep
behave more like grep's default behavior.
For files explicitly specified in a search, e.g., `rg foo some-file`,
then no binary filtering is applied (just like no gitignore and no
hidden file filtering is applied). Instead, ripgrep behaves as if you
gave the --binary flag for all explicitly given files.
This was a fairly invasive change, and potentially increases the UX
complexity of ripgrep around binary files. (Before, there were two
binary modes, where as now there are three.) However, ripgrep is now a
bit louder with warning messages when binary file detection might
otherwise be hiding potential matches, so hopefully this is a net
improvement.
Finally, the `-uuu` convenience now maps to `--no-ignore --hidden
--binary`, since this is closer to the actualy intent of the
`--unrestricted` flag, i.e., to reduce ripgrep's smart filtering. As a
consequence, `rg -uuu foo` should now search roughly the same number of
bytes as `grep -r foo`, and `rg -uuua foo` should search roughly the
same number of bytes as `grep -ra foo`. (The "roughly" weasel word is
used because grep's and ripgrep's binary file detection might differ
somewhat---perhaps based on buffer sizes---which can impact exactly what
is and isn't searched.)
See the numerous tests in tests/binary.rs for intended behavior.
Fixes #306, Fixes #855
2019-04-09 01:28:38 +02:00
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(binary_convert_mmap, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("file", "foo\x00bar\nfoo\x00baz\n");
|
|
|
|
cmd.arg("--mmap").arg("foo").arg("file");
|
|
|
|
|
|
|
|
let expected = "\
|
2020-11-02 17:37:49 +02:00
|
|
|
binary file matches (found \"\\0\" byte around offset 3)
|
binary: rejigger ripgrep's handling of binary files
This commit attempts to surface binary filtering in a slightly more
user friendly way. Namely, before, ripgrep would silently stop
searching a file if it detected a NUL byte, even if it had previously
printed a match. This can lead to the user quite reasonably assuming
that there are no more matches, since a partial search is fairly
unintuitive. (ripgrep has this behavior by default because it really
wants to NOT search binary files at all, just like it doesn't search
gitignored or hidden files.)
With this commit, if a match has already been printed and ripgrep detects
a NUL byte, then it will print a warning message indicating that the search
stopped prematurely.
Moreover, this commit adds a new flag, --binary, which causes ripgrep to
stop filtering binary files, but in a way that still avoids dumping
binary data into terminals. That is, the --binary flag makes ripgrep
behave more like grep's default behavior.
For files explicitly specified in a search, e.g., `rg foo some-file`,
then no binary filtering is applied (just like no gitignore and no
hidden file filtering is applied). Instead, ripgrep behaves as if you
gave the --binary flag for all explicitly given files.
This was a fairly invasive change, and potentially increases the UX
complexity of ripgrep around binary files. (Before, there were two
binary modes, where as now there are three.) However, ripgrep is now a
bit louder with warning messages when binary file detection might
otherwise be hiding potential matches, so hopefully this is a net
improvement.
Finally, the `-uuu` convenience now maps to `--no-ignore --hidden
--binary`, since this is closer to the actualy intent of the
`--unrestricted` flag, i.e., to reduce ripgrep's smart filtering. As a
consequence, `rg -uuu foo` should now search roughly the same number of
bytes as `grep -r foo`, and `rg -uuua foo` should search roughly the
same number of bytes as `grep -ra foo`. (The "roughly" weasel word is
used because grep's and ripgrep's binary file detection might differ
somewhat---perhaps based on buffer sizes---which can impact exactly what
is and isn't searched.)
See the numerous tests in tests/binary.rs for intended behavior.
Fixes #306, Fixes #855
2019-04-09 01:28:38 +02:00
|
|
|
";
|
|
|
|
eqnice!(expected, cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(binary_quit, |dir: Dir, mut cmd: TestCommand| {
|
2018-08-07 02:11:58 +02:00
|
|
|
dir.create("file", "foo\x00bar\nfoo\x00baz\n");
|
binary: rejigger ripgrep's handling of binary files
This commit attempts to surface binary filtering in a slightly more
user friendly way. Namely, before, ripgrep would silently stop
searching a file if it detected a NUL byte, even if it had previously
printed a match. This can lead to the user quite reasonably assuming
that there are no more matches, since a partial search is fairly
unintuitive. (ripgrep has this behavior by default because it really
wants to NOT search binary files at all, just like it doesn't search
gitignored or hidden files.)
With this commit, if a match has already been printed and ripgrep detects
a NUL byte, then it will print a warning message indicating that the search
stopped prematurely.
Moreover, this commit adds a new flag, --binary, which causes ripgrep to
stop filtering binary files, but in a way that still avoids dumping
binary data into terminals. That is, the --binary flag makes ripgrep
behave more like grep's default behavior.
For files explicitly specified in a search, e.g., `rg foo some-file`,
then no binary filtering is applied (just like no gitignore and no
hidden file filtering is applied). Instead, ripgrep behaves as if you
gave the --binary flag for all explicitly given files.
This was a fairly invasive change, and potentially increases the UX
complexity of ripgrep around binary files. (Before, there were two
binary modes, where as now there are three.) However, ripgrep is now a
bit louder with warning messages when binary file detection might
otherwise be hiding potential matches, so hopefully this is a net
improvement.
Finally, the `-uuu` convenience now maps to `--no-ignore --hidden
--binary`, since this is closer to the actualy intent of the
`--unrestricted` flag, i.e., to reduce ripgrep's smart filtering. As a
consequence, `rg -uuu foo` should now search roughly the same number of
bytes as `grep -r foo`, and `rg -uuua foo` should search roughly the
same number of bytes as `grep -ra foo`. (The "roughly" weasel word is
used because grep's and ripgrep's binary file detection might differ
somewhat---perhaps based on buffer sizes---which can impact exactly what
is and isn't searched.)
See the numerous tests in tests/binary.rs for intended behavior.
Fixes #306, Fixes #855
2019-04-09 01:28:38 +02:00
|
|
|
cmd.arg("--no-mmap").arg("foo").arg("-gfile");
|
|
|
|
cmd.assert_err();
|
|
|
|
});
|
2018-08-07 02:11:58 +02:00
|
|
|
|
binary: rejigger ripgrep's handling of binary files
This commit attempts to surface binary filtering in a slightly more
user friendly way. Namely, before, ripgrep would silently stop
searching a file if it detected a NUL byte, even if it had previously
printed a match. This can lead to the user quite reasonably assuming
that there are no more matches, since a partial search is fairly
unintuitive. (ripgrep has this behavior by default because it really
wants to NOT search binary files at all, just like it doesn't search
gitignored or hidden files.)
With this commit, if a match has already been printed and ripgrep detects
a NUL byte, then it will print a warning message indicating that the search
stopped prematurely.
Moreover, this commit adds a new flag, --binary, which causes ripgrep to
stop filtering binary files, but in a way that still avoids dumping
binary data into terminals. That is, the --binary flag makes ripgrep
behave more like grep's default behavior.
For files explicitly specified in a search, e.g., `rg foo some-file`,
then no binary filtering is applied (just like no gitignore and no
hidden file filtering is applied). Instead, ripgrep behaves as if you
gave the --binary flag for all explicitly given files.
This was a fairly invasive change, and potentially increases the UX
complexity of ripgrep around binary files. (Before, there were two
binary modes, where as now there are three.) However, ripgrep is now a
bit louder with warning messages when binary file detection might
otherwise be hiding potential matches, so hopefully this is a net
improvement.
Finally, the `-uuu` convenience now maps to `--no-ignore --hidden
--binary`, since this is closer to the actualy intent of the
`--unrestricted` flag, i.e., to reduce ripgrep's smart filtering. As a
consequence, `rg -uuu foo` should now search roughly the same number of
bytes as `grep -r foo`, and `rg -uuua foo` should search roughly the
same number of bytes as `grep -ra foo`. (The "roughly" weasel word is
used because grep's and ripgrep's binary file detection might differ
somewhat---perhaps based on buffer sizes---which can impact exactly what
is and isn't searched.)
See the numerous tests in tests/binary.rs for intended behavior.
Fixes #306, Fixes #855
2019-04-09 01:28:38 +02:00
|
|
|
rgtest!(binary_quit_mmap, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("file", "foo\x00bar\nfoo\x00baz\n");
|
|
|
|
cmd.arg("--mmap").arg("foo").arg("-gfile");
|
2018-08-07 02:11:58 +02:00
|
|
|
cmd.assert_err();
|
|
|
|
});
|
|
|
|
|
|
|
|
// The following two tests show a discrepancy in search results between
|
|
|
|
// searching with memory mapped files and stream searching. Stream searching
|
|
|
|
// uses a heuristic (that GNU grep also uses) where NUL bytes are replaced with
|
|
|
|
// the EOL terminator, which tends to avoid allocating large amounts of memory
|
|
|
|
// for really long "lines." The memory map searcher has no need to worry about
|
|
|
|
// such things, and more than that, it would be pretty hard for it to match the
|
|
|
|
// semantics of streaming search in this case.
|
|
|
|
//
|
|
|
|
// Binary files with lots of NULs aren't really part of the use case of ripgrep
|
|
|
|
// (or any other grep-like tool for that matter), so we shouldn't feel too bad
|
|
|
|
// about it.
|
|
|
|
rgtest!(binary_search_mmap, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("file", "foo\x00bar\nfoo\x00baz\n");
|
|
|
|
cmd.arg("-a").arg("--mmap").arg("foo").arg("file");
|
|
|
|
eqnice!("foo\x00bar\nfoo\x00baz\n", cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(binary_search_no_mmap, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("file", "foo\x00bar\nfoo\x00baz\n");
|
|
|
|
cmd.arg("-a").arg("--no-mmap").arg("foo").arg("file");
|
|
|
|
eqnice!("foo\x00bar\nfoo\x00baz\n", cmd.stdout());
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(files, |dir: Dir, mut cmd: TestCommand| {
|
|
|
|
dir.create("file", "");
|
|
|
|
dir.create_dir("dir");
|
|
|
|
dir.create("dir/file", "");
|
|
|
|
cmd.arg("--files");
|
|
|
|
|
|
|
|
eqnice!(sort_lines("file\ndir/file\n"), sort_lines(&cmd.stdout()));
|
|
|
|
});
|
|
|
|
|
|
|
|
rgtest!(type_list, |_: Dir, mut cmd: TestCommand| {
|
|
|
|
cmd.arg("--type-list");
|
|
|
|
// This can change over time, so just make sure we print something.
|
|
|
|
assert!(!cmd.stdout().is_empty());
|
|
|
|
});
|