From f17fef34b21b2c8bccacaf41814b0ad75f8b0d2d Mon Sep 17 00:00:00 2001 From: Thomas <73077675+tmzane@users.noreply.github.com> Date: Sun, 5 Nov 2023 15:09:59 +0300 Subject: [PATCH] build(deps): bump go-simpler.org/sloglint from 0.1.2 to 0.2.0 (#4166) --- .golangci.reference.yml | 7 ++++++ go.mod | 2 +- go.sum | 2 ++ pkg/config/linters_settings.go | 12 ++++++---- pkg/golinters/sloglint.go | 2 ++ .../configs/sloglint_context_only.yml | 3 +++ .../configs/sloglint_key_naming_case.yml | 3 +++ test/testdata/sloglint_context_only.go | 16 +++++++++++++ test/testdata/sloglint_key_naming_case.go | 24 +++++++++++++++++++ 9 files changed, 66 insertions(+), 5 deletions(-) create mode 100644 test/testdata/configs/sloglint_context_only.yml create mode 100644 test/testdata/configs/sloglint_key_naming_case.yml create mode 100644 test/testdata/sloglint_context_only.go create mode 100644 test/testdata/sloglint_key_naming_case.go diff --git a/.golangci.reference.yml b/.golangci.reference.yml index 02546f7c4834..1deb3e4a1ebd 100644 --- a/.golangci.reference.yml +++ b/.golangci.reference.yml @@ -1824,9 +1824,16 @@ linters-settings: # Enforce using attributes only (incompatible with kv-only). # Default: false attr-only: true + # Enforce using methods that accept a context. + # Default: false + context-only: true # Enforce using constants instead of raw keys. # Default: false no-raw-keys: true + # Enforce a single key naming convention. + # Values: snake, kebab, camel, pascal + # Default: "" + key-naming-case: snake # Enforce putting arguments on separate lines. # Default: false args-on-sep-lines: true diff --git a/go.mod b/go.mod index 96c24e8bf578..fb49f7015cb2 100644 --- a/go.mod +++ b/go.mod @@ -120,7 +120,7 @@ require ( github.com/yeya24/promlinter v0.2.0 github.com/ykadowak/zerologlint v0.1.3 gitlab.com/bosi/decorder v0.4.1 - go-simpler.org/sloglint v0.1.2 + go-simpler.org/sloglint v0.2.0 go.tmz.dev/musttag v0.7.2 golang.org/x/exp v0.0.0-20230510235704-dd950f8aeaea golang.org/x/tools v0.14.0 diff --git a/go.sum b/go.sum index 838e7c10bafd..2e954b4dc4b1 100644 --- a/go.sum +++ b/go.sum @@ -592,6 +592,8 @@ gitlab.com/bosi/decorder v0.4.1/go.mod h1:jecSqWUew6Yle1pCr2eLWTensJMmsxHsBwt+PV go-simpler.org/assert v0.6.0 h1:QxSrXa4oRuo/1eHMXSBFHKvJIpWABayzKldqZyugG7E= go-simpler.org/sloglint v0.1.2 h1:IjdhF8NPxyn0Ckn2+fuIof7ntSnVUAqBFcQRrnG9AiM= go-simpler.org/sloglint v0.1.2/go.mod h1:2LL+QImPfTslD5muNPydAEYmpXIj6o/WYcqnJjLi4o4= +go-simpler.org/sloglint v0.2.0 h1:XpOhA+7BCQJnl7KlDLmnFUFTSrl989ZmaVPSWWCWEtc= +go-simpler.org/sloglint v0.2.0/go.mod h1:/RQr0TeTf89IyRjLJ9ogUbIp1Zs5zJJAj02pwQoDQdg= go.opencensus.io v0.21.0/go.mod h1:mSImk1erAIZhrmZN+AvHh14ztQfjbGwt4TtuofqLduU= go.opencensus.io v0.22.0/go.mod h1:+kGneAE2xo2IficOXnaByMWTGM9T73dGwxeWcUqIpI8= go.opencensus.io v0.22.2/go.mod h1:yxeiOL68Rb0Xd1ddK5vPZ/oVn4vY4Ynel7k9FzqtOIw= diff --git a/pkg/config/linters_settings.go b/pkg/config/linters_settings.go index 54807c6b732a..86ff861d7cf8 100644 --- a/pkg/config/linters_settings.go +++ b/pkg/config/linters_settings.go @@ -119,7 +119,9 @@ var defaultLintersSettings = LintersSettings{ SlogLint: SlogLintSettings{ KVOnly: false, AttrOnly: false, + ContextOnly: false, NoRawKeys: false, + KeyNamingCase: "", ArgsOnSepLines: false, }, TagAlign: TagAlignSettings{ @@ -734,10 +736,12 @@ type RowsErrCheckSettings struct { } type SlogLintSettings struct { - KVOnly bool `mapstructure:"kv-only"` - AttrOnly bool `mapstructure:"attr-only"` - NoRawKeys bool `mapstructure:"no-raw-keys"` - ArgsOnSepLines bool `mapstructure:"args-on-sep-lines"` + KVOnly bool `mapstructure:"kv-only"` + AttrOnly bool `mapstructure:"attr-only"` + ContextOnly bool `mapstructure:"context-only"` + NoRawKeys bool `mapstructure:"no-raw-keys"` + KeyNamingCase string `mapstructure:"key-naming-case"` + ArgsOnSepLines bool `mapstructure:"args-on-sep-lines"` } type StaticCheckSettings struct { diff --git a/pkg/golinters/sloglint.go b/pkg/golinters/sloglint.go index b506d187fd18..98fa00523586 100644 --- a/pkg/golinters/sloglint.go +++ b/pkg/golinters/sloglint.go @@ -14,7 +14,9 @@ func NewSlogLint(settings *config.SlogLintSettings) *goanalysis.Linter { opts = &sloglint.Options{ KVOnly: settings.KVOnly, AttrOnly: settings.AttrOnly, + ContextOnly: settings.ContextOnly, NoRawKeys: settings.NoRawKeys, + KeyNamingCase: settings.KeyNamingCase, ArgsOnSepLines: settings.ArgsOnSepLines, } } diff --git a/test/testdata/configs/sloglint_context_only.yml b/test/testdata/configs/sloglint_context_only.yml new file mode 100644 index 000000000000..a15bbe49680a --- /dev/null +++ b/test/testdata/configs/sloglint_context_only.yml @@ -0,0 +1,3 @@ +linters-settings: + sloglint: + context-only: true diff --git a/test/testdata/configs/sloglint_key_naming_case.yml b/test/testdata/configs/sloglint_key_naming_case.yml new file mode 100644 index 000000000000..653d8c0b480d --- /dev/null +++ b/test/testdata/configs/sloglint_key_naming_case.yml @@ -0,0 +1,3 @@ +linters-settings: + sloglint: + key-naming-case: snake diff --git a/test/testdata/sloglint_context_only.go b/test/testdata/sloglint_context_only.go new file mode 100644 index 000000000000..78f39e373432 --- /dev/null +++ b/test/testdata/sloglint_context_only.go @@ -0,0 +1,16 @@ +//go:build go1.21 + +//golangcitest:args -Esloglint +//golangcitest:config_path testdata/configs/sloglint_context_only.yml +package testdata + +import ( + "context" + "log/slog" +) + +func test() { + slog.InfoContext(context.Background(), "msg") + + slog.Info("msg") // want `methods without a context should not be used` +} diff --git a/test/testdata/sloglint_key_naming_case.go b/test/testdata/sloglint_key_naming_case.go new file mode 100644 index 000000000000..d278cd974c80 --- /dev/null +++ b/test/testdata/sloglint_key_naming_case.go @@ -0,0 +1,24 @@ +//go:build go1.21 + +//golangcitest:args -Esloglint +//golangcitest:config_path testdata/configs/sloglint_key_naming_case.yml +package testdata + +import "log/slog" + +const ( + snakeKey = "foo_bar" + kebabKey = "foo-bar" +) + +func test() { + slog.Info("msg", "foo_bar", 1) + slog.Info("msg", snakeKey, 1) + slog.Info("msg", slog.Int("foo_bar", 1)) + slog.Info("msg", slog.Int(snakeKey, 1)) + + slog.Info("msg", "foo-bar", 1) // want `keys should be written in snake_case` + slog.Info("msg", kebabKey, 1) // want `keys should be written in snake_case` + slog.Info("msg", slog.Int("foo-bar", 1)) // want `keys should be written in snake_case` + slog.Info("msg", slog.Int(kebabKey, 1)) // want `keys should be written in snake_case` +}