]> Untitled Git - lemmy.git/blob - crates/utils/src/test.rs
Merge pull request #1536 from LemmyNet/change_preferred_to_display_name
[lemmy.git] / crates / utils / src / test.rs
1 use crate::utils::{
2   is_valid_community_name,
3   is_valid_display_name,
4   is_valid_post_title,
5   is_valid_username,
6   remove_slurs,
7   scrape_text_for_mentions,
8   slur_check,
9   slurs_vec_to_str,
10 };
11
12 #[test]
13 fn test_mentions_regex() {
14   let text = "Just read a great blog post by [@tedu@honk.teduangst.com](/u/test). And another by !test_community@fish.teduangst.com . Another [@lemmy@lemmy-alpha:8540](/u/fish)";
15   let mentions = scrape_text_for_mentions(text);
16
17   assert_eq!(mentions[0].name, "tedu".to_string());
18   assert_eq!(mentions[0].domain, "honk.teduangst.com".to_string());
19   assert_eq!(mentions[1].domain, "lemmy-alpha:8540".to_string());
20 }
21
22 #[test]
23 fn test_valid_register_username() {
24   assert!(is_valid_username("Hello_98"));
25   assert!(is_valid_username("ten"));
26   assert!(!is_valid_username("Hello-98"));
27   assert!(!is_valid_username("a"));
28   assert!(!is_valid_username(""));
29 }
30
31 #[test]
32 fn test_valid_display_name() {
33   assert!(is_valid_display_name("hello @there"));
34   assert!(!is_valid_display_name("@hello there"));
35
36   // Make sure zero-space with an @ doesn't work
37   assert!(!is_valid_display_name(&format!(
38     "{}@my name is",
39     '\u{200b}'
40   )));
41 }
42
43 #[test]
44 fn test_valid_community_name() {
45   assert!(is_valid_community_name("example"));
46   assert!(is_valid_community_name("example_community"));
47   assert!(!is_valid_community_name("Example"));
48   assert!(!is_valid_community_name("Ex"));
49   assert!(!is_valid_community_name(""));
50 }
51
52 #[test]
53 fn test_valid_post_title() {
54   assert!(is_valid_post_title("Post Title"));
55   assert!(is_valid_post_title("   POST TITLE ðŸ˜ƒðŸ˜ƒðŸ˜ƒðŸ˜ƒðŸ˜ƒ"));
56   assert!(!is_valid_post_title("\n \n \n \n             ")); // tabs/spaces/newlines
57 }
58
59 #[test]
60 fn test_slur_filter() {
61   let test =
62       "faggot test kike tranny cocksucker retardeds. Capitalized Niggerz. This is a bunch of other safe text.";
63   let slur_free = "No slurs here";
64   assert_eq!(
65       remove_slurs(&test),
66       "*removed* test *removed* *removed* *removed* *removed*. Capitalized *removed*. This is a bunch of other safe text."
67         .to_string()
68     );
69
70   let has_slurs_vec = vec![
71     "Niggerz",
72     "cocksucker",
73     "faggot",
74     "kike",
75     "retardeds",
76     "tranny",
77   ];
78   let has_slurs_err_str = "No slurs - Niggerz, cocksucker, faggot, kike, retardeds, tranny";
79
80   assert_eq!(slur_check(test), Err(has_slurs_vec));
81   assert_eq!(slur_check(slur_free), Ok(()));
82   if let Err(slur_vec) = slur_check(test) {
83     assert_eq!(&slurs_vec_to_str(slur_vec), has_slurs_err_str);
84   }
85 }
86
87 // These helped with testing
88 // #[test]
89 // fn test_send_email() {
90 //  let result =  send_email("not a subject", "test_email@gmail.com", "ur user", "<h1>HI there</h1>");
91 //   assert!(result.is_ok());
92 // }