|
3 | 3 |
|
4 | 4 | package software.aws.toolkits.jetbrains.services.telemetry |
5 | 5 |
|
6 | | -import org.junit.jupiter.api.Assertions.assertEquals |
7 | | -import org.junit.jupiter.api.Test |
| 6 | +import org.assertj.core.api.Assertions.assertThat |
| 7 | +import org.junit.jupiter.params.ParameterizedTest |
| 8 | +import org.junit.jupiter.params.provider.Arguments |
| 9 | +import org.junit.jupiter.params.provider.MethodSource |
| 10 | +import java.util.stream.Stream |
8 | 11 |
|
9 | 12 | class TelemetryUtilsTest { |
10 | 13 |
|
11 | | - @Test |
12 | | - fun testScrubNames() { |
| 14 | + @ParameterizedTest |
| 15 | + @MethodSource("scrubNamesTestCases") |
| 16 | + fun testScrubNames(input: String, expected: String) { |
13 | 17 | val fakeUser = "jdoe123" |
| 18 | + assertThat(expected).isEqualTo(scrubNames(input, fakeUser)) |
| 19 | + } |
14 | 20 |
|
15 | | - assertEquals("", scrubNames("", fakeUser)) |
16 | | - assertEquals("a ./ b", scrubNames("a ./ b", fakeUser)) |
17 | | - assertEquals("a ../ b", scrubNames("a ../ b", fakeUser)) |
18 | | - assertEquals("a /.. b", scrubNames("a /.. b", fakeUser)) |
19 | | - assertEquals("a //..// b", scrubNames("a //..// b", fakeUser)) |
20 | | - assertEquals("a / b", scrubNames("a / b", fakeUser)) |
21 | | - assertEquals("a ~/ b", scrubNames("a ~/ b", fakeUser)) |
22 | | - assertEquals("a //// b", scrubNames("a //// b", fakeUser)) |
23 | | - assertEquals("a .. b", scrubNames("a .. b", fakeUser)) |
24 | | - assertEquals("a . b", scrubNames("a . b", fakeUser)) |
25 | | - assertEquals("lots of x", scrubNames(" lots of space ", "space")) |
26 | | - assertEquals( |
27 | | - "Failed to save c:/xß/xï/xó/x∑/xπ/xö/x/xö/x.txt no permissions (error!)", |
28 | | - scrubNames( |
| 21 | + companion object { |
| 22 | + @JvmStatic |
| 23 | + fun scrubNamesTestCases(): Stream<Arguments> = Stream.of( |
| 24 | + Arguments.of("", ""), |
| 25 | + Arguments.of("a ./ b", "a ./ b"), |
| 26 | + Arguments.of("a ../ b", "a ../ b"), |
| 27 | + Arguments.of("a /.. b", "a /.. b"), |
| 28 | + Arguments.of("a //..// b", "a //..// b"), |
| 29 | + Arguments.of("a / b", "a / b"), |
| 30 | + Arguments.of("a ~/ b", "a ~/ b"), |
| 31 | + Arguments.of("a //// b", "a //// b"), |
| 32 | + Arguments.of("a .. b", "a .. b"), |
| 33 | + Arguments.of("a . b", "a . b"), |
| 34 | + Arguments.of(" lots of space ", "lots of space"), |
| 35 | + Arguments.of( |
29 | 36 | "Failed to save c:/fooß/aïböcß/aób∑c/∑ö/ππ¨p/ö/a/bar123öabc/baz.txt no permissions (error!)", |
30 | | - fakeUser |
| 37 | + "Failed to save c:/xß/xï/xó/x∑/xπ/xö/x/xö/x.txt no permissions (error!)" |
| 38 | + ), |
| 39 | + Arguments.of( |
| 40 | + "user: jdoe123 file: C:/Users/user1/.aws/sso/cache/abc123.json (regex: /foo/)", |
| 41 | + "user: x file: C:/Users/x/.aws/sso/cache/x.json (regex: /x/)" |
| 42 | + ), |
| 43 | + Arguments.of("/Users/user1/foo.jso", "/Users/x/x.jso"), |
| 44 | + Arguments.of("/Users/user1/foo.js", "/Users/x/x.js"), |
| 45 | + Arguments.of("/Users/user1/noFileExtension", "/Users/x/x"), |
| 46 | + Arguments.of("/Users/user1/minExtLength.a", "/Users/x/x.a"), |
| 47 | + Arguments.of("/Users/user1/extIsNum.123456", "/Users/x/x.123456"), |
| 48 | + Arguments.of("/Users/user1/foo.looooooooongextension", "/Users/x/x.looooooooongextension"), |
| 49 | + Arguments.of("/Users/user1/multipleExts.ext1.ext2.ext3", "/Users/x/x.ext3"), |
| 50 | + Arguments.of("c:\\fooß\\bar\\baz.txt", "c:/xß/x/x.txt"), |
| 51 | + Arguments.of("unc path: \\\\server$\\pipename\\etc END", "unc path: //x$/x/x END"), |
| 52 | + Arguments.of( |
| 53 | + "c:\\Users\\user1\\.aws\\sso\\cache\\abc123.json jdoe123 abc", |
| 54 | + "c:/Users/x/.aws/sso/cache/x.json x abc" |
| 55 | + ), |
| 56 | + Arguments.of("unix /home/jdoe123/.aws/config failed", "unix /home/x/.aws/config failed"), |
| 57 | + Arguments.of("unix ~jdoe123/.aws/config failed", "unix ~x/.aws/config failed"), |
| 58 | + Arguments.of("unix ../../.aws/config failed", "unix ../../.aws/config failed"), |
| 59 | + Arguments.of("unix ~/.aws/config failed", "unix ~/.aws/config failed"), |
| 60 | + Arguments.of( |
| 61 | + "/Users/user1/.aws/sso/cache/abc123.json no space", |
| 62 | + "/Users/x/.aws/sso/cache/x.json no space" |
31 | 63 | ) |
32 | 64 | ) |
33 | | - assertEquals( |
34 | | - "user: x file: C:/Users/x/.aws/sso/cache/x.json (regex: /x/)", |
35 | | - scrubNames("user: jdoe123 file: C:/Users/user1/.aws/sso/cache/abc123.json (regex: /foo/)", fakeUser) |
36 | | - ) |
37 | | - assertEquals("/Users/x/x.jso", scrubNames("/Users/user1/foo.jso", fakeUser)) |
38 | | - assertEquals("/Users/x/x.js", scrubNames("/Users/user1/foo.js", fakeUser)) |
39 | | - assertEquals("/Users/x/x", scrubNames("/Users/user1/noFileExtension", fakeUser)) |
40 | | - assertEquals("/Users/x/x.a", scrubNames("/Users/user1/minExtLength.a", fakeUser)) |
41 | | - assertEquals("/Users/x/x.123456", scrubNames("/Users/user1/extIsNum.123456", fakeUser)) |
42 | | - assertEquals( |
43 | | - "/Users/x/x.looooooooongextension", |
44 | | - scrubNames("/Users/user1/foo.looooooooongextension", fakeUser) |
45 | | - ) |
46 | | - assertEquals("/Users/x/x.ext3", scrubNames("/Users/user1/multipleExts.ext1.ext2.ext3", fakeUser)) |
47 | | - assertEquals("c:/xß/x/x.txt", scrubNames("c:\\fooß\\bar\\baz.txt", fakeUser)) |
48 | | - assertEquals( |
49 | | - "unc path: //x$/x/x END", |
50 | | - scrubNames("unc path: \\\\server$\\pipename\\etc END", fakeUser) |
51 | | - ) |
52 | | - assertEquals( |
53 | | - "c:/Users/x/.aws/sso/cache/x.json x abc", |
54 | | - scrubNames("c:\\Users\\user1\\.aws\\sso\\cache\\abc123.json jdoe123 abc", fakeUser) |
55 | | - ) |
56 | | - assertEquals( |
57 | | - "unix /home/x/.aws/config failed", |
58 | | - scrubNames("unix /home/jdoe123/.aws/config failed", fakeUser) |
59 | | - ) |
60 | | - assertEquals( |
61 | | - "unix ~x/.aws/config failed", |
62 | | - scrubNames("unix ~jdoe123/.aws/config failed", fakeUser) |
63 | | - ) |
64 | | - assertEquals( |
65 | | - "unix ../../.aws/config failed", |
66 | | - scrubNames("unix ../../.aws/config failed", fakeUser) |
67 | | - ) |
68 | | - assertEquals("unix ~/.aws/config failed", scrubNames("unix ~/.aws/config failed", fakeUser)) |
69 | | - assertEquals( |
70 | | - "/Users/x/.aws/sso/cache/x.json no space", |
71 | | - scrubNames("/Users/user1/.aws/sso/cache/abc123.json no space", fakeUser) |
72 | | - ) |
73 | 65 | } |
74 | 66 | } |
0 commit comments