package cmd import ( "fmt" "log" "github.com/spf13/cobra" "github.com/spf13/viper" "github.com/aws/eks-anywhere/pkg/logger" ) var rootCmd = &cobra.Command{ Use: "eks-a-test-tool", Short: "Amazon EKS Anywhere Test Tooling", Long: `Use eks-a-test-tool to evaluate EKS-A test results`, PersistentPreRun: rootPersistentPreRun, } func init() { rootCmd.PersistentFlags().IntP("verbosity", "v", 0, "Set the log level verbosity") if err := viper.BindPFlags(rootCmd.PersistentFlags()); err != nil { log.Fatalf("failed to bind flags for root: %v", err) } } func rootPersistentPreRun(cmd *cobra.Command, args []string) { if err := initLogger(); err != nil { log.Fatal(err) } } func initLogger() error { if err := logger.InitZap(logger.ZapOpts{ Level: viper.GetInt("verbosity"), }); err != nil { return fmt.Errorf("failed init zap logger in root command: %v", err) } return nil } func Execute() error { return rootCmd.Execute() }