]> git.lizzy.rs Git - rust.git/blob - tests/ui/regex.rs
Merge branch 'master' into issue-2879
[rust.git] / tests / ui / regex.rs
1 #![feature(tool_lints)]
2
3
4 #![allow(unused)]
5 #![warn(clippy::invalid_regex, clippy::trivial_regex, clippy::regex_macro)]
6
7 extern crate regex;
8
9 use regex::{Regex, RegexSet, RegexBuilder};
10 use regex::bytes::{Regex as BRegex, RegexSet as BRegexSet, RegexBuilder as BRegexBuilder};
11
12 const OPENING_PAREN: &str = "(";
13 const NOT_A_REAL_REGEX: &str = "foobar";
14
15 fn syntax_error() {
16     let pipe_in_wrong_position = Regex::new("|");
17     let pipe_in_wrong_position_builder = RegexBuilder::new("|");
18     let wrong_char_ranice = Regex::new("[z-a]");
19     let some_unicode = Regex::new("[é-è]");
20
21     let some_regex = Regex::new(OPENING_PAREN);
22
23     let binary_pipe_in_wrong_position = BRegex::new("|");
24     let some_binary_regex = BRegex::new(OPENING_PAREN);
25     let some_binary_regex_builder = BRegexBuilder::new(OPENING_PAREN);
26
27     let closing_paren = ")";
28     let not_linted = Regex::new(closing_paren);
29
30     let set = RegexSet::new(&[
31         r"[a-z]+@[a-z]+\.(com|org|net)",
32         r"[a-z]+\.(com|org|net)",
33     ]);
34     let bset = BRegexSet::new(&[
35         r"[a-z]+@[a-z]+\.(com|org|net)",
36         r"[a-z]+\.(com|org|net)",
37         r".", // regression test
38     ]);
39
40     let set_error = RegexSet::new(&[
41         OPENING_PAREN,
42         r"[a-z]+\.(com|org|net)",
43     ]);
44     let bset_error = BRegexSet::new(&[
45         OPENING_PAREN,
46         r"[a-z]+\.(com|org|net)",
47     ]);
48
49     let raw_string_error = Regex::new(r"[...\/...]");
50     let raw_string_error = Regex::new(r#"[...\/...]"#);
51 }
52
53 fn trivial_regex() {
54     let trivial_eq = Regex::new("^foobar$");
55
56     let trivial_eq_builder = RegexBuilder::new("^foobar$");
57
58     let trivial_starts_with = Regex::new("^foobar");
59
60     let trivial_ends_with = Regex::new("foobar$");
61
62     let trivial_contains = Regex::new("foobar");
63
64     let trivial_contains = Regex::new(NOT_A_REAL_REGEX);
65
66     let trivial_backslash = Regex::new("a\\.b");
67
68     // unlikely corner cases
69     let trivial_empty = Regex::new("");
70
71     let trivial_empty = Regex::new("^");
72
73     let trivial_empty = Regex::new("^$");
74
75     let binary_trivial_empty = BRegex::new("^$");
76
77     // non-trivial regexes
78     let non_trivial_dot = Regex::new("a.b");
79     let non_trivial_dot_builder = RegexBuilder::new("a.b");
80     let non_trivial_eq = Regex::new("^foo|bar$");
81     let non_trivial_starts_with = Regex::new("^foo|bar");
82     let non_trivial_ends_with = Regex::new("^foo|bar");
83     let non_trivial_ends_with = Regex::new("foo|bar");
84     let non_trivial_binary = BRegex::new("foo|bar");
85     let non_trivial_binary_builder = BRegexBuilder::new("foo|bar");
86 }
87
88 fn main() {
89     syntax_error();
90     trivial_regex();
91 }