|
9 | 9 | "fmt"
|
10 | 10 | "testing"
|
11 | 11 |
|
| 12 | + "github.com/stretchr/testify/assert" |
12 | 13 | "github.com/stretchr/testify/require"
|
13 | 14 | "go.uber.org/zap/zapcore"
|
14 | 15 |
|
@@ -86,70 +87,148 @@ func BenchmarkIndexerGet(b *testing.B) {
|
86 | 87 | })
|
87 | 88 | }
|
88 | 89 |
|
89 |
| -func TestGet_ListAllPackages(t *testing.T) { |
| 90 | +func TestGet_ListPackages(t *testing.T) { |
90 | 91 | // given
|
91 | 92 | fs := PrepareFakeServer(t, "testdata/search-index-all-full.json")
|
92 | 93 | defer fs.Stop()
|
93 | 94 | storageClient := fs.Client()
|
94 | 95 | indexer := NewIndexer(util.NewTestLogger(), storageClient, FakeIndexerOptions)
|
95 | 96 |
|
96 |
| - err := indexer.Init(context.Background()) |
| 97 | + ctx := context.Background() |
| 98 | + err := indexer.Init(ctx) |
97 | 99 | require.NoError(t, err, "storage indexer must be initialized properly")
|
98 | 100 |
|
99 |
| - // when |
100 |
| - foundPackages, err := indexer.Get(context.Background(), &packages.GetOptions{}) |
101 |
| - |
102 |
| - // then |
103 |
| - require.NoError(t, err, "packages should be returned") |
104 |
| - require.Len(t, foundPackages, 1133) |
105 |
| -} |
106 |
| - |
107 |
| -func TestGet_FindLatestPackage(t *testing.T) { |
108 |
| - // given |
109 |
| - fs := PrepareFakeServer(t, "testdata/search-index-all-full.json") |
110 |
| - defer fs.Stop() |
111 |
| - storageClient := fs.Client() |
112 |
| - indexer := NewIndexer(util.NewTestLogger(), storageClient, FakeIndexerOptions) |
113 |
| - |
114 |
| - err := indexer.Init(context.Background()) |
115 |
| - require.NoError(t, err, "storage indexer must be initialized properly") |
116 |
| - |
117 |
| - // when |
118 |
| - foundPackages, err := indexer.Get(context.Background(), &packages.GetOptions{ |
119 |
| - Filter: &packages.Filter{ |
120 |
| - PackageName: "apm", |
121 |
| - PackageType: "integration", |
| 101 | + cases := []struct { |
| 102 | + name string |
| 103 | + options *packages.GetOptions |
| 104 | + expected int |
| 105 | + expectedName string |
| 106 | + expectedVersion string |
| 107 | + }{ |
| 108 | + { |
| 109 | + name: "all packages filter nil", |
| 110 | + options: &packages.GetOptions{}, |
| 111 | + expected: 1133, |
122 | 112 | },
|
123 |
| - }) |
124 |
| - |
125 |
| - // then |
126 |
| - require.NoError(t, err, "packages should be returned") |
127 |
| - require.Len(t, foundPackages, 1) |
128 |
| - require.Equal(t, "apm", foundPackages[0].Name) |
129 |
| - require.Equal(t, "8.2.0", foundPackages[0].Version) |
130 |
| -} |
131 |
| - |
132 |
| -func TestGet_UnknownPackage(t *testing.T) { |
133 |
| - // given |
134 |
| - fs := PrepareFakeServer(t, "testdata/search-index-all-full.json") |
135 |
| - defer fs.Stop() |
136 |
| - storageClient := fs.Client() |
137 |
| - indexer := NewIndexer(util.NewTestLogger(), storageClient, FakeIndexerOptions) |
138 |
| - |
139 |
| - err := indexer.Init(context.Background()) |
140 |
| - require.NoError(t, err, "storage indexer must be initialized properly") |
141 |
| - |
142 |
| - // when |
143 |
| - foundPackages, err := indexer.Get(context.Background(), &packages.GetOptions{ |
144 |
| - Filter: &packages.Filter{ |
145 |
| - PackageName: "qwertyuiop", |
146 |
| - PackageType: "integration", |
| 113 | + { |
| 114 | + name: "all versions of packages including prerelease", |
| 115 | + options: &packages.GetOptions{ |
| 116 | + Filter: &packages.Filter{ |
| 117 | + AllVersions: true, |
| 118 | + Prerelease: true, |
| 119 | + }, |
| 120 | + }, |
| 121 | + expected: 1133, |
147 | 122 | },
|
148 |
| - }) |
| 123 | + { |
| 124 | + name: "latest versions of packages not including prerelease", |
| 125 | + options: &packages.GetOptions{ |
| 126 | + Filter: &packages.Filter{ |
| 127 | + AllVersions: false, |
| 128 | + Prerelease: false, |
| 129 | + }, |
| 130 | + }, |
| 131 | + expected: 99, |
| 132 | + }, |
| 133 | + { |
| 134 | + name: "all packages with all versions and no prerelease", |
| 135 | + options: &packages.GetOptions{ |
| 136 | + Filter: &packages.Filter{ |
| 137 | + AllVersions: true, |
| 138 | + }, |
| 139 | + }, |
| 140 | + expected: 494, |
| 141 | + }, |
| 142 | + { |
| 143 | + name: "all packages with latest versions and no prerelease", |
| 144 | + options: &packages.GetOptions{ |
| 145 | + Filter: &packages.Filter{ |
| 146 | + Prerelease: false, |
| 147 | + }, |
| 148 | + }, |
| 149 | + expected: 99, |
| 150 | + }, |
| 151 | + { |
| 152 | + name: "all packages prerelease", |
| 153 | + options: &packages.GetOptions{ |
| 154 | + Filter: &packages.Filter{ |
| 155 | + Prerelease: true, |
| 156 | + }, |
| 157 | + }, |
| 158 | + expected: 147, |
| 159 | + }, |
| 160 | + { |
| 161 | + name: "all zeek packages with prerelease", |
| 162 | + options: &packages.GetOptions{ |
| 163 | + Filter: &packages.Filter{ |
| 164 | + AllVersions: true, |
| 165 | + Prerelease: true, |
| 166 | + PackageName: "zeek", |
| 167 | + }, |
| 168 | + }, |
| 169 | + expected: 17, |
| 170 | + }, |
| 171 | + { |
| 172 | + name: "all packages with all versions of a giventype", |
| 173 | + options: &packages.GetOptions{ |
| 174 | + Filter: &packages.Filter{ |
| 175 | + AllVersions: true, |
| 176 | + Prerelease: true, |
| 177 | + PackageType: "solution", |
| 178 | + }, |
| 179 | + }, |
| 180 | + expected: 2, |
| 181 | + }, |
| 182 | + { |
| 183 | + name: "one package of a giventype", |
| 184 | + options: &packages.GetOptions{ |
| 185 | + Filter: &packages.Filter{ |
| 186 | + Prerelease: true, |
| 187 | + PackageName: "tomcat", |
| 188 | + PackageVersion: "0.3.0", |
| 189 | + }, |
| 190 | + }, |
| 191 | + expected: 1, |
| 192 | + }, |
| 193 | + { |
| 194 | + name: "unknown package", |
| 195 | + options: &packages.GetOptions{ |
| 196 | + Filter: &packages.Filter{ |
| 197 | + PackageName: "qwertyuiop", |
| 198 | + PackageType: "integration", |
| 199 | + }, |
| 200 | + }, |
| 201 | + expected: 0, |
| 202 | + }, |
| 203 | + { |
| 204 | + name: "latest package", |
| 205 | + options: &packages.GetOptions{ |
| 206 | + Filter: &packages.Filter{ |
| 207 | + PackageName: "apm", |
| 208 | + PackageType: "integration", |
| 209 | + }, |
| 210 | + }, |
| 211 | + expected: 1, |
| 212 | + expectedName: "apm", |
| 213 | + expectedVersion: "8.2.0", |
| 214 | + }, |
| 215 | + } |
149 | 216 |
|
150 |
| - // then |
151 |
| - require.NoError(t, err, "packages should be returned") |
152 |
| - require.Len(t, foundPackages, 0) |
| 217 | + for _, c := range cases { |
| 218 | + t.Run(c.name, func(t *testing.T) { |
| 219 | + // when |
| 220 | + foundPackages, err := indexer.Get(ctx, c.options) |
| 221 | + // then |
| 222 | + require.NoError(t, err, "packages should be returned") |
| 223 | + require.Len(t, foundPackages, c.expected) |
| 224 | + if c.expectedName != "" { |
| 225 | + assert.Equal(t, c.expectedName, foundPackages[0].Name) |
| 226 | + } |
| 227 | + if c.expectedVersion != "" { |
| 228 | + assert.Equal(t, c.expectedVersion, foundPackages[0].Version) |
| 229 | + } |
| 230 | + }) |
| 231 | + } |
153 | 232 | }
|
154 | 233 |
|
155 | 234 | func TestGet_IndexUpdated(t *testing.T) {
|
|
0 commit comments