1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-10 16:11:13 -05:00

test: fixed initial [WILDCARD] not matching empty the on first line (#5420)

This commit is contained in:
Jack Kelly 2020-06-08 18:24:27 +01:00 committed by GitHub
parent 6236252c66
commit cb29f7f323
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 71 additions and 3 deletions

View file

@ -1 +1,2 @@
[WILDCARD]
Hello Hello

View file

@ -152,8 +152,66 @@ pub fn test_raw_tty() {
#[test] #[test]
fn test_pattern_match() { fn test_pattern_match() {
assert!(util::pattern_match("foo[BAR]baz", "foobarbaz", "[BAR]")); // foo, bar, baz, qux, quux, quuz, corge, grault, garply, waldo, fred, plugh, xyzzy
assert!(!util::pattern_match("foo[BAR]baz", "foobazbar", "[BAR]"));
let wildcard = "[BAR]";
assert!(util::pattern_match("foo[BAR]baz", "foobarbaz", wildcard));
assert!(!util::pattern_match("foo[BAR]baz", "foobazbar", wildcard));
let multiline_pattern = "[BAR]
foo:
[BAR]baz[BAR]";
fn multi_line_builder(input: &str, leading_text: Option<&str>) -> String {
// If there is leading text add a newline so it's on it's own line
let head = match leading_text {
Some(v) => format!("{}\n", v),
None => "".to_string(),
};
format!(
"{}foo:
quuz {} corge
grault",
head, input
)
}
// Validate multi-line string builder
assert_eq!(
"QUUX=qux
foo:
quuz BAZ corge
grault",
multi_line_builder("BAZ", Some("QUUX=qux"))
);
// Correct input & leading line
assert!(util::pattern_match(
multiline_pattern,
&multi_line_builder("baz", Some("QUX=quux")),
wildcard
));
// Correct input & no leading line
assert!(util::pattern_match(
multiline_pattern,
&multi_line_builder("baz", None),
wildcard
));
// Incorrect input & leading line
assert!(!util::pattern_match(
multiline_pattern,
&multi_line_builder("garply", Some("QUX=quux")),
wildcard
));
// Incorrect input & no leading line
assert!(!util::pattern_match(
multiline_pattern,
&multi_line_builder("garply", None),
wildcard
));
} }
#[test] #[test]
@ -2996,6 +3054,8 @@ mod util {
let (mut reader, writer) = pipe().unwrap(); let (mut reader, writer) = pipe().unwrap();
let tests_dir = root.join("cli").join("tests"); let tests_dir = root.join("cli").join("tests");
let mut command = deno_cmd(); let mut command = deno_cmd();
println!("deno_exe args {}", self.args);
println!("deno_exe tests path {:?}", &tests_dir);
command.args(args); command.args(args);
command.current_dir(&tests_dir); command.current_dir(&tests_dir);
command.stdin(Stdio::piped()); command.stdin(Stdio::piped());
@ -3056,7 +3116,7 @@ mod util {
pub fn pattern_match(pattern: &str, s: &str, wildcard: &str) -> bool { pub fn pattern_match(pattern: &str, s: &str, wildcard: &str) -> bool {
// Normalize line endings // Normalize line endings
let s = s.replace("\r\n", "\n"); let mut s = s.replace("\r\n", "\n");
let pattern = pattern.replace("\r\n", "\n"); let pattern = pattern.replace("\r\n", "\n");
if pattern == wildcard { if pattern == wildcard {
@ -3072,6 +3132,13 @@ mod util {
return false; return false;
} }
// If the first line of the pattern is just a wildcard the newline character
// needs to be pre-pended so it can safely match anything or nothing and
// continue matching.
if pattern.lines().next() == Some(wildcard) {
s.insert_str(0, "\n");
}
let mut t = s.split_at(parts[0].len()); let mut t = s.split_at(parts[0].len());
for (i, part) in parts.iter().enumerate() { for (i, part) in parts.iter().enumerate() {