From f7855fcf8799adeb3feeca9a61e85249cfe9a498 Mon Sep 17 00:00:00 2001 From: Johnny Steenbergen Date: Thu, 27 Feb 2020 15:01:42 -0800 Subject: [PATCH] fix(pkger): fix bug where tasks are exported for notification rules --- pkger/service.go | 10 ++++++++++ pkger/service_test.go | 28 +++++++++++++++------------- 2 files changed, 25 insertions(+), 13 deletions(-) diff --git a/pkger/service.go b/pkger/service.go index 9a38a50d88b..f48258c2f2b 100644 --- a/pkger/service.go +++ b/pkger/service.go @@ -454,6 +454,13 @@ func (s *Service) cloneOrgTasks(ctx context.Context, orgID influxdb.ID) ([]Resou return nil, err } + rules, _, err := s.ruleSVC.FindNotificationRules(ctx, influxdb.NotificationRuleFilter{ + OrgID: &orgID, + }) + if err != nil { + return nil, err + } + mTeles := make(map[influxdb.ID]*influxdb.Task) for i := range teles { t := teles[i] @@ -465,6 +472,9 @@ func (s *Service) cloneOrgTasks(ctx context.Context, orgID influxdb.ID) ([]Resou for _, c := range checks { delete(mTeles, c.GetTaskID()) } + for _, r := range rules { + delete(mTeles, r.GetTaskID()) + } resources := make([]ResourceToClone, 0, len(mTeles)) for _, t := range mTeles { diff --git a/pkger/service_test.go b/pkger/service_test.go index 9c33ac43ca6..07ff05af107 100644 --- a/pkger/service_test.go +++ b/pkger/service_test.go @@ -2634,21 +2634,22 @@ func TestService(t *testing.T) { }, nil } + expectedRule := &rule.HTTP{ + Base: rule.Base{ + ID: 12, + Name: "rule_0", + EndpointID: 2, + Every: mustDuration(t, time.Minute), + StatusRules: []notification.StatusRule{{CurrentLevel: notification.Critical}}, + }, + } ruleSVC := mock.NewNotificationRuleStore() ruleSVC.FindNotificationRulesF = func(ctx context.Context, f influxdb.NotificationRuleFilter, _ ...influxdb.FindOptions) ([]influxdb.NotificationRule, int, error) { - out := []influxdb.NotificationRule{&rule.HTTP{Base: rule.Base{ID: 91}}} + out := []influxdb.NotificationRule{expectedRule} return out, len(out), nil } ruleSVC.FindNotificationRuleByIDF = func(ctx context.Context, id influxdb.ID) (influxdb.NotificationRule, error) { - return &rule.HTTP{ - Base: rule.Base{ - ID: id, - Name: "rule_0", - EndpointID: 2, - Every: mustDuration(t, time.Minute), - StatusRules: []notification.StatusRule{{CurrentLevel: notification.Critical}}, - }, - }, nil + return expectedRule, nil } labelSVC := mock.NewLabelService() @@ -2670,6 +2671,7 @@ func TestService(t *testing.T) { return []*influxdb.Task{ {ID: 31}, {ID: expectedCheck.TaskID}, // this one should be ignored in the return + {ID: expectedRule.TaskID}, // this one should be ignored in the return as well {ID: 99, Type: influxdb.TaskSystemType}, // this one should be skipped since it is a system task }, 3, nil } @@ -2722,7 +2724,7 @@ func TestService(t *testing.T) { checks := summary.Checks require.Len(t, checks, 1) - assert.Equal(t, "check_1", checks[0].Check.GetName()) + assert.Equal(t, expectedCheck.Name, checks[0].Check.GetName()) dashs := summary.Dashboards require.Len(t, dashs, 1) @@ -2738,8 +2740,8 @@ func TestService(t *testing.T) { rules := summary.NotificationRules require.Len(t, rules, 1) - assert.Equal(t, "rule_0", rules[0].Name) - assert.Equal(t, "http", rules[0].EndpointName) + assert.Equal(t, expectedRule.Name, rules[0].Name) + assert.Equal(t, expectedRule.Type(), rules[0].EndpointName) require.Len(t, summary.Tasks, 1) task1 := summary.Tasks[0]