mirror of
https://github.com/aquasecurity/trivy.git
synced 2025-12-22 07:10:41 -08:00
* refactor: rename Value to Default * refactor: support allowed values for CLI flags * docs: auto-generate * test: fix * test: add tests for flags
132 lines
2.6 KiB
Go
132 lines
2.6 KiB
Go
package flag_test
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/spf13/viper"
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"github.com/aquasecurity/trivy/pkg/flag"
|
|
"github.com/aquasecurity/trivy/pkg/types"
|
|
)
|
|
|
|
func TestScanFlagGroup_ToOptions(t *testing.T) {
|
|
type fields struct {
|
|
skipDirs []string
|
|
skipFiles []string
|
|
offlineScan bool
|
|
scanners string
|
|
}
|
|
tests := []struct {
|
|
name string
|
|
args []string
|
|
fields fields
|
|
want flag.ScanOptions
|
|
assertion require.ErrorAssertionFunc
|
|
}{
|
|
{
|
|
name: "happy path",
|
|
args: []string{"alpine:latest"},
|
|
fields: fields{},
|
|
want: flag.ScanOptions{
|
|
Target: "alpine:latest",
|
|
},
|
|
assertion: require.NoError,
|
|
},
|
|
{
|
|
name: "happy path for configs",
|
|
args: []string{"alpine:latest"},
|
|
fields: fields{
|
|
scanners: "config",
|
|
},
|
|
want: flag.ScanOptions{
|
|
Target: "alpine:latest",
|
|
Scanners: types.Scanners{types.MisconfigScanner},
|
|
},
|
|
assertion: require.NoError,
|
|
},
|
|
{
|
|
name: "without target (args)",
|
|
args: []string{},
|
|
fields: fields{},
|
|
want: flag.ScanOptions{},
|
|
assertion: require.NoError,
|
|
},
|
|
{
|
|
name: "with two or more targets (args)",
|
|
args: []string{
|
|
"alpine:latest",
|
|
"nginx:latest",
|
|
},
|
|
fields: fields{},
|
|
want: flag.ScanOptions{},
|
|
assertion: require.NoError,
|
|
},
|
|
{
|
|
name: "skip two files",
|
|
fields: fields{
|
|
skipFiles: []string{
|
|
"file1",
|
|
"file2",
|
|
},
|
|
},
|
|
want: flag.ScanOptions{
|
|
SkipFiles: []string{
|
|
"file1",
|
|
"file2",
|
|
},
|
|
},
|
|
assertion: require.NoError,
|
|
},
|
|
{
|
|
name: "skip two folders",
|
|
fields: fields{
|
|
skipDirs: []string{
|
|
"dir1",
|
|
"dir2",
|
|
},
|
|
},
|
|
want: flag.ScanOptions{
|
|
SkipDirs: []string{
|
|
"dir1",
|
|
"dir2",
|
|
},
|
|
},
|
|
assertion: require.NoError,
|
|
},
|
|
{
|
|
name: "offline scan",
|
|
fields: fields{
|
|
offlineScan: true,
|
|
},
|
|
want: flag.ScanOptions{
|
|
OfflineScan: true,
|
|
},
|
|
assertion: require.NoError,
|
|
},
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
viper.Set(flag.SkipDirsFlag.ConfigName, tt.fields.skipDirs)
|
|
viper.Set(flag.SkipFilesFlag.ConfigName, tt.fields.skipFiles)
|
|
viper.Set(flag.OfflineScanFlag.ConfigName, tt.fields.offlineScan)
|
|
viper.Set(flag.ScannersFlag.ConfigName, tt.fields.scanners)
|
|
|
|
// Assert options
|
|
f := &flag.ScanFlagGroup{
|
|
SkipDirs: &flag.SkipDirsFlag,
|
|
SkipFiles: &flag.SkipFilesFlag,
|
|
OfflineScan: &flag.OfflineScanFlag,
|
|
Scanners: &flag.ScannersFlag,
|
|
}
|
|
|
|
got, err := f.ToOptions(tt.args)
|
|
tt.assertion(t, err)
|
|
assert.Equalf(t, tt.want, got, "ToOptions()")
|
|
})
|
|
|
|
}
|
|
}
|