|
4 | 4 | package resources |
5 | 5 |
|
6 | 6 | import ( |
7 | | - "sort" |
8 | 7 | "testing" |
9 | 8 | "time" |
10 | 9 |
|
@@ -75,32 +74,67 @@ func TestAddConnInfoToEc2Instances(t *testing.T) { |
75 | 74 | } |
76 | 75 |
|
77 | 76 | func TestGetDiscoveryTargets(t *testing.T) { |
78 | | - config := &inventory.Config{ |
79 | | - Discover: &inventory.Discovery{ |
80 | | - Targets: []string{}, |
| 77 | + cases := []struct { |
| 78 | + name string |
| 79 | + targets []string |
| 80 | + want []string |
| 81 | + }{ |
| 82 | + { |
| 83 | + name: "empty", |
| 84 | + targets: []string{}, |
| 85 | + want: Auto, |
| 86 | + }, |
| 87 | + { |
| 88 | + name: "all", |
| 89 | + targets: []string{"all"}, |
| 90 | + want: allDiscovery(), |
| 91 | + }, |
| 92 | + { |
| 93 | + name: "auto", |
| 94 | + targets: []string{"auto"}, |
| 95 | + want: Auto, |
| 96 | + }, |
| 97 | + { |
| 98 | + name: "resources", |
| 99 | + targets: []string{"resources"}, |
| 100 | + want: AllAPIResources, |
| 101 | + }, |
| 102 | + { |
| 103 | + name: "auto and resources", |
| 104 | + targets: []string{"auto", "resources"}, |
| 105 | + want: append(Auto, AllAPIResources...), |
| 106 | + }, |
| 107 | + { |
| 108 | + name: "all and resources", |
| 109 | + targets: []string{"all", "resources"}, |
| 110 | + want: allDiscovery(), |
| 111 | + }, |
| 112 | + { |
| 113 | + name: "all, auto and resources", |
| 114 | + targets: []string{"all", "resources"}, |
| 115 | + want: allDiscovery(), |
| 116 | + }, |
| 117 | + { |
| 118 | + name: "random", |
| 119 | + targets: []string{"s3-buckets", "iam-users", "instances"}, |
| 120 | + want: []string{DiscoveryS3Buckets, DiscoveryIAMUsers, DiscoveryInstances}, |
| 121 | + }, |
| 122 | + { |
| 123 | + name: "duplicates", |
| 124 | + targets: []string{"auto", "s3-buckets", "iam-users", "s3-buckets", "auto"}, |
| 125 | + want: append(Auto, []string{DiscoveryS3Buckets, DiscoveryIAMUsers}...), |
81 | 126 | }, |
82 | 127 | } |
83 | | - // test all with other stuff |
84 | | - config.Discover.Targets = []string{"all", "projects", "instances"} |
85 | | - require.Equal(t, allDiscovery(), getDiscoveryTargets(config)) |
86 | | - |
87 | | - // test just all |
88 | | - config.Discover.Targets = []string{"all"} |
89 | | - require.Equal(t, allDiscovery(), getDiscoveryTargets(config)) |
90 | 128 |
|
91 | | - // test auto with other stuff |
92 | | - config.Discover.Targets = []string{"auto", "s3-buckets", "iam-users"} |
93 | | - res := append(Auto, []string{DiscoveryS3Buckets, DiscoveryIAMUsers}...) |
94 | | - sort.Strings(res) |
95 | | - targets := getDiscoveryTargets(config) |
96 | | - sort.Strings(targets) |
97 | | - require.Equal(t, res, targets) |
98 | | - |
99 | | - // test just auto |
100 | | - config.Discover.Targets = []string{"auto"} |
101 | | - require.Equal(t, Auto, getDiscoveryTargets(config)) |
102 | | - |
103 | | - // test random |
104 | | - config.Discover.Targets = []string{"s3-buckets", "iam-users", "instances"} |
105 | | - require.Equal(t, []string{DiscoveryS3Buckets, DiscoveryIAMUsers, DiscoveryInstances}, getDiscoveryTargets(config)) |
| 129 | + for _, tc := range cases { |
| 130 | + t.Run(tc.name, func(t *testing.T) { |
| 131 | + config := &inventory.Config{ |
| 132 | + Discover: &inventory.Discovery{ |
| 133 | + Targets: tc.targets, |
| 134 | + }, |
| 135 | + } |
| 136 | + got := getDiscoveryTargets(config) |
| 137 | + require.ElementsMatch(t, tc.want, got) |
| 138 | + }) |
| 139 | + } |
106 | 140 | } |
0 commit comments