From 682b55efd67a0e348990c2a00e03e7615237651f Mon Sep 17 00:00:00 2001 From: Spencer Schrock Date: Wed, 4 Oct 2023 12:16:30 -0700 Subject: [PATCH 1/2] accept checks arg when generating golden. Signed-off-by: Spencer Schrock --- cmd/internal/scdiff/app/generate.go | 6 ++++- cmd/internal/scdiff/app/runner/runner.go | 23 +++++++++++++++++-- cmd/internal/scdiff/app/runner/runner_test.go | 7 +++++- 3 files changed, 32 insertions(+), 4 deletions(-) diff --git a/cmd/internal/scdiff/app/generate.go b/cmd/internal/scdiff/app/generate.go index 3cf29acd8ac..605bc25e4ac 100644 --- a/cmd/internal/scdiff/app/generate.go +++ b/cmd/internal/scdiff/app/generate.go @@ -19,6 +19,7 @@ import ( "fmt" "io" "os" + "strings" "github.com/spf13/cobra" @@ -32,11 +33,13 @@ func init() { rootCmd.AddCommand(generateCmd) generateCmd.PersistentFlags().StringVarP(&repoFile, "repos", "r", "", "path to newline-delimited repo file") generateCmd.PersistentFlags().StringVarP(&outputFile, "output", "o", "", "write to file instead of stdout") + generateCmd.PersistentFlags().StringVar(&checks, "checks", "", "Comma separated list of checks to run") } var ( repoFile string outputFile string + checks string generateCmd = &cobra.Command{ Use: "generate [flags] repofile", @@ -57,7 +60,8 @@ var ( defer outputF.Close() output = outputF } - r := runner.New() + checks := strings.Split(checks, ",") + r := runner.New(checks) return generate(&r, input, output) }, } diff --git a/cmd/internal/scdiff/app/runner/runner.go b/cmd/internal/scdiff/app/runner/runner.go index 4a65e1f7a51..fa9a93b2dbf 100644 --- a/cmd/internal/scdiff/app/runner/runner.go +++ b/cmd/internal/scdiff/app/runner/runner.go @@ -16,6 +16,7 @@ package runner import ( "context" + "strings" "github.com/ossf/scorecard/v4/checker" "github.com/ossf/scorecard/v4/checks" @@ -42,7 +43,8 @@ type Runner struct { vuln clients.VulnerabilitiesClient } -func New() Runner { +// Creates a Runner which will run the listed checks. If no checks are provided, all will run. +func New(checks []string) Runner { ctx := context.Background() logger := log.NewLogger(log.DefaultLevel) return Runner{ @@ -52,7 +54,7 @@ func New() Runner { ossFuzz: ossfuzz.CreateOSSFuzzClient(ossfuzz.StatusURL), cii: clients.DefaultCIIBestPracticesClient(), vuln: clients.DefaultVulnerabilitiesClient(), - enabledChecks: checks.GetAll(), + enabledChecks: parseChecks(checks), } } @@ -73,3 +75,20 @@ func (r *Runner) log(msg string) { r.logger.Info(msg) } } + +func parseChecks(c []string) checker.CheckNameToFnMap { + all := checks.GetAll() + if len(c) == 0 { + return all + } + + ret := checker.CheckNameToFnMap{} + for _, requested := range c { + for key, fn := range all { + if strings.EqualFold(key, requested) { + ret[key] = fn + } + } + } + return ret +} diff --git a/cmd/internal/scdiff/app/runner/runner_test.go b/cmd/internal/scdiff/app/runner/runner_test.go index 8d44ce10345..1b4c05e3c4a 100644 --- a/cmd/internal/scdiff/app/runner/runner_test.go +++ b/cmd/internal/scdiff/app/runner/runner_test.go @@ -25,10 +25,15 @@ import ( ) func TestNew(t *testing.T) { - r := New() + r := New(nil) if len(r.enabledChecks) == 0 { t.Errorf("runner has no checks to run: %v", r.enabledChecks) } + requestedChecks := []string{"Code-Review"} + r = New(requestedChecks) + if len(r.enabledChecks) != len(requestedChecks) { + t.Errorf("requested %d checks but only got: %v", len(requestedChecks), r.enabledChecks) + } } func TestRunner_Run(t *testing.T) { From 0af6e078115d85b0223804d9a90ff3ee754dc443 Mon Sep 17 00:00:00 2001 From: Spencer Schrock Date: Wed, 4 Oct 2023 13:25:17 -0700 Subject: [PATCH 2/2] dont shadow import Signed-off-by: Spencer Schrock --- cmd/internal/scdiff/app/generate.go | 6 +++--- cmd/internal/scdiff/app/runner/runner.go | 4 ++-- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/cmd/internal/scdiff/app/generate.go b/cmd/internal/scdiff/app/generate.go index 605bc25e4ac..d3a6399a3fa 100644 --- a/cmd/internal/scdiff/app/generate.go +++ b/cmd/internal/scdiff/app/generate.go @@ -33,13 +33,13 @@ func init() { rootCmd.AddCommand(generateCmd) generateCmd.PersistentFlags().StringVarP(&repoFile, "repos", "r", "", "path to newline-delimited repo file") generateCmd.PersistentFlags().StringVarP(&outputFile, "output", "o", "", "write to file instead of stdout") - generateCmd.PersistentFlags().StringVar(&checks, "checks", "", "Comma separated list of checks to run") + generateCmd.PersistentFlags().StringVar(&checksArg, "checks", "", "Comma separated list of checks to run") } var ( repoFile string outputFile string - checks string + checksArg string generateCmd = &cobra.Command{ Use: "generate [flags] repofile", @@ -60,7 +60,7 @@ var ( defer outputF.Close() output = outputF } - checks := strings.Split(checks, ",") + checks := strings.Split(checksArg, ",") r := runner.New(checks) return generate(&r, input, output) }, diff --git a/cmd/internal/scdiff/app/runner/runner.go b/cmd/internal/scdiff/app/runner/runner.go index fa9a93b2dbf..535bc7a84f2 100644 --- a/cmd/internal/scdiff/app/runner/runner.go +++ b/cmd/internal/scdiff/app/runner/runner.go @@ -44,7 +44,7 @@ type Runner struct { } // Creates a Runner which will run the listed checks. If no checks are provided, all will run. -func New(checks []string) Runner { +func New(enabledChecks []string) Runner { ctx := context.Background() logger := log.NewLogger(log.DefaultLevel) return Runner{ @@ -54,7 +54,7 @@ func New(checks []string) Runner { ossFuzz: ossfuzz.CreateOSSFuzzClient(ossfuzz.StatusURL), cii: clients.DefaultCIIBestPracticesClient(), vuln: clients.DefaultVulnerabilitiesClient(), - enabledChecks: parseChecks(checks), + enabledChecks: parseChecks(enabledChecks), } }