From 1c9c676756a076ec4eb64e5de0b3f6855d415a0b Mon Sep 17 00:00:00 2001 From: "Kiss, Tibor" Date: Wed, 31 Jan 2024 10:44:10 +0100 Subject: [PATCH 1/4] Add static errors --- pkg/application/lister.go | 4 +++- pkg/cloudevents/builder/generic.go | 4 +++- pkg/cloudevents/eventtype/parse.go | 9 +++++++-- pkg/handler/handler_v1alpha1_test.go | 4 +++- pkg/nats/connect.go | 4 +++- pkg/signals/signals.go | 4 +++- 6 files changed, 22 insertions(+), 7 deletions(-) diff --git a/pkg/application/lister.go b/pkg/application/lister.go index ee1025c..7cba6ec 100644 --- a/pkg/application/lister.go +++ b/pkg/application/lister.go @@ -18,6 +18,8 @@ import ( emlogger "github.com/kyma-project/eventing-manager/pkg/logger" ) +var ErrFailedToConvertObjectToUnstructured = errors.New("failed to convert runtime object to unstructured") // Static error. + type Lister struct { lister cache.GenericLister } @@ -41,7 +43,7 @@ func (l Lister) Get(name string) (*kymaappconnv1alpha1.Application, error) { u, ok := object.(*unstructured.Unstructured) if !ok { - return nil, errors.New("failed to convert runtime object to unstructured") + return nil, ErrFailedToConvertObjectToUnstructured } a := &kymaappconnv1alpha1.Application{} diff --git a/pkg/cloudevents/builder/generic.go b/pkg/cloudevents/builder/generic.go index 1273652..d86bb87 100644 --- a/pkg/cloudevents/builder/generic.go +++ b/pkg/cloudevents/builder/generic.go @@ -12,6 +12,8 @@ import ( "github.com/kyma-project/eventing-manager/pkg/logger" ) +var ErrEventTypeCannotHaveEmptySegments = fmt.Errorf("event type cannot have empty segments after cleaning") // Static error. + // Perform a compile-time check. var _ CloudEventBuilder = &GenericBuilder{} @@ -57,7 +59,7 @@ func (gb *GenericBuilder) Build(event ceevent.Event) (*ceevent.Event, error) { // validate if the segments are not empty segments := strings.Split(finalEventType, ".") if DoesEmptySegmentsExist(segments) { - return nil, fmt.Errorf("event type cannot have empty segments after cleaning: %s", finalEventType) + return nil, fmt.Errorf("ErrEventTypeCannotHaveEmptySegments %w: %s", ErrEventTypeCannotHaveEmptySegments, finalEventType) } namedLogger.Debugf("using event type: %s", finalEventType) diff --git a/pkg/cloudevents/eventtype/parse.go b/pkg/cloudevents/eventtype/parse.go index f157efd..eb06e8c 100644 --- a/pkg/cloudevents/eventtype/parse.go +++ b/pkg/cloudevents/eventtype/parse.go @@ -8,6 +8,11 @@ import ( "github.com/kyma-project/eventing-publisher-proxy/pkg/cloudevents/builder" ) +var ( // Static errors. + ErrPrefixNotFound = errors.New("prefix not found") + ErrInvalidFormat = errors.New("invalid format") +) + // parse splits the event-type using the given prefix and returns the application name, event and version // or an error if the event-type format is invalid. // A valid even-type format should be: prefix.application.event.version or application.event.version @@ -15,7 +20,7 @@ import ( // Constraint: the application segment in the input event-type should not contain ".". func parse(eventType, prefix string) (string, string, string, error) { if !strings.HasPrefix(eventType, prefix) { - return "", "", "", errors.New("prefix not found") + return "", "", "", ErrPrefixNotFound } // remove the prefix @@ -26,7 +31,7 @@ func parse(eventType, prefix string) (string, string, string, error) { // (e.g. application.businessObject.operation.version) parts := strings.Split(eventType, ".") if len(parts) < 4 || builder.DoesEmptySegmentsExist(parts) { - return "", "", "", errors.New("invalid format") + return "", "", "", ErrInvalidFormat } // parse the event-type segments diff --git a/pkg/handler/handler_v1alpha1_test.go b/pkg/handler/handler_v1alpha1_test.go index df75f30..0067ed8 100644 --- a/pkg/handler/handler_v1alpha1_test.go +++ b/pkg/handler/handler_v1alpha1_test.go @@ -34,6 +34,8 @@ import ( emlogger "github.com/kyma-project/eventing-manager/pkg/logger" ) +var ErrUnableToClean = fmt.Errorf("unable to clean") // Static error. + func Test_extractCloudEventFromRequest(t *testing.T) { type args struct { request *http.Request @@ -253,7 +255,7 @@ func TestHandler_publishCloudEvents_v1alpha1(t *testing.T) { collector: metrics.NewCollector(latency), eventTypeCleaner: &eventtypetest.CleanerStub{ CleanType: "", - Error: fmt.Errorf("I cannot clean"), + Error: ErrUnableToClean, }, }, args: args{ diff --git a/pkg/nats/connect.go b/pkg/nats/connect.go index ba17023..40c960f 100644 --- a/pkg/nats/connect.go +++ b/pkg/nats/connect.go @@ -6,6 +6,8 @@ import ( "github.com/nats-io/nats.go" ) +var ErrNATSConnectionNotConnected = fmt.Errorf("NATS connection not connected") // Static error. + type Opt = nats.Option //nolint:gochecknoglobals // cloning functions as variables. @@ -27,7 +29,7 @@ func Connect(url string, opts ...Opt) (*nats.Conn, error) { } if status := connection.Status(); status != nats.CONNECTED { - return nil, fmt.Errorf("NATS connection not connected with status:%v", status) + return nil, fmt.Errorf("%w with status:%v", ErrNATSConnectionNotConnected, status) } return connection, err diff --git a/pkg/signals/signals.go b/pkg/signals/signals.go index dcf01e0..b182af4 100644 --- a/pkg/signals/signals.go +++ b/pkg/signals/signals.go @@ -9,6 +9,8 @@ import ( "time" ) +var ErrReceivedTerminationSignal = errors.New("received a termination signal") // Static error + //nolint:gochecknoglobals // defining channels var ( // onlyOneSignalHandler to make sure that only one signal handler is registered. @@ -70,7 +72,7 @@ func (scc *signalContext) Err() error { select { case _, ok := <-scc.Done(): if !ok { - return errors.New("received a termination signal") + return ErrReceivedTerminationSignal } default: } From 241f6a8cbe388049bf1c658344fdb41f215784f8 Mon Sep 17 00:00:00 2001 From: "Kiss, Tibor" Date: Wed, 31 Jan 2024 14:44:49 +0100 Subject: [PATCH 2/4] Linter config --- .github/workflows/lint-go.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/lint-go.yml b/.github/workflows/lint-go.yml index 41e84f6..4392454 100644 --- a/.github/workflows/lint-go.yml +++ b/.github/workflows/lint-go.yml @@ -16,4 +16,4 @@ jobs: uses: kyma-project/eventing-tools/.github/workflows/lint-go-reusable.yml@main with: go-version: '1.21' - lint-config-uri: https://raw.githubusercontent.com/kyma-project/eventing-tools/4bc0e923b67ddb0a028171d8beebc3cb4a211d69/config/lint/.golangci.yaml + lint-config-uri: https://raw.githubusercontent.com/kyma-project/eventing-tools/cf7f3aebaad2d323730a9ab2a76f6cb78f459ee4/config/lint/.golangci.yaml From 38477d231f68b45e188a88aac4d8168d98bee4e1 Mon Sep 17 00:00:00 2001 From: "Kiss, Tibor" Date: Wed, 31 Jan 2024 14:54:02 +0100 Subject: [PATCH 3/4] Fix clean message --- pkg/handler/handler_v1alpha1_test.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pkg/handler/handler_v1alpha1_test.go b/pkg/handler/handler_v1alpha1_test.go index 0067ed8..e74008e 100644 --- a/pkg/handler/handler_v1alpha1_test.go +++ b/pkg/handler/handler_v1alpha1_test.go @@ -262,7 +262,7 @@ func TestHandler_publishCloudEvents_v1alpha1(t *testing.T) { request: CreateValidBinaryRequestV1Alpha1(t), }, wantStatus: 400, - wantBody: []byte("I cannot clean"), + wantBody: []byte("unable to clean"), wantTEF: "", // client error will not be recorded as EPP internal error. So no metric will be updated. }, { From d2b3e81a8244421f271c63bd53b4e16171d5f17a Mon Sep 17 00:00:00 2001 From: "Kiss, Tibor" Date: Thu, 1 Feb 2024 12:14:41 +0100 Subject: [PATCH 4/4] Fix minor issues --- pkg/application/lister.go | 2 +- pkg/cloudevents/builder/generic.go | 4 ++-- pkg/handler/handler_v1alpha1_test.go | 2 +- pkg/nats/connect.go | 2 +- pkg/signals/signals.go | 2 +- 5 files changed, 6 insertions(+), 6 deletions(-) diff --git a/pkg/application/lister.go b/pkg/application/lister.go index 7cba6ec..bf54afe 100644 --- a/pkg/application/lister.go +++ b/pkg/application/lister.go @@ -18,7 +18,7 @@ import ( emlogger "github.com/kyma-project/eventing-manager/pkg/logger" ) -var ErrFailedToConvertObjectToUnstructured = errors.New("failed to convert runtime object to unstructured") // Static error. +var ErrFailedToConvertObjectToUnstructured = errors.New("failed to convert runtime object to unstructured") type Lister struct { lister cache.GenericLister diff --git a/pkg/cloudevents/builder/generic.go b/pkg/cloudevents/builder/generic.go index d86bb87..ea7292c 100644 --- a/pkg/cloudevents/builder/generic.go +++ b/pkg/cloudevents/builder/generic.go @@ -12,7 +12,7 @@ import ( "github.com/kyma-project/eventing-manager/pkg/logger" ) -var ErrEventTypeCannotHaveEmptySegments = fmt.Errorf("event type cannot have empty segments after cleaning") // Static error. +var ErrEventTypeCannotHaveEmptySegments = fmt.Errorf("event type cannot have empty segments after cleaning") // Perform a compile-time check. var _ CloudEventBuilder = &GenericBuilder{} @@ -59,7 +59,7 @@ func (gb *GenericBuilder) Build(event ceevent.Event) (*ceevent.Event, error) { // validate if the segments are not empty segments := strings.Split(finalEventType, ".") if DoesEmptySegmentsExist(segments) { - return nil, fmt.Errorf("ErrEventTypeCannotHaveEmptySegments %w: %s", ErrEventTypeCannotHaveEmptySegments, finalEventType) + return nil, fmt.Errorf("%w: %s", ErrEventTypeCannotHaveEmptySegments, finalEventType) } namedLogger.Debugf("using event type: %s", finalEventType) diff --git a/pkg/handler/handler_v1alpha1_test.go b/pkg/handler/handler_v1alpha1_test.go index e74008e..a6a356e 100644 --- a/pkg/handler/handler_v1alpha1_test.go +++ b/pkg/handler/handler_v1alpha1_test.go @@ -34,7 +34,7 @@ import ( emlogger "github.com/kyma-project/eventing-manager/pkg/logger" ) -var ErrUnableToClean = fmt.Errorf("unable to clean") // Static error. +var ErrUnableToClean = fmt.Errorf("unable to clean") func Test_extractCloudEventFromRequest(t *testing.T) { type args struct { diff --git a/pkg/nats/connect.go b/pkg/nats/connect.go index 40c960f..0d9a3b7 100644 --- a/pkg/nats/connect.go +++ b/pkg/nats/connect.go @@ -6,7 +6,7 @@ import ( "github.com/nats-io/nats.go" ) -var ErrNATSConnectionNotConnected = fmt.Errorf("NATS connection not connected") // Static error. +var ErrNATSConnectionNotConnected = fmt.Errorf("NATS connection not connected") type Opt = nats.Option diff --git a/pkg/signals/signals.go b/pkg/signals/signals.go index b182af4..5d742fc 100644 --- a/pkg/signals/signals.go +++ b/pkg/signals/signals.go @@ -9,7 +9,7 @@ import ( "time" ) -var ErrReceivedTerminationSignal = errors.New("received a termination signal") // Static error +var ErrReceivedTerminationSignal = errors.New("received a termination signal") //nolint:gochecknoglobals // defining channels var (