1
0
mirror of https://github.com/goreleaser/goreleaser.git synced 2025-01-10 03:47:03 +02:00
goreleaser/cmd/check.go
Carlos Alexandro Becker da380cc9a7
fix: improve check/load config logs
Signed-off-by: Carlos Alexandro Becker <caarlos0@users.noreply.github.com>
2023-08-18 21:47:18 +00:00

105 lines
2.6 KiB
Go

package cmd
import (
"fmt"
"io"
"os"
"github.com/caarlos0/ctrlc"
"github.com/caarlos0/log"
"github.com/goreleaser/goreleaser/internal/pipe/defaults"
"github.com/goreleaser/goreleaser/pkg/context"
"github.com/spf13/cobra"
)
type checkCmd struct {
cmd *cobra.Command
config string
quiet bool
deprecated bool
checked int
}
func newCheckCmd() *checkCmd {
root := &checkCmd{}
cmd := &cobra.Command{
Use: "check [configuration files]",
Aliases: []string{"c"},
Short: "Checks if configuration is valid",
SilenceUsage: true,
SilenceErrors: true,
Args: cobra.ArbitraryArgs,
RunE: func(_ *cobra.Command, args []string) error {
if root.quiet {
log.Log = log.New(io.Discard)
}
var errs []*exitError
if root.config != "" || len(args) == 0 {
args = append(args, root.config)
}
for _, config := range args {
cfg, path, err := loadConfigCheck(config)
if err != nil {
return err
}
ctx := context.New(cfg)
ctx.Deprecated = root.deprecated
if err := ctrlc.Default.Run(ctx, func() error {
log.WithField("path", config).
Info(boldStyle.Render("checking"))
return defaults.Pipe{}.Run(ctx)
}); err != nil {
log.WithError(err).Error(boldStyle.Render("configuration is invalid"))
errs = append(errs, wrapErrorWithCode(
fmt.Errorf("configuration is invalid: %w", err),
1,
path,
))
}
if ctx.Deprecated {
errs = append(errs, wrapErrorWithCode(
fmt.Errorf("configuration is valid, but uses deprecated properties"),
2,
path,
))
}
}
root.checked = len(args)
exit := 0
for _, err := range errs {
if err.code < exit || exit == 0 {
exit = err.code
}
log.Log = log.New(os.Stderr)
if err.code == 1 {
log.WithError(err.err).Error(err.details)
} else {
log.WithError(err.err).Warn(err.details)
}
}
if exit > 0 {
return wrapErrorWithCode(fmt.Errorf("%d out of %d configuration file(s) have issues", len(errs), len(args)), exit, "")
}
log.Info(boldStyle.Render(fmt.Sprintf("%d configuration file(s) validated", len(args))))
return nil
},
}
cmd.Flags().StringVarP(&root.config, "config", "f", "", "Configuration file(s) to check")
_ = cmd.MarkFlagFilename("config", "yaml", "yml")
cmd.Flags().BoolVarP(&root.quiet, "quiet", "q", false, "Quiet mode: no output")
cmd.Flags().BoolVar(&root.deprecated, "deprecated", false, "Force print the deprecation message - tests only")
_ = cmd.Flags().MarkHidden("deprecated")
_ = cmd.Flags().MarkHidden("config")
root.cmd = cmd
return root
}