1
0
mirror of https://github.com/goreleaser/goreleaser.git synced 2025-01-24 04:16:27 +02:00
goreleaser/cmd/check.go
Hugo Hromic bf79c2cf91
fix: use correct path variable for logging in check command (#4756)
This trivial PR fixes a minor cosmetic issue in the `check` command.

Before this fix, GoReleaser would not show the auto-detected config path
under check when no args are provided:
```
$ goreleaser check
  • checking                                 path=
  • 1 configuration file(s) validated
  • thanks for using goreleaser!
```

After this check, GoReleaser correctly shows any auto-detected config
paths:
```
$ goreleaser check
  • checking                                 path=.goreleaser.yaml
  • 1 configuration file(s) validated
  • thanks for using goreleaser!
```
2024-04-04 09:32:05 -03: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", path).
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
}