vuln-list-update/alpine/alpine_test.go
DmitriyLewen f1f4c3e8e6
refactor(nvd): use API instead of JSON feeds (#258)
Signed-off-by: knqyf263 <knqyf263@gmail.com>
Co-authored-by: knqyf263 <knqyf263@gmail.com>
2023-12-18 20:34:54 +04:00

135 lines
3.3 KiB
Go

package alpine_test
import (
"flag"
"net/http"
"net/http/httptest"
"net/url"
"os"
"testing"
"github.com/spf13/afero"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
"github.com/aquasecurity/vuln-list-update/alpine"
)
var update = flag.Bool("update", false, "update golden files")
func TestUpdater_Update(t *testing.T) {
type fields struct {
appFs afero.Fs
retry int
}
tests := []struct {
name string
fields fields
fileNames map[string]string
goldenFiles map[string]string
wantErr string
}{
{
name: "happy path",
fields: fields{
appFs: afero.NewMemMapFs(),
retry: 0,
},
fileNames: map[string]string{
"/": "testdata/index.html",
"/v3.11": "testdata/311.html",
"/v3.12": "testdata/312.html",
"/edge": "testdata/edge.html",
"/v3.11/main.json": "testdata/311-main.json",
"/v3.11/community.json": "testdata/311-community.json",
"/v3.12/main.json": "testdata/312-main.json",
"/v3.12/community.json": "testdata/312-community.json",
"/edge/main.json": "testdata/edge-main.json",
"/edge/community.json": "testdata/edge-community.json",
},
goldenFiles: map[string]string{
"/tmp/alpine/3.11/main/apache2.json": "testdata/golden/311-apache2.json",
"/tmp/alpine/3.12/main/ansible.json": "testdata/golden/312-ansible.json",
"/tmp/alpine/edge/main/apk-tools.json": "testdata/golden/edge-apk-tools.json",
},
},
{
name: "no release",
fields: fields{
appFs: afero.NewMemMapFs(),
retry: 0,
},
fileNames: map[string]string{
"/": "testdata/norelease.html",
},
},
{
name: "404",
fields: fields{
appFs: afero.NewMemMapFs(),
retry: 0,
},
fileNames: map[string]string{
"/": "testdata/index.html",
},
wantErr: "status code: 404",
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
ts := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
fileName, ok := tt.fileNames[r.URL.Path]
if !ok {
http.NotFound(w, r)
return
}
http.ServeFile(w, r, fileName)
}))
defer ts.Close()
baseURL, err := url.Parse(ts.URL)
require.NoError(t, err)
u := alpine.NewUpdater(alpine.WithVulnListDir("/tmp"), alpine.WithBaseURL(baseURL),
alpine.WithAppFs(tt.fields.appFs), alpine.WithRetry(tt.fields.retry))
err = u.Update()
if tt.wantErr != "" {
require.NotNil(t, err)
assert.Contains(t, err.Error(), tt.wantErr)
return
} else {
assert.NoError(t, err)
}
fileCount := 0
err = afero.Walk(tt.fields.appFs, "/", func(path string, info os.FileInfo, err error) error {
if err != nil {
return err
}
if info.IsDir() {
return nil
}
fileCount++
actual, err := afero.ReadFile(tt.fields.appFs, path)
assert.NoError(t, err, path)
goldenPath, ok := tt.goldenFiles[path]
require.True(t, ok, path)
if *update {
err = os.WriteFile(goldenPath, actual, 0666)
require.NoError(t, err, goldenPath)
}
expected, err := os.ReadFile(goldenPath)
assert.NoError(t, err, goldenPath)
assert.JSONEq(t, string(expected), string(actual), path)
return nil
})
assert.Equal(t, len(tt.goldenFiles), fileCount)
assert.NoError(t, err)
})
}
}