From 7f709518212db5fb34310ef3894ecddcc6e0f76d Mon Sep 17 00:00:00 2001 From: mirii1994 Date: Thu, 4 May 2023 12:34:47 +0300 Subject: [PATCH 01/24] init - grafana alerts --- grafana_alerts/client_grafana_alert.go | 41 ++++++++++++++++++++++++++ 1 file changed, 41 insertions(+) create mode 100644 grafana_alerts/client_grafana_alert.go diff --git a/grafana_alerts/client_grafana_alert.go b/grafana_alerts/client_grafana_alert.go new file mode 100644 index 0000000..8014776 --- /dev/null +++ b/grafana_alerts/client_grafana_alert.go @@ -0,0 +1,41 @@ +package grafana_alerts + +import ( + "github.com/logzio/logzio_terraform_client/client" + "time" +) + +const ( + grafanaObjectServiceEndpoint = "%s/v1/grafana/api/v1/provisioning/alert-rules" +) + +type GrafanaAlertsClient struct { + *client.Client +} + +type AlertRule struct { + Annotations map[string]string `json:"annotations,omitempty"` + Condition string `json:"condition"` // Required + Data []*AlertQuery `json:"data"` // Required + ExecErrState string `json:"execErrState"` // Required + FolderUID string `json:"folderUID"` // Required + For string `json:"for"` // Required + Id int64 `json:"id,omitempty"` + Labels map[string]string `json:"labels,omitempty"` + NoDataState string `json:"noDataState"` // Required + OrgID int64 `json:"orgID"` // Required + Provenance ProvenanceObj `json:"provenance"` +} + +type AlertQuery struct { + DatasourceUid string `json:"datasourceUid"` + Model interface{} `json:"model"` + QueryType string `json:"queryType"` + RefId string `json:"refId"` + RelativeTimeRange RelativeTimeRangeObj `json:"relativeTimeRange"` +} + +type RelativeTimeRangeObj struct { + From time.Duration `json:"from"` + To time.Duration `json:"to"` +} From d527a8541dd137e4ae3105d667ff0722bea67432 Mon Sep 17 00:00:00 2001 From: mirii1994 Date: Sun, 14 May 2023 17:44:29 +0300 Subject: [PATCH 02/24] grafana alert client --- grafana_alerts/client_grafana_alert.go | 32 ++++++++++++++++++++++++-- 1 file changed, 30 insertions(+), 2 deletions(-) diff --git a/grafana_alerts/client_grafana_alert.go b/grafana_alerts/client_grafana_alert.go index 8014776..8035be1 100644 --- a/grafana_alerts/client_grafana_alert.go +++ b/grafana_alerts/client_grafana_alert.go @@ -1,15 +1,24 @@ package grafana_alerts import ( + "fmt" "github.com/logzio/logzio_terraform_client/client" "time" ) const ( grafanaObjectServiceEndpoint = "%s/v1/grafana/api/v1/provisioning/alert-rules" + + grafanaAlertResourceName = "grafana alert" + + operationCreateGrafanaAlert = "CreateGrafanaAlert" + operationGetGrafanaAlert = "GetGrafanaAlert" + operationUpdateGrafanaAlert = "UpdateGrafanaAlert" + operationDeleteGrafanaAlert = "DeleteGrafanaAlert" + operationListGrafanaAlerts = "ListGrafanaAlerts" ) -type GrafanaAlertsClient struct { +type GrafanaAlertClient struct { *client.Client } @@ -24,7 +33,11 @@ type AlertRule struct { Labels map[string]string `json:"labels,omitempty"` NoDataState string `json:"noDataState"` // Required OrgID int64 `json:"orgID"` // Required - Provenance ProvenanceObj `json:"provenance"` + Provenance string `json:"provenance,omitempty"` + RuleGroup string `json:"ruleGroup"` // Required + Title string `json:"title"` // Required + Uid string `json:"uid,omitempty"` + Updated time.Time `json:"updated"` } type AlertQuery struct { @@ -39,3 +52,18 @@ type RelativeTimeRangeObj struct { From time.Duration `json:"from"` To time.Duration `json:"to"` } + +func New(apiToken string, baseUrl string) (*GrafanaAlertClient, error) { + if len(apiToken) == 0 { + return nil, fmt.Errorf("API token not defined") + } + if len(baseUrl) == 0 { + return nil, fmt.Errorf("Base URL not defined") + } + + grafanaAlertClient := &GrafanaAlertClient{ + Client: client.New(apiToken, baseUrl), + } + + return grafanaAlertClient, nil +} From 6ac3c0b071f8ef693b366080a7deba3cd83ead17 Mon Sep 17 00:00:00 2001 From: mirii1994 Date: Sun, 14 May 2023 17:45:57 +0300 Subject: [PATCH 03/24] fix typo --- grafana_alerts/client_grafana_alert.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/grafana_alerts/client_grafana_alert.go b/grafana_alerts/client_grafana_alert.go index 8035be1..9d94f0c 100644 --- a/grafana_alerts/client_grafana_alert.go +++ b/grafana_alerts/client_grafana_alert.go @@ -7,7 +7,7 @@ import ( ) const ( - grafanaObjectServiceEndpoint = "%s/v1/grafana/api/v1/provisioning/alert-rules" + grafanaAlertServiceEndpoint = "%s/v1/grafana/api/v1/provisioning/alert-rules" grafanaAlertResourceName = "grafana alert" From 4a1ac6d06d34dc5359887f13e97527aa0544f00f Mon Sep 17 00:00:00 2001 From: mirii1994 Date: Sun, 14 May 2023 18:09:37 +0300 Subject: [PATCH 04/24] rename --- grafana_alerts/client_grafana_alert.go | 34 +++++++++++++------------- 1 file changed, 17 insertions(+), 17 deletions(-) diff --git a/grafana_alerts/client_grafana_alert.go b/grafana_alerts/client_grafana_alert.go index 9d94f0c..b0c2f22 100644 --- a/grafana_alerts/client_grafana_alert.go +++ b/grafana_alerts/client_grafana_alert.go @@ -22,25 +22,25 @@ type GrafanaAlertClient struct { *client.Client } -type AlertRule struct { - Annotations map[string]string `json:"annotations,omitempty"` - Condition string `json:"condition"` // Required - Data []*AlertQuery `json:"data"` // Required - ExecErrState string `json:"execErrState"` // Required - FolderUID string `json:"folderUID"` // Required - For string `json:"for"` // Required - Id int64 `json:"id,omitempty"` - Labels map[string]string `json:"labels,omitempty"` - NoDataState string `json:"noDataState"` // Required - OrgID int64 `json:"orgID"` // Required - Provenance string `json:"provenance,omitempty"` - RuleGroup string `json:"ruleGroup"` // Required - Title string `json:"title"` // Required - Uid string `json:"uid,omitempty"` - Updated time.Time `json:"updated"` +type GrafanaAlertRule struct { + Annotations map[string]string `json:"annotations,omitempty"` + Condition string `json:"condition"` // Required + Data []*GrafanaAlertQuery `json:"data"` // Required + ExecErrState string `json:"execErrState"` // Required + FolderUID string `json:"folderUID"` // Required + For string `json:"for"` // Required + Id int64 `json:"id,omitempty"` + Labels map[string]string `json:"labels,omitempty"` + NoDataState string `json:"noDataState"` // Required + OrgID int64 `json:"orgID"` // Required + Provenance string `json:"provenance,omitempty"` + RuleGroup string `json:"ruleGroup"` // Required + Title string `json:"title"` // Required + Uid string `json:"uid,omitempty"` + Updated time.Time `json:"updated"` } -type AlertQuery struct { +type GrafanaAlertQuery struct { DatasourceUid string `json:"datasourceUid"` Model interface{} `json:"model"` QueryType string `json:"queryType"` From da94332fbfba92ab6f829fc7408af9ef646d8d72 Mon Sep 17 00:00:00 2001 From: mirii1994 Date: Sun, 14 May 2023 18:20:03 +0300 Subject: [PATCH 05/24] create, delete --- grafana_alerts/client_grafana_alert_create.go | 91 +++++++++++++++++++ grafana_alerts/client_grafana_alert_delete.go | 30 ++++++ 2 files changed, 121 insertions(+) create mode 100644 grafana_alerts/client_grafana_alert_create.go create mode 100644 grafana_alerts/client_grafana_alert_delete.go diff --git a/grafana_alerts/client_grafana_alert_create.go b/grafana_alerts/client_grafana_alert_create.go new file mode 100644 index 0000000..aea010e --- /dev/null +++ b/grafana_alerts/client_grafana_alert_create.go @@ -0,0 +1,91 @@ +package grafana_alerts + +import ( + "encoding/json" + "fmt" + logzio_client "github.com/logzio/logzio_terraform_client" + "net/http" +) + +const ( + createGrafanaAlertServiceUrl = grafanaAlertServiceEndpoint + createGrafanaAlertServiceMethod = http.MethodPost + createGrafanaAlertMethodCreated = http.StatusCreated + createGrafanaAlertStatusNotFound = http.StatusNotFound +) + +func (c *GrafanaAlertClient) CreateGrafanaAlertRule(payload GrafanaAlertRule) (*GrafanaAlertRule, error) { + err := validateCreateGrafanaAlertRule(payload) + if err != nil { + return nil, err + } + + createGrafanaAlertRuleJson, err := json.Marshal(payload) + if err != nil { + return nil, err + } + + res, err := logzio_client.CallLogzioApi(logzio_client.LogzioApiCallDetails{ + ApiToken: c.ApiToken, + HttpMethod: createGrafanaAlertServiceMethod, + Url: fmt.Sprintf(createGrafanaAlertServiceUrl, c.BaseUrl), + Body: createGrafanaAlertRuleJson, + SuccessCodes: []int{createGrafanaAlertMethodCreated}, + NotFoundCode: createGrafanaAlertStatusNotFound, + ResourceId: nil, + ApiAction: operationCreateGrafanaAlert, + ResourceName: grafanaAlertResourceName, + }) + + if err != nil { + return nil, err + } + + var retVal GrafanaAlertRule + err = json.Unmarshal(res, &retVal) + if err != nil { + return nil, err + } + + return &retVal, nil +} + +func validateCreateGrafanaAlertRule(payload GrafanaAlertRule) error { + if len(payload.Condition) == 0 { + return fmt.Errorf("Field condition must be set!") + } + + if payload.Data == nil { + return fmt.Errorf("Field data must be set!") + } + + if len(payload.ExecErrState) == 0 { + return fmt.Errorf("Field execErrState must be set!") + } + + if len(payload.FolderUID) == 0 { + return fmt.Errorf("Field folderUID must be set!") + } + + if len(payload.For) == 0 { + return fmt.Errorf("Field for must be set!") + } + + if len(payload.NoDataState) == 0 { + return fmt.Errorf("Field noDataState must be set!") + } + + if payload.OrgID == 0 { + return fmt.Errorf("Field orgID must be set!") + } + + if len(payload.RuleGroup) == 0 { + return fmt.Errorf("Field ruleGroup must be set!") + } + + if len(payload.Title) == 0 { + return fmt.Errorf("Field title must be set!") + } + + return nil +} diff --git a/grafana_alerts/client_grafana_alert_delete.go b/grafana_alerts/client_grafana_alert_delete.go new file mode 100644 index 0000000..8fc67bc --- /dev/null +++ b/grafana_alerts/client_grafana_alert_delete.go @@ -0,0 +1,30 @@ +package grafana_alerts + +import ( + "fmt" + logzio_client "github.com/logzio/logzio_terraform_client" + "net/http" +) + +const ( + deleteGrafanaAlertServiceUrl = grafanaAlertServiceEndpoint + "/%s" + deleteGrafanaAlertServiceMethod = http.MethodDelete + deleteGrafanaAlertServiceSuccess = http.StatusNoContent + deleteGrafanaAlertNotFound = http.StatusNotFound +) + +func (c *GrafanaAlertClient) DeleteGrafanaAlertRule(uid string) error { + _, err := logzio_client.CallLogzioApi(logzio_client.LogzioApiCallDetails{ + ApiToken: c.ApiToken, + HttpMethod: deleteGrafanaAlertServiceMethod, + Url: fmt.Sprintf(deleteGrafanaAlertServiceUrl, c.BaseUrl, uid), + Body: nil, + SuccessCodes: []int{deleteGrafanaAlertServiceSuccess}, + NotFoundCode: deleteGrafanaAlertNotFound, + ResourceId: uid, + ApiAction: operationDeleteGrafanaAlert, + ResourceName: grafanaAlertResourceName, + }) + + return err +} From a3852d968e9b9985e930a2b3a28a6905b9ae8423 Mon Sep 17 00:00:00 2001 From: mirii1994 Date: Mon, 15 May 2023 10:40:51 +0300 Subject: [PATCH 06/24] get --- grafana_alerts/client_grafana_folder_get.go | 41 +++++++++++++++++++++ 1 file changed, 41 insertions(+) create mode 100644 grafana_alerts/client_grafana_folder_get.go diff --git a/grafana_alerts/client_grafana_folder_get.go b/grafana_alerts/client_grafana_folder_get.go new file mode 100644 index 0000000..f6abbdf --- /dev/null +++ b/grafana_alerts/client_grafana_folder_get.go @@ -0,0 +1,41 @@ +package grafana_alerts + +import ( + "encoding/json" + "fmt" + logzio_client "github.com/logzio/logzio_terraform_client" + "net/http" +) + +const ( + getGrafanaAlertServiceUrl = grafanaAlertServiceEndpoint + "/%s" + getGrafanaAlertServiceMethod = http.MethodGet + getGrafanaAlertServiceSuccess = http.StatusOK + getGrafanaAlertServiceNotFound = http.StatusNotFound +) + +func (c *GrafanaAlertClient) GetGrafanaAlertRule(uid string) (*GrafanaAlertRule, error) { + res, err := logzio_client.CallLogzioApi(logzio_client.LogzioApiCallDetails{ + ApiToken: c.ApiToken, + HttpMethod: getGrafanaAlertServiceMethod, + Url: fmt.Sprintf(getGrafanaAlertServiceUrl, c.BaseUrl, uid), + Body: nil, + SuccessCodes: []int{getGrafanaAlertServiceSuccess}, + NotFoundCode: getGrafanaAlertServiceNotFound, + ResourceId: uid, + ApiAction: operationGetGrafanaAlert, + ResourceName: grafanaAlertResourceName, + }) + + if err != nil { + return nil, err + } + + var grafanaAlertRule GrafanaAlertRule + err = json.Unmarshal(res, &grafanaAlertRule) + if err != nil { + return nil, err + } + + return &grafanaAlertRule, nil +} From aeb3c672289f7e6a99b9622f6946d13449b75c69 Mon Sep 17 00:00:00 2001 From: mirii1994 Date: Mon, 15 May 2023 10:44:10 +0300 Subject: [PATCH 07/24] rename resource --- grafana_alerts/client_grafana_alert.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/grafana_alerts/client_grafana_alert.go b/grafana_alerts/client_grafana_alert.go index b0c2f22..ed4bcfa 100644 --- a/grafana_alerts/client_grafana_alert.go +++ b/grafana_alerts/client_grafana_alert.go @@ -9,7 +9,7 @@ import ( const ( grafanaAlertServiceEndpoint = "%s/v1/grafana/api/v1/provisioning/alert-rules" - grafanaAlertResourceName = "grafana alert" + grafanaAlertResourceName = "grafana alert rule" operationCreateGrafanaAlert = "CreateGrafanaAlert" operationGetGrafanaAlert = "GetGrafanaAlert" From e0849fbcdf56d731ded3fbb0530f7ef7217afbdf Mon Sep 17 00:00:00 2001 From: mirii1994 Date: Mon, 15 May 2023 10:45:56 +0300 Subject: [PATCH 08/24] rename file, list --- ...der_get.go => client_grafana_alert_get.go} | 0 grafana_alerts/client_grafana_alert_list.go | 41 +++++++++++++++++++ 2 files changed, 41 insertions(+) rename grafana_alerts/{client_grafana_folder_get.go => client_grafana_alert_get.go} (100%) create mode 100644 grafana_alerts/client_grafana_alert_list.go diff --git a/grafana_alerts/client_grafana_folder_get.go b/grafana_alerts/client_grafana_alert_get.go similarity index 100% rename from grafana_alerts/client_grafana_folder_get.go rename to grafana_alerts/client_grafana_alert_get.go diff --git a/grafana_alerts/client_grafana_alert_list.go b/grafana_alerts/client_grafana_alert_list.go new file mode 100644 index 0000000..d20d855 --- /dev/null +++ b/grafana_alerts/client_grafana_alert_list.go @@ -0,0 +1,41 @@ +package grafana_alerts + +import ( + "encoding/json" + "fmt" + logzio_client "github.com/logzio/logzio_terraform_client" + "net/http" +) + +const ( + listGrafanaAlertServiceUrl = grafanaAlertServiceEndpoint + listGrafanaAlertServiceMethod = http.MethodGet + listGrafanaAlertServiceSuccess = http.StatusOK + listGrafanaAlertStatusNotFound = http.StatusNotFound +) + +func (c *GrafanaAlertClient) ListGrafanaAlertRules() ([]GrafanaAlertRule, error) { + res, err := logzio_client.CallLogzioApi(logzio_client.LogzioApiCallDetails{ + ApiToken: c.ApiToken, + HttpMethod: listGrafanaAlertServiceMethod, + Url: fmt.Sprintf(listGrafanaAlertServiceUrl, c.BaseUrl), + Body: nil, + SuccessCodes: []int{listGrafanaAlertServiceSuccess}, + NotFoundCode: listGrafanaAlertStatusNotFound, + ResourceId: nil, + ApiAction: operationListGrafanaAlerts, + ResourceName: grafanaAlertResourceName, + }) + + if err != nil { + return nil, err + } + + var alertRules []GrafanaAlertRule + err = json.Unmarshal(res, &alertRules) + if err != nil { + return nil, err + } + + return alertRules, nil +} From ea410daa5f8f665dfa0d3bdc671612e68cb93e0b Mon Sep 17 00:00:00 2001 From: mirii1994 Date: Mon, 15 May 2023 11:14:35 +0300 Subject: [PATCH 09/24] update, refactor --- grafana_alerts/client_grafana_alert.go | 40 ++++++++++++++ grafana_alerts/client_grafana_alert_create.go | 42 +-------------- grafana_alerts/client_grafana_alert_update.go | 54 +++++++++++++++++++ 3 files changed, 95 insertions(+), 41 deletions(-) create mode 100644 grafana_alerts/client_grafana_alert_update.go diff --git a/grafana_alerts/client_grafana_alert.go b/grafana_alerts/client_grafana_alert.go index ed4bcfa..808bae6 100644 --- a/grafana_alerts/client_grafana_alert.go +++ b/grafana_alerts/client_grafana_alert.go @@ -67,3 +67,43 @@ func New(apiToken string, baseUrl string) (*GrafanaAlertClient, error) { return grafanaAlertClient, nil } + +func validateGrafanaAlertRule(payload GrafanaAlertRule) error { + if len(payload.Condition) == 0 { + return fmt.Errorf("Field condition must be set!") + } + + if payload.Data == nil { + return fmt.Errorf("Field data must be set!") + } + + if len(payload.ExecErrState) == 0 { + return fmt.Errorf("Field execErrState must be set!") + } + + if len(payload.FolderUID) == 0 { + return fmt.Errorf("Field folderUID must be set!") + } + + if len(payload.For) == 0 { + return fmt.Errorf("Field for must be set!") + } + + if len(payload.NoDataState) == 0 { + return fmt.Errorf("Field noDataState must be set!") + } + + if payload.OrgID == 0 { + return fmt.Errorf("Field orgID must be set!") + } + + if len(payload.RuleGroup) == 0 { + return fmt.Errorf("Field ruleGroup must be set!") + } + + if len(payload.Title) == 0 { + return fmt.Errorf("Field title must be set!") + } + + return nil +} diff --git a/grafana_alerts/client_grafana_alert_create.go b/grafana_alerts/client_grafana_alert_create.go index aea010e..ffac73d 100644 --- a/grafana_alerts/client_grafana_alert_create.go +++ b/grafana_alerts/client_grafana_alert_create.go @@ -15,7 +15,7 @@ const ( ) func (c *GrafanaAlertClient) CreateGrafanaAlertRule(payload GrafanaAlertRule) (*GrafanaAlertRule, error) { - err := validateCreateGrafanaAlertRule(payload) + err := validateGrafanaAlertRule(payload) if err != nil { return nil, err } @@ -49,43 +49,3 @@ func (c *GrafanaAlertClient) CreateGrafanaAlertRule(payload GrafanaAlertRule) (* return &retVal, nil } - -func validateCreateGrafanaAlertRule(payload GrafanaAlertRule) error { - if len(payload.Condition) == 0 { - return fmt.Errorf("Field condition must be set!") - } - - if payload.Data == nil { - return fmt.Errorf("Field data must be set!") - } - - if len(payload.ExecErrState) == 0 { - return fmt.Errorf("Field execErrState must be set!") - } - - if len(payload.FolderUID) == 0 { - return fmt.Errorf("Field folderUID must be set!") - } - - if len(payload.For) == 0 { - return fmt.Errorf("Field for must be set!") - } - - if len(payload.NoDataState) == 0 { - return fmt.Errorf("Field noDataState must be set!") - } - - if payload.OrgID == 0 { - return fmt.Errorf("Field orgID must be set!") - } - - if len(payload.RuleGroup) == 0 { - return fmt.Errorf("Field ruleGroup must be set!") - } - - if len(payload.Title) == 0 { - return fmt.Errorf("Field title must be set!") - } - - return nil -} diff --git a/grafana_alerts/client_grafana_alert_update.go b/grafana_alerts/client_grafana_alert_update.go new file mode 100644 index 0000000..3f99c40 --- /dev/null +++ b/grafana_alerts/client_grafana_alert_update.go @@ -0,0 +1,54 @@ +package grafana_alerts + +import ( + "encoding/json" + "fmt" + logzio_client "github.com/logzio/logzio_terraform_client" + "net/http" +) + +const ( + updateGrafanaAlertServiceUrl = grafanaAlertServiceEndpoint + "/%s" + updateGrafanaAlertServiceMethod = http.MethodPut + updateGrafanaAlertServiceSuccess = http.StatusOK + updateGrafanaAlertServiceNotFound = http.StatusNotFound +) + +func (c *GrafanaAlertClient) UpdateGrafanaAlertRule(payload GrafanaAlertRule) error { + err := validateUpdateGrafanaAlertRule(payload) + if err != nil { + return err + } + + updateGrafanaAlertRuleJson, err := json.Marshal(payload) + if err != nil { + return err + } + + _, err = logzio_client.CallLogzioApi(logzio_client.LogzioApiCallDetails{ + ApiToken: c.ApiToken, + HttpMethod: updateGrafanaAlertServiceMethod, + Url: fmt.Sprintf(updateGrafanaAlertServiceUrl, c.BaseUrl, payload.Uid), + Body: updateGrafanaAlertRuleJson, + SuccessCodes: []int{updateGrafanaAlertServiceSuccess}, + NotFoundCode: updateGrafanaAlertServiceNotFound, + ResourceId: payload.Uid, + ApiAction: operationUpdateGrafanaAlert, + ResourceName: grafanaAlertResourceName, + }) + + return err +} + +func validateUpdateGrafanaAlertRule(payload GrafanaAlertRule) error { + err := validateGrafanaAlertRule(payload) + if err != nil { + return err + } + + if len(payload.Uid) == 0 { + return fmt.Errorf("Field uid must be set when updating a Grafana alert rule!") + } + + return nil +} From 8336761b3042422349075f2e40b766c9ab657c4e Mon Sep 17 00:00:00 2001 From: mirii1994 Date: Mon, 15 May 2023 12:53:04 +0300 Subject: [PATCH 10/24] test save progress --- grafana_alerts/grafana_alert_test.go | 86 ++++++++++++++++++++++++++++ 1 file changed, 86 insertions(+) create mode 100644 grafana_alerts/grafana_alert_test.go diff --git a/grafana_alerts/grafana_alert_test.go b/grafana_alerts/grafana_alert_test.go new file mode 100644 index 0000000..9f3fb40 --- /dev/null +++ b/grafana_alerts/grafana_alert_test.go @@ -0,0 +1,86 @@ +package grafana_alerts_test + +import ( + "encoding/json" + "github.com/logzio/logzio_terraform_client/grafana_alerts" + "github.com/logzio/logzio_terraform_client/test_utils" + "net/http" + "net/http/httptest" + "os" + "time" +) + +var ( + mux *http.ServeMux + server *httptest.Server +) + +func fixture(path string) string { + b, err := os.ReadFile("testdata/fixtures/" + path) + if err != nil { + panic(err) + } + return string(b) +} + +func setupGrafanaAlertRuleTest() (*grafana_alerts.GrafanaAlertClient, error, func()) { + mux = http.NewServeMux() + server = httptest.NewServer(mux) + + apiToken := "SOME_API_TOKEN" + underTest, _ := grafana_alerts.New(apiToken, server.URL) + + return underTest, nil, func() { + server.Close() + } +} + +func setupGrafanaFolderIntegrationTest() (*grafana_alerts.GrafanaAlertClient, error) { + apiToken, err := test_utils.GetApiToken() + if err != nil { + return nil, err + } + + underTest, err := grafana_alerts.New(apiToken, test_utils.GetLogzIoBaseUrl()) + return underTest, err +} + +func getGrafanaAlertRuleObject() grafana_alerts.GrafanaAlertRule { + data := grafana_alerts.GrafanaAlertQuery{ + DatasourceUid: "__expr__", + Model: json.RawMessage(`{"conditions":[{"evaluator":{"params":[0,0],"type":"gt"},"operator":{"type":"and"},"query":{"params":[]},"reducer":{"params":[],"type":"avg"},"type":"query"}],"datasource":{"type":"__expr__","uid":"__expr__"},"expression":"1 == 1","hide":false,"intervalMs":1000,"maxDataPoints":43200,"refId":"A","type":"math"}`), + RefId: "A", + RelativeTimeRange: grafana_alerts.RelativeTimeRangeObj{ + From: 0, + To: 0, + }, + } + + alertRule := grafana_alerts.GrafanaAlertRule{ + Annotations: map[string]string{"key_test": "value_test"}, + Condition: "A", + Data: []*grafana_alerts.GrafanaAlertQuery{&data}, + FolderUID: "", + For: "", + Id: 0, + Labels: nil, + NoDataState: "", + OrgID: 0, + Provenance: "", + RuleGroup: "", + Title: "", + Uid: "", + Updated: time.Time{}, + } +} + +func getModel() interface{} { + modelJson := "{\"conditions\":[{\"evaluator\":{\"params\":[0,0],\"type\":\"gt\"},\"operator\":{\"type\":\"and\"},\"query\":{\"params\":[]},\"reducer\":{\"params\":[],\"type\":\"avg\"},\"type\":\"query\"}],\"datasource\":{\"type\":\"__expr__\",\"uid\":\"__expr__\"},\"expression\":\"1 == 1\",\"hide\":false,\"intervalMs\":1000,\"maxDataPoints\":43200,\"refId\":\"A\",\"type\":\"math\"}" + var modelObj map[string]interface{} + _ = json.Unmarshal([]byte(modelJson), &modelObj) + return modelObj +} + +func getTestFolderUid() string { + +} From 669958e0c2335a9ea48ce475feb6d63ad1e3068e Mon Sep 17 00:00:00 2001 From: mirii1994 Date: Tue, 27 Jun 2023 09:24:51 +0300 Subject: [PATCH 11/24] save progress --- grafana_alerts/grafana_alert_test.go | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/grafana_alerts/grafana_alert_test.go b/grafana_alerts/grafana_alert_test.go index 9f3fb40..2136e1a 100644 --- a/grafana_alerts/grafana_alert_test.go +++ b/grafana_alerts/grafana_alert_test.go @@ -10,6 +10,10 @@ import ( "time" ) +const ( + envGrafanaFolderUid = "GRAFANA_FOLDER_UID" +) + var ( mux *http.ServeMux server *httptest.Server @@ -60,7 +64,7 @@ func getGrafanaAlertRuleObject() grafana_alerts.GrafanaAlertRule { Annotations: map[string]string{"key_test": "value_test"}, Condition: "A", Data: []*grafana_alerts.GrafanaAlertQuery{&data}, - FolderUID: "", + FolderUID: os.Getenv(envGrafanaFolderUid), For: "", Id: 0, Labels: nil, @@ -82,5 +86,4 @@ func getModel() interface{} { } func getTestFolderUid() string { - } From d3013d36e1031ba37a5646562950f33c4204775a Mon Sep 17 00:00:00 2001 From: mirii1994 Date: Wed, 20 Sep 2023 12:51:01 +0300 Subject: [PATCH 12/24] grafana alert create int tests --- grafana_alerts/client_grafana_alert.go | 20 +++- .../grafana_alert_create_integration_test.go | 104 ++++++++++++++++++ grafana_alerts/grafana_alert_test.go | 39 ++----- 3 files changed, 131 insertions(+), 32 deletions(-) create mode 100644 grafana_alerts/grafana_alert_create_integration_test.go diff --git a/grafana_alerts/client_grafana_alert.go b/grafana_alerts/client_grafana_alert.go index 808bae6..a61f1c5 100644 --- a/grafana_alerts/client_grafana_alert.go +++ b/grafana_alerts/client_grafana_alert.go @@ -6,6 +6,9 @@ import ( "time" ) +type ExecErrState string +type NoDataState string + const ( grafanaAlertServiceEndpoint = "%s/v1/grafana/api/v1/provisioning/alert-rules" @@ -16,6 +19,13 @@ const ( operationUpdateGrafanaAlert = "UpdateGrafanaAlert" operationDeleteGrafanaAlert = "DeleteGrafanaAlert" operationListGrafanaAlerts = "ListGrafanaAlerts" + + ErrOK ExecErrState = "OK" + ErrError ExecErrState = "Error" + ErrAlerting ExecErrState = "Alerting" + NoDataOk NoDataState = "OK" + NoData NoDataState = "NoData" + NoDataAlerting NoDataState = "Alerting" ) type GrafanaAlertClient struct { @@ -26,12 +36,12 @@ type GrafanaAlertRule struct { Annotations map[string]string `json:"annotations,omitempty"` Condition string `json:"condition"` // Required Data []*GrafanaAlertQuery `json:"data"` // Required - ExecErrState string `json:"execErrState"` // Required + ExecErrState ExecErrState `json:"execErrState"` // Required FolderUID string `json:"folderUID"` // Required - For string `json:"for"` // Required + For int64 `json:"for"` // Required Id int64 `json:"id,omitempty"` Labels map[string]string `json:"labels,omitempty"` - NoDataState string `json:"noDataState"` // Required + NoDataState NoDataState `json:"noDataState"` // Required OrgID int64 `json:"orgID"` // Required Provenance string `json:"provenance,omitempty"` RuleGroup string `json:"ruleGroup"` // Required @@ -73,7 +83,7 @@ func validateGrafanaAlertRule(payload GrafanaAlertRule) error { return fmt.Errorf("Field condition must be set!") } - if payload.Data == nil { + if payload.Data == nil || len(payload.Data) == 0 { return fmt.Errorf("Field data must be set!") } @@ -85,7 +95,7 @@ func validateGrafanaAlertRule(payload GrafanaAlertRule) error { return fmt.Errorf("Field folderUID must be set!") } - if len(payload.For) == 0 { + if payload.For == 0 { return fmt.Errorf("Field for must be set!") } diff --git a/grafana_alerts/grafana_alert_create_integration_test.go b/grafana_alerts/grafana_alert_create_integration_test.go new file mode 100644 index 0000000..3e85436 --- /dev/null +++ b/grafana_alerts/grafana_alert_create_integration_test.go @@ -0,0 +1,104 @@ +package grafana_alerts_test + +import ( + "fmt" + "github.com/logzio/logzio_terraform_client/test_utils" + "github.com/stretchr/testify/assert" + "testing" + "time" +) + +func TestIntegrationGrafanaAlert_CreateGrafanaAlert(t *testing.T) { + underTest, err := setupGrafanaAlertIntegrationTest() + defer test_utils.TestDoneTimeBuffer() + + if assert.NoError(t, err) { + createGrafanaAlert := getGrafanaAlertRuleObject() + createGrafanaAlert.Title = fmt.Sprintf("%s_%s", createGrafanaAlert.Title, "create") + grafanaAlert, err := underTest.CreateGrafanaAlertRule(createGrafanaAlert) + if assert.NoError(t, err) && assert.NotNil(t, grafanaAlert) { + time.Sleep(4 * time.Second) + defer underTest.DeleteGrafanaAlertRule(grafanaAlert.Uid) + assert.NotZero(t, grafanaAlert.Uid) + assert.Equal(t, createGrafanaAlert.Title, grafanaAlert.Title) + } + } +} + +func TestIntegrationGrafanaAlert_CreateGrafanaAlertNoTitle(t *testing.T) { + underTest, err := setupGrafanaAlertIntegrationTest() + defer test_utils.TestDoneTimeBuffer() + + if assert.NoError(t, err) { + createGrafanaAlert := getGrafanaAlertRuleObject() + createGrafanaAlert.Title = "" + grafanaAlert, err := underTest.CreateGrafanaAlertRule(createGrafanaAlert) + assert.Error(t, err) + assert.Nil(t, grafanaAlert) + } +} + +func TestIntegrationGrafanaAlert_CreateGrafanaAlertNoData(t *testing.T) { + underTest, err := setupGrafanaAlertIntegrationTest() + defer test_utils.TestDoneTimeBuffer() + + if assert.NoError(t, err) { + createGrafanaAlert := getGrafanaAlertRuleObject() + createGrafanaAlert.Data = nil + grafanaAlert, err := underTest.CreateGrafanaAlertRule(createGrafanaAlert) + assert.Error(t, err) + assert.Nil(t, grafanaAlert) + } +} + +func TestIntegrationGrafanaAlert_CreateGrafanaAlertNoFolderUid(t *testing.T) { + underTest, err := setupGrafanaAlertIntegrationTest() + defer test_utils.TestDoneTimeBuffer() + + if assert.NoError(t, err) { + createGrafanaAlert := getGrafanaAlertRuleObject() + createGrafanaAlert.FolderUID = "" + grafanaAlert, err := underTest.CreateGrafanaAlertRule(createGrafanaAlert) + assert.Error(t, err) + assert.Nil(t, grafanaAlert) + } +} + +func TestIntegrationGrafanaAlert_CreateGrafanaAlertNoFor(t *testing.T) { + underTest, err := setupGrafanaAlertIntegrationTest() + defer test_utils.TestDoneTimeBuffer() + + if assert.NoError(t, err) { + createGrafanaAlert := getGrafanaAlertRuleObject() + createGrafanaAlert.For = 0 + grafanaAlert, err := underTest.CreateGrafanaAlertRule(createGrafanaAlert) + assert.Error(t, err) + assert.Nil(t, grafanaAlert) + } +} + +func TestIntegrationGrafanaAlert_CreateGrafanaAlertNoOrgId(t *testing.T) { + underTest, err := setupGrafanaAlertIntegrationTest() + defer test_utils.TestDoneTimeBuffer() + + if assert.NoError(t, err) { + createGrafanaAlert := getGrafanaAlertRuleObject() + createGrafanaAlert.OrgID = 0 + grafanaAlert, err := underTest.CreateGrafanaAlertRule(createGrafanaAlert) + assert.Error(t, err) + assert.Nil(t, grafanaAlert) + } +} + +func TestIntegrationGrafanaAlert_CreateGrafanaAlertNoOrgRuleGroup(t *testing.T) { + underTest, err := setupGrafanaAlertIntegrationTest() + defer test_utils.TestDoneTimeBuffer() + + if assert.NoError(t, err) { + createGrafanaAlert := getGrafanaAlertRuleObject() + createGrafanaAlert.RuleGroup = "" + grafanaAlert, err := underTest.CreateGrafanaAlertRule(createGrafanaAlert) + assert.Error(t, err) + assert.Nil(t, grafanaAlert) + } +} diff --git a/grafana_alerts/grafana_alert_test.go b/grafana_alerts/grafana_alert_test.go index 2136e1a..ecd5184 100644 --- a/grafana_alerts/grafana_alert_test.go +++ b/grafana_alerts/grafana_alert_test.go @@ -7,7 +7,6 @@ import ( "net/http" "net/http/httptest" "os" - "time" ) const ( @@ -39,7 +38,7 @@ func setupGrafanaAlertRuleTest() (*grafana_alerts.GrafanaAlertClient, error, fun } } -func setupGrafanaFolderIntegrationTest() (*grafana_alerts.GrafanaAlertClient, error) { +func setupGrafanaAlertIntegrationTest() (*grafana_alerts.GrafanaAlertClient, error) { apiToken, err := test_utils.GetApiToken() if err != nil { return nil, err @@ -60,30 +59,16 @@ func getGrafanaAlertRuleObject() grafana_alerts.GrafanaAlertRule { }, } - alertRule := grafana_alerts.GrafanaAlertRule{ - Annotations: map[string]string{"key_test": "value_test"}, - Condition: "A", - Data: []*grafana_alerts.GrafanaAlertQuery{&data}, - FolderUID: os.Getenv(envGrafanaFolderUid), - For: "", - Id: 0, - Labels: nil, - NoDataState: "", - OrgID: 0, - Provenance: "", - RuleGroup: "", - Title: "", - Uid: "", - Updated: time.Time{}, + return grafana_alerts.GrafanaAlertRule{ + Annotations: map[string]string{"key_test": "value_test"}, + Condition: "A", + Data: []*grafana_alerts.GrafanaAlertQuery{&data}, + FolderUID: os.Getenv(envGrafanaFolderUid), + NoDataState: grafana_alerts.NoDataOk, + ExecErrState: grafana_alerts.ErrOK, + OrgID: 1, + RuleGroup: "rule_group_1", + Title: "test_alert", + For: int64(3), } } - -func getModel() interface{} { - modelJson := "{\"conditions\":[{\"evaluator\":{\"params\":[0,0],\"type\":\"gt\"},\"operator\":{\"type\":\"and\"},\"query\":{\"params\":[]},\"reducer\":{\"params\":[],\"type\":\"avg\"},\"type\":\"query\"}],\"datasource\":{\"type\":\"__expr__\",\"uid\":\"__expr__\"},\"expression\":\"1 == 1\",\"hide\":false,\"intervalMs\":1000,\"maxDataPoints\":43200,\"refId\":\"A\",\"type\":\"math\"}" - var modelObj map[string]interface{} - _ = json.Unmarshal([]byte(modelJson), &modelObj) - return modelObj -} - -func getTestFolderUid() string { -} From 3858a039557b5e5b11ea05b5ee9e19d9fb3898d6 Mon Sep 17 00:00:00 2001 From: mirii1994 Date: Wed, 27 Sep 2023 14:03:26 +0300 Subject: [PATCH 13/24] delete create tests --- grafana_alerts/grafana_alert_create_test.go | 63 +++++++++++++++++++ .../grafana_alert_delete_integration_test.go | 42 +++++++++++++ grafana_alerts/grafana_alert_delete_test.go | 25 ++++++++ 3 files changed, 130 insertions(+) create mode 100644 grafana_alerts/grafana_alert_create_test.go create mode 100644 grafana_alerts/grafana_alert_delete_integration_test.go create mode 100644 grafana_alerts/grafana_alert_delete_test.go diff --git a/grafana_alerts/grafana_alert_create_test.go b/grafana_alerts/grafana_alert_create_test.go new file mode 100644 index 0000000..5a92f97 --- /dev/null +++ b/grafana_alerts/grafana_alert_create_test.go @@ -0,0 +1,63 @@ +package grafana_alerts_test + +import ( + "encoding/json" + "fmt" + "github.com/logzio/logzio_terraform_client/grafana_alerts" + "github.com/stretchr/testify/assert" + "io" + "net/http" + "testing" +) + +func TestGrafanaAlert_CreateGrafanaAlert(t *testing.T) { + underTest, err, teardown := setupGrafanaAlertRuleTest() + defer teardown() + + if assert.NoError(t, err) { + mux.HandleFunc("/v1/grafana/api/v1/provisioning/alert-rules", func(w http.ResponseWriter, r *http.Request) { + assert.Equal(t, http.MethodPost, r.Method) + jsonBytes, _ := io.ReadAll(r.Body) + var target grafana_alerts.GrafanaAlertRule + err = json.Unmarshal(jsonBytes, &target) + assert.NoError(t, err) + assert.NotNil(t, target) + assert.NotEmpty(t, target.Title) + w.Header().Set("Content-Type", "application/json") + w.WriteHeader(http.StatusCreated) + fmt.Fprint(w, fixture("create_grafana_alert_res.json")) + }) + + createGrafanaAlert := getGrafanaAlertRuleObject() + grafanaAlert, err := underTest.CreateGrafanaAlertRule(createGrafanaAlert) + assert.NoError(t, err) + assert.NotNil(t, grafanaAlert) + assert.Equal(t, int64(123456), grafanaAlert.Id) + assert.Equal(t, "some_uid", grafanaAlert.Uid) + assert.Equal(t, "folder_uid", grafanaAlert.FolderUID) + assert.Equal(t, createGrafanaAlert.RuleGroup, grafanaAlert.RuleGroup) + } +} + +func TestGrafanaAlert_CreateGrafanaAlertInternalServerError(t *testing.T) { + underTest, err, teardown := setupGrafanaAlertRuleTest() + defer teardown() + + if assert.NoError(t, err) { + mux.HandleFunc("/v1/grafana/api/v1/provisioning/alert-rules", func(w http.ResponseWriter, r *http.Request) { + assert.Equal(t, http.MethodPost, r.Method) + jsonBytes, _ := io.ReadAll(r.Body) + var target grafana_alerts.GrafanaAlertRule + err = json.Unmarshal(jsonBytes, &target) + assert.NoError(t, err) + assert.NotNil(t, target) + assert.NotEmpty(t, target.Title) + w.WriteHeader(http.StatusInternalServerError) + }) + + createGrafanaAlert := getGrafanaAlertRuleObject() + grafanaAlert, err := underTest.CreateGrafanaAlertRule(createGrafanaAlert) + assert.Error(t, err) + assert.Nil(t, grafanaAlert) + } +} diff --git a/grafana_alerts/grafana_alert_delete_integration_test.go b/grafana_alerts/grafana_alert_delete_integration_test.go new file mode 100644 index 0000000..462e4b1 --- /dev/null +++ b/grafana_alerts/grafana_alert_delete_integration_test.go @@ -0,0 +1,42 @@ +package grafana_alerts_test + +import ( + "github.com/logzio/logzio_terraform_client/test_utils" + "github.com/stretchr/testify/assert" + "testing" + "time" +) + +func TestIntegrationGrafanaAlert_DeleteGrafanaAlert(t *testing.T) { + underTest, err := setupGrafanaAlertIntegrationTest() + defer test_utils.TestDoneTimeBuffer() + if assert.NoError(t, err) { + createGrafanaAlert := getGrafanaAlertRuleObject() + grafanaAlert, err := underTest.CreateGrafanaAlertRule(createGrafanaAlert) + if assert.NoError(t, err) && assert.NotNil(t, grafanaAlert) && assert.NotEmpty(t, grafanaAlert.Uid) { + time.Sleep(2 * time.Second) + defer func() { + err = underTest.DeleteGrafanaAlertRule(grafanaAlert.Uid) + assert.NoError(t, err) + }() + } + } +} + +func TestIntegrationGrafanaAlert_DeleteGrafanaAlertEmptyUid(t *testing.T) { + underTest, err := setupGrafanaAlertIntegrationTest() + defer test_utils.TestDoneTimeBuffer() + if assert.NoError(t, err) { + err = underTest.DeleteGrafanaAlertRule("") + assert.Error(t, err) + } +} + +func TestIntegrationGrafanaAlert_DeleteGrafanaAlertUidNotFound(t *testing.T) { + underTest, err := setupGrafanaAlertIntegrationTest() + defer test_utils.TestDoneTimeBuffer() + if assert.NoError(t, err) { + err = underTest.DeleteGrafanaAlertRule("uidNotFound") + assert.Error(t, err) + } +} diff --git a/grafana_alerts/grafana_alert_delete_test.go b/grafana_alerts/grafana_alert_delete_test.go new file mode 100644 index 0000000..6841673 --- /dev/null +++ b/grafana_alerts/grafana_alert_delete_test.go @@ -0,0 +1,25 @@ +package grafana_alerts_test + +import ( + "github.com/stretchr/testify/assert" + "net/http" + "testing" +) + +func TestGrafanaAlert_DeleteGrafanaAlert(t *testing.T) { + underTest, err, teardown := setupGrafanaAlertRuleTest() + defer teardown() + + if assert.NoError(t, err) { + grafanaAlertUid := "delete-me" + + mux.HandleFunc("/v1/grafana/api/v1/provisioning/alert-rules/", func(w http.ResponseWriter, r *http.Request) { + assert.Equal(t, http.MethodDelete, r.Method) + assert.Contains(t, r.URL.String(), grafanaAlertUid) + w.WriteHeader(http.StatusNoContent) + }) + + err = underTest.DeleteGrafanaAlertRule(grafanaAlertUid) + assert.NoError(t, err) + } +} From cca4ca7b5227f80fd1cc179fe9b546fcb3edc474 Mon Sep 17 00:00:00 2001 From: mirii1994 Date: Wed, 27 Sep 2023 14:03:51 +0300 Subject: [PATCH 14/24] cont. --- grafana_alerts/client_grafana_alert_delete.go | 3 + .../fixtures/create_grafana_alert_res.json | 60 +++++++++++++++++++ 2 files changed, 63 insertions(+) create mode 100644 grafana_alerts/testdata/fixtures/create_grafana_alert_res.json diff --git a/grafana_alerts/client_grafana_alert_delete.go b/grafana_alerts/client_grafana_alert_delete.go index 8fc67bc..4347e29 100644 --- a/grafana_alerts/client_grafana_alert_delete.go +++ b/grafana_alerts/client_grafana_alert_delete.go @@ -14,6 +14,9 @@ const ( ) func (c *GrafanaAlertClient) DeleteGrafanaAlertRule(uid string) error { + if uid == "" { + return fmt.Errorf("uid is empty") + } _, err := logzio_client.CallLogzioApi(logzio_client.LogzioApiCallDetails{ ApiToken: c.ApiToken, HttpMethod: deleteGrafanaAlertServiceMethod, diff --git a/grafana_alerts/testdata/fixtures/create_grafana_alert_res.json b/grafana_alerts/testdata/fixtures/create_grafana_alert_res.json new file mode 100644 index 0000000..38644c3 --- /dev/null +++ b/grafana_alerts/testdata/fixtures/create_grafana_alert_res.json @@ -0,0 +1,60 @@ +{ + "id": 123456, + "uid": "some_uid", + "folderUID": "folder_uid", + "ruleGroup": "rule_group_1", + "title": "test_alert", + "condition": "A", + "data": [ + { + "refId": "A", + "queryType": "", + "relativeTimeRange": { + "from": 0, + "to": 0 + }, + "datasourceUid": "__expr__", + "model": { + "conditions": [ + { + "evaluator": { + "params": [ + 0, + 0 + ], + "type": "gt" + }, + "operator": { + "type": "and" + }, + "query": { + "params": [] + }, + "reducer": { + "params": [], + "type": "avg" + }, + "type": "query" + } + ], + "datasource": { + "type": "__expr__", + "uid": "__expr__" + }, + "expression": "1 == 1", + "hide": false, + "intervalMs": 1000, + "maxDataPoints": 43200, + "refId": "A", + "type": "math" + } + } + ], + "updated": "2023-09-20T09:47:10Z", + "noDataState": "OK", + "execErrState": "OK", + "for": 3, + "annotations": { + "key_test": "value_test" + } +} From 102cdd9e70605a334b1ef7ab4d8b232579d9beba Mon Sep 17 00:00:00 2001 From: mirii1994 Date: Wed, 27 Sep 2023 16:24:25 +0300 Subject: [PATCH 15/24] get tests --- grafana_alerts/client_grafana_alert_delete.go | 4 +- .../grafana_alert_delete_integration_test.go | 9 ---- .../grafana_alert_get_integration_test.go | 50 +++++++++++++++++++ grafana_alerts/grafana_alert_get_test.go | 50 +++++++++++++++++++ 4 files changed, 103 insertions(+), 10 deletions(-) create mode 100644 grafana_alerts/grafana_alert_get_integration_test.go create mode 100644 grafana_alerts/grafana_alert_get_test.go diff --git a/grafana_alerts/client_grafana_alert_delete.go b/grafana_alerts/client_grafana_alert_delete.go index 4347e29..5b2eaab 100644 --- a/grafana_alerts/client_grafana_alert_delete.go +++ b/grafana_alerts/client_grafana_alert_delete.go @@ -10,7 +10,9 @@ const ( deleteGrafanaAlertServiceUrl = grafanaAlertServiceEndpoint + "/%s" deleteGrafanaAlertServiceMethod = http.MethodDelete deleteGrafanaAlertServiceSuccess = http.StatusNoContent - deleteGrafanaAlertNotFound = http.StatusNotFound + // NOTE: the grafana api returns 204 even when you try to delete with a uid that doesn't exist, + // so the following line is just for compatibility with the CallLogzioApi object + deleteGrafanaAlertNotFound = http.StatusNotFound ) func (c *GrafanaAlertClient) DeleteGrafanaAlertRule(uid string) error { diff --git a/grafana_alerts/grafana_alert_delete_integration_test.go b/grafana_alerts/grafana_alert_delete_integration_test.go index 462e4b1..a1f870f 100644 --- a/grafana_alerts/grafana_alert_delete_integration_test.go +++ b/grafana_alerts/grafana_alert_delete_integration_test.go @@ -31,12 +31,3 @@ func TestIntegrationGrafanaAlert_DeleteGrafanaAlertEmptyUid(t *testing.T) { assert.Error(t, err) } } - -func TestIntegrationGrafanaAlert_DeleteGrafanaAlertUidNotFound(t *testing.T) { - underTest, err := setupGrafanaAlertIntegrationTest() - defer test_utils.TestDoneTimeBuffer() - if assert.NoError(t, err) { - err = underTest.DeleteGrafanaAlertRule("uidNotFound") - assert.Error(t, err) - } -} diff --git a/grafana_alerts/grafana_alert_get_integration_test.go b/grafana_alerts/grafana_alert_get_integration_test.go new file mode 100644 index 0000000..80091d3 --- /dev/null +++ b/grafana_alerts/grafana_alert_get_integration_test.go @@ -0,0 +1,50 @@ +package grafana_alerts_test + +import ( + "github.com/logzio/logzio_terraform_client/test_utils" + "github.com/stretchr/testify/assert" + "testing" + "time" +) + +func TestIntegrationGrafanaAlert_GetGrafanaAlert(t *testing.T) { + underTest, err := setupGrafanaAlertIntegrationTest() + defer test_utils.TestDoneTimeBuffer() + + if assert.NoError(t, err) { + createGrafanaAlert := getGrafanaAlertRuleObject() + grafanaAlert, err := underTest.CreateGrafanaAlertRule(createGrafanaAlert) + if assert.NoError(t, err) && assert.NotNil(t, grafanaAlert) && assert.NotEmpty(t, grafanaAlert.Uid) { + defer underTest.DeleteGrafanaAlertRule(grafanaAlert.Uid) + time.Sleep(4 * time.Second) + getAlert, err := underTest.GetGrafanaAlertRule(grafanaAlert.Uid) + assert.NoError(t, err) + assert.NotNil(t, getAlert) + assert.Equal(t, grafanaAlert.Annotations, getAlert.Annotations) + assert.Equal(t, grafanaAlert.Uid, getAlert.Uid) + assert.Equal(t, grafanaAlert.Id, getAlert.Id) + assert.Equal(t, grafanaAlert.Title, getAlert.Title) + assert.Equal(t, grafanaAlert.RuleGroup, getAlert.RuleGroup) + assert.Equal(t, grafanaAlert.FolderUID, getAlert.FolderUID) + assert.Equal(t, grafanaAlert.Data, getAlert.Data) + assert.Equal(t, grafanaAlert.OrgID, getAlert.OrgID) + assert.Equal(t, grafanaAlert.Condition, getAlert.Condition) + assert.Equal(t, grafanaAlert.ExecErrState, getAlert.ExecErrState) + assert.Equal(t, grafanaAlert.For, getAlert.For) + assert.Equal(t, grafanaAlert.Labels, getAlert.Labels) + assert.Equal(t, grafanaAlert.NoDataState, getAlert.NoDataState) + } + } +} + +func TestIntegrationGrafanaAlert_GetGrafanaAlertUidNotExists(t *testing.T) { + underTest, err := setupGrafanaAlertIntegrationTest() + defer test_utils.TestDoneTimeBuffer() + + if assert.NoError(t, err) { + getAlert, err := underTest.GetGrafanaAlertRule("someUid") + assert.Error(t, err) + assert.Nil(t, getAlert) + assert.Contains(t, err.Error(), "failed with missing grafana alert rule") + } +} diff --git a/grafana_alerts/grafana_alert_get_test.go b/grafana_alerts/grafana_alert_get_test.go new file mode 100644 index 0000000..98a3ce3 --- /dev/null +++ b/grafana_alerts/grafana_alert_get_test.go @@ -0,0 +1,50 @@ +package grafana_alerts_test + +import ( + "fmt" + "github.com/stretchr/testify/assert" + "net/http" + "testing" +) + +func TestGrafanaAlert_GetGrafanaAlert(t *testing.T) { + underTest, err, teardown := setupGrafanaAlertRuleTest() + assert.NoError(t, err) + defer teardown() + + alertUid := "some-uid" + + mux.HandleFunc("/v1/grafana/api/v1/provisioning/alert-rules/", func(w http.ResponseWriter, r *http.Request) { + assert.Equal(t, http.MethodGet, r.Method) + assert.Contains(t, r.URL.String(), alertUid) + w.Header().Set("Content-Type", "application/json") + fmt.Fprint(w, fixture("create_grafana_alert_res.json")) + }) + + alert, err := underTest.GetGrafanaAlertRule(alertUid) + assert.NoError(t, err) + assert.NotNil(t, alert) + assert.NoError(t, err) + assert.NotNil(t, alert) + assert.Equal(t, int64(123456), alert.Id) + assert.Equal(t, "some_uid", alert.Uid) + assert.Equal(t, "folder_uid", alert.FolderUID) +} + +func TestGrafanaAlert_GetGrafanaAlertInternalError(t *testing.T) { + underTest, err, teardown := setupGrafanaAlertRuleTest() + assert.NoError(t, err) + defer teardown() + + alertUid := "some-id" + + mux.HandleFunc("/v1/grafana/api/v1/provisioning/alert-rules/", func(w http.ResponseWriter, r *http.Request) { + assert.Equal(t, http.MethodGet, r.Method) + assert.Contains(t, r.URL.String(), alertUid) + w.WriteHeader(http.StatusInternalServerError) + }) + + alert, err := underTest.GetGrafanaAlertRule(alertUid) + assert.Error(t, err) + assert.Nil(t, alert) +} From 4cac51dd863a8d73632e357f1bad39ff470718e2 Mon Sep 17 00:00:00 2001 From: mirii1994 Date: Wed, 27 Sep 2023 16:36:52 +0300 Subject: [PATCH 16/24] list tests --- .../grafana_alert_list_integration_test.go | 16 +++++ grafana_alerts/grafana_alert_list_test.go | 40 ++++++++++++ .../fixtures/list_grafana_alert_res.json | 62 +++++++++++++++++++ .../grafana_folder_list_integration_test.go | 4 +- 4 files changed, 120 insertions(+), 2 deletions(-) create mode 100644 grafana_alerts/grafana_alert_list_integration_test.go create mode 100644 grafana_alerts/grafana_alert_list_test.go create mode 100644 grafana_alerts/testdata/fixtures/list_grafana_alert_res.json diff --git a/grafana_alerts/grafana_alert_list_integration_test.go b/grafana_alerts/grafana_alert_list_integration_test.go new file mode 100644 index 0000000..12d1d0a --- /dev/null +++ b/grafana_alerts/grafana_alert_list_integration_test.go @@ -0,0 +1,16 @@ +package grafana_alerts_test + +import ( + "github.com/stretchr/testify/assert" + "testing" +) + +func TestIntegrationGrafanaAlert_ListGrafanaAlerts(t *testing.T) { + underTest, err := setupGrafanaAlertIntegrationTest() + + if assert.NoError(t, err) { + alerts, err := underTest.ListGrafanaAlertRules() + assert.NoError(t, err) + assert.NotNil(t, alerts) + } +} diff --git a/grafana_alerts/grafana_alert_list_test.go b/grafana_alerts/grafana_alert_list_test.go new file mode 100644 index 0000000..cf6721d --- /dev/null +++ b/grafana_alerts/grafana_alert_list_test.go @@ -0,0 +1,40 @@ +package grafana_alerts_test + +import ( + "fmt" + "github.com/stretchr/testify/assert" + "net/http" + "testing" +) + +func TestGrafanaAlert_ListGrafanaAlerts(t *testing.T) { + underTest, err, teardown := setupGrafanaAlertRuleTest() + assert.NoError(t, err) + defer teardown() + + mux.HandleFunc("/v1/grafana/api/v1/provisioning/alert-rules/", func(w http.ResponseWriter, r *http.Request) { + assert.Equal(t, http.MethodGet, r.Method) + w.Header().Set("Content-Type", "application/json") + fmt.Fprint(w, fixture("list_grafana_alert_res.json")) + }) + + alerts, err := underTest.ListGrafanaAlertRules() + assert.NoError(t, err) + assert.NotNil(t, alerts) + assert.Equal(t, 1, len(alerts)) +} + +func TestGrafanaAlert_ListGrafanaAlertsInternalServerError(t *testing.T) { + underTest, err, teardown := setupGrafanaAlertRuleTest() + assert.NoError(t, err) + defer teardown() + + mux.HandleFunc("/v1/grafana/api/v1/provisioning/alert-rules/", func(w http.ResponseWriter, r *http.Request) { + assert.Equal(t, http.MethodGet, r.Method) + w.WriteHeader(http.StatusInternalServerError) + }) + + alerts, err := underTest.ListGrafanaAlertRules() + assert.Error(t, err) + assert.Nil(t, alerts) +} diff --git a/grafana_alerts/testdata/fixtures/list_grafana_alert_res.json b/grafana_alerts/testdata/fixtures/list_grafana_alert_res.json new file mode 100644 index 0000000..5c58bd2 --- /dev/null +++ b/grafana_alerts/testdata/fixtures/list_grafana_alert_res.json @@ -0,0 +1,62 @@ +[ + { + "id": 123456, + "uid": "some_uid", + "folderUID": "folder_uid", + "ruleGroup": "rule_group_1", + "title": "test_alert", + "condition": "A", + "data": [ + { + "refId": "A", + "queryType": "", + "relativeTimeRange": { + "from": 0, + "to": 0 + }, + "datasourceUid": "__expr__", + "model": { + "conditions": [ + { + "evaluator": { + "params": [ + 0, + 0 + ], + "type": "gt" + }, + "operator": { + "type": "and" + }, + "query": { + "params": [] + }, + "reducer": { + "params": [], + "type": "avg" + }, + "type": "query" + } + ], + "datasource": { + "type": "__expr__", + "uid": "__expr__" + }, + "expression": "1 == 1", + "hide": false, + "intervalMs": 1000, + "maxDataPoints": 43200, + "refId": "A", + "type": "math" + } + } + ], + "updated": "2023-09-20T09:47:10Z", + "noDataState": "OK", + "execErrState": "OK", + "for": 3, + "annotations": { + "key_test": "value_test" + } + } +] \ No newline at end of file diff --git a/grafana_folders/grafana_folder_list_integration_test.go b/grafana_folders/grafana_folder_list_integration_test.go index 6479c78..048c154 100644 --- a/grafana_folders/grafana_folder_list_integration_test.go +++ b/grafana_folders/grafana_folder_list_integration_test.go @@ -9,8 +9,8 @@ func TestIntegrationGrafanaFolder_ListGrafanaFolders(t *testing.T) { underTest, err := setupGrafanaFolderIntegrationTest() if assert.NoError(t, err) { - subAccounts, err := underTest.ListGrafanaFolders() + folders, err := underTest.ListGrafanaFolders() assert.NoError(t, err) - assert.NotNil(t, subAccounts) + assert.NotNil(t, folders) } } From baf34b60476c25725e9f8ee98276b453c68ef6a6 Mon Sep 17 00:00:00 2001 From: mirii1994 Date: Wed, 27 Sep 2023 17:42:33 +0300 Subject: [PATCH 17/24] update --- grafana_alerts/client_grafana_alert.go | 17 +++++++---- grafana_alerts/client_grafana_alert_create.go | 2 +- grafana_alerts/client_grafana_alert_update.go | 15 +--------- .../grafana_alert_delete_integration_test.go | 2 ++ .../grafana_alert_get_integration_test.go | 2 ++ .../grafana_alert_update_integration_test.go | 30 +++++++++++++++++++ 6 files changed, 48 insertions(+), 20 deletions(-) create mode 100644 grafana_alerts/grafana_alert_update_integration_test.go diff --git a/grafana_alerts/client_grafana_alert.go b/grafana_alerts/client_grafana_alert.go index a61f1c5..b7421d5 100644 --- a/grafana_alerts/client_grafana_alert.go +++ b/grafana_alerts/client_grafana_alert.go @@ -78,7 +78,7 @@ func New(apiToken string, baseUrl string) (*GrafanaAlertClient, error) { return grafanaAlertClient, nil } -func validateGrafanaAlertRule(payload GrafanaAlertRule) error { +func validateGrafanaAlertRuleCreateUpdate(payload GrafanaAlertRule, isUpdate bool) error { if len(payload.Condition) == 0 { return fmt.Errorf("Field condition must be set!") } @@ -103,10 +103,6 @@ func validateGrafanaAlertRule(payload GrafanaAlertRule) error { return fmt.Errorf("Field noDataState must be set!") } - if payload.OrgID == 0 { - return fmt.Errorf("Field orgID must be set!") - } - if len(payload.RuleGroup) == 0 { return fmt.Errorf("Field ruleGroup must be set!") } @@ -115,5 +111,16 @@ func validateGrafanaAlertRule(payload GrafanaAlertRule) error { return fmt.Errorf("Field title must be set!") } + if isUpdate { + if len(payload.Uid) == 0 { + return fmt.Errorf("Field uid must be set when updating a Grafana alert rule!") + } + + } else { + if payload.OrgID == 0 { + return fmt.Errorf("Field orgID must be set!") + } + } + return nil } diff --git a/grafana_alerts/client_grafana_alert_create.go b/grafana_alerts/client_grafana_alert_create.go index ffac73d..c8ec368 100644 --- a/grafana_alerts/client_grafana_alert_create.go +++ b/grafana_alerts/client_grafana_alert_create.go @@ -15,7 +15,7 @@ const ( ) func (c *GrafanaAlertClient) CreateGrafanaAlertRule(payload GrafanaAlertRule) (*GrafanaAlertRule, error) { - err := validateGrafanaAlertRule(payload) + err := validateGrafanaAlertRuleCreateUpdate(payload, false) if err != nil { return nil, err } diff --git a/grafana_alerts/client_grafana_alert_update.go b/grafana_alerts/client_grafana_alert_update.go index 3f99c40..6e50834 100644 --- a/grafana_alerts/client_grafana_alert_update.go +++ b/grafana_alerts/client_grafana_alert_update.go @@ -15,7 +15,7 @@ const ( ) func (c *GrafanaAlertClient) UpdateGrafanaAlertRule(payload GrafanaAlertRule) error { - err := validateUpdateGrafanaAlertRule(payload) + err := validateGrafanaAlertRuleCreateUpdate(payload, true) if err != nil { return err } @@ -39,16 +39,3 @@ func (c *GrafanaAlertClient) UpdateGrafanaAlertRule(payload GrafanaAlertRule) er return err } - -func validateUpdateGrafanaAlertRule(payload GrafanaAlertRule) error { - err := validateGrafanaAlertRule(payload) - if err != nil { - return err - } - - if len(payload.Uid) == 0 { - return fmt.Errorf("Field uid must be set when updating a Grafana alert rule!") - } - - return nil -} diff --git a/grafana_alerts/grafana_alert_delete_integration_test.go b/grafana_alerts/grafana_alert_delete_integration_test.go index a1f870f..38c693d 100644 --- a/grafana_alerts/grafana_alert_delete_integration_test.go +++ b/grafana_alerts/grafana_alert_delete_integration_test.go @@ -1,6 +1,7 @@ package grafana_alerts_test import ( + "fmt" "github.com/logzio/logzio_terraform_client/test_utils" "github.com/stretchr/testify/assert" "testing" @@ -12,6 +13,7 @@ func TestIntegrationGrafanaAlert_DeleteGrafanaAlert(t *testing.T) { defer test_utils.TestDoneTimeBuffer() if assert.NoError(t, err) { createGrafanaAlert := getGrafanaAlertRuleObject() + createGrafanaAlert.Title = fmt.Sprintf("%s_%s", createGrafanaAlert.Title, "delete") grafanaAlert, err := underTest.CreateGrafanaAlertRule(createGrafanaAlert) if assert.NoError(t, err) && assert.NotNil(t, grafanaAlert) && assert.NotEmpty(t, grafanaAlert.Uid) { time.Sleep(2 * time.Second) diff --git a/grafana_alerts/grafana_alert_get_integration_test.go b/grafana_alerts/grafana_alert_get_integration_test.go index 80091d3..4846add 100644 --- a/grafana_alerts/grafana_alert_get_integration_test.go +++ b/grafana_alerts/grafana_alert_get_integration_test.go @@ -1,6 +1,7 @@ package grafana_alerts_test import ( + "fmt" "github.com/logzio/logzio_terraform_client/test_utils" "github.com/stretchr/testify/assert" "testing" @@ -14,6 +15,7 @@ func TestIntegrationGrafanaAlert_GetGrafanaAlert(t *testing.T) { if assert.NoError(t, err) { createGrafanaAlert := getGrafanaAlertRuleObject() grafanaAlert, err := underTest.CreateGrafanaAlertRule(createGrafanaAlert) + createGrafanaAlert.Title = fmt.Sprintf("%s_%s", createGrafanaAlert.Title, "get") if assert.NoError(t, err) && assert.NotNil(t, grafanaAlert) && assert.NotEmpty(t, grafanaAlert.Uid) { defer underTest.DeleteGrafanaAlertRule(grafanaAlert.Uid) time.Sleep(4 * time.Second) diff --git a/grafana_alerts/grafana_alert_update_integration_test.go b/grafana_alerts/grafana_alert_update_integration_test.go new file mode 100644 index 0000000..76f9fb5 --- /dev/null +++ b/grafana_alerts/grafana_alert_update_integration_test.go @@ -0,0 +1,30 @@ +package grafana_alerts_test + +import ( + "fmt" + "github.com/stretchr/testify/assert" + "testing" + "time" +) + +func TestIntegrationGrafanaAlert_UpdateGrafanaAlert(t *testing.T) { + underTest, err := setupGrafanaAlertIntegrationTest() + + if assert.NoError(t, err) { + createGrafanaAlert := getGrafanaAlertRuleObject() + createGrafanaAlert.Title = fmt.Sprintf("%s_%s", createGrafanaAlert.Title, "update") + grafanaAlert, err := underTest.CreateGrafanaAlertRule(createGrafanaAlert) + if assert.NoError(t, err) && assert.NotNil(t, grafanaAlert) && assert.NotEmpty(t, grafanaAlert.Uid) { + defer underTest.DeleteGrafanaAlertRule(grafanaAlert.Uid) + time.Sleep(time.Second * 2) + createGrafanaAlert.Condition = "B" + err = underTest.UpdateGrafanaAlertRule(*grafanaAlert) + assert.NoError(t, err) + // verify that the update was made + time.Sleep(time.Second * 4) + getFolder, err := underTest.GetGrafanaAlertRule(grafanaAlert.Uid) + assert.NoError(t, err) + assert.Equal(t, createGrafanaAlert.Condition, getFolder.Condition) + } + } +} From cdd3f27d6b6c17732cb16f399c5e937b23a2ccd3 Mon Sep 17 00:00:00 2001 From: mirii1994 Date: Thu, 28 Sep 2023 11:56:48 +0300 Subject: [PATCH 18/24] update fix, tests, readme, refactor ioutils to io --- grafana_alerts/README.md | 39 ++++++++++++ .../grafana_alert_update_integration_test.go | 17 +++++- grafana_alerts/grafana_alert_update_test.go | 61 +++++++++++++++++++ utils.go | 3 +- 4 files changed, 116 insertions(+), 4 deletions(-) create mode 100644 grafana_alerts/README.md create mode 100644 grafana_alerts/grafana_alert_update_test.go diff --git a/grafana_alerts/README.md b/grafana_alerts/README.md new file mode 100644 index 0000000..571804f --- /dev/null +++ b/grafana_alerts/README.md @@ -0,0 +1,39 @@ +# Grafana Alert + +To create a Grafana alert: + +```go +data := grafana_alerts.GrafanaAlertQuery{ + DatasourceUid: "__expr__", + Model: json.RawMessage(`{"conditions":[{"evaluator":{"params":[0,0],"type":"gt"},"operator":{"type":"and"},"query":{"params":[]},"reducer":{"params":[],"type":"avg"},"type":"query"}],"datasource":{"type":"__expr__","uid":"__expr__"},"expression":"1 == 1","hide":false,"intervalMs":1000,"maxDataPoints":43200,"refId":"A","type":"math"}`), + RefId: "A", + RelativeTimeRange: grafana_alerts.RelativeTimeRangeObj{ + From: 0, + To: 0, + }, +} + +createGrafanaAlert := grafana_alerts.GrafanaAlertRule{ + Annotations: map[string]string{"key_test": "value_test"}, + Condition: "A", + Data: []*grafana_alerts.GrafanaAlertQuery{&data}, + FolderUID: os.Getenv(envGrafanaFolderUid), + NoDataState: grafana_alerts.NoDataOk, + ExecErrState: grafana_alerts.ErrOK, + OrgID: 1, + RuleGroup: "rule_group_1", + Title: "test_alert", + For: int64(3), +} + +client, err := grafana_alerts.New(apiToken, server.URL) +grafanaAlert, err := client.CreateGrafanaAlertRule(createGrafanaAlert) +``` + +| function | func name | +|---------------------|------------------------------------------------------------------------------------------------------------| +| create alert | `func (c *GrafanaAlertClient) CreateGrafanaAlertRule(payload GrafanaAlertRule) (*GrafanaAlertRule, error)` | +| update alert | `func (c *GrafanaAlertClient) UpdateGrafanaAlertRule(payload GrafanaAlertRule) error` | +| delete alert by uid | `func (c *GrafanaAlertClient) DeleteGrafanaAlertRule(uid string) error` | +| get alert by uid | `func (c *GrafanaAlertClient) GetGrafanaAlertRule(uid string) (*GrafanaAlertRule, error)` | +| list alerts | `func (c *GrafanaAlertClient) ListGrafanaAlertRules() ([]GrafanaAlertRule, error)` | diff --git a/grafana_alerts/grafana_alert_update_integration_test.go b/grafana_alerts/grafana_alert_update_integration_test.go index 76f9fb5..1bdaa25 100644 --- a/grafana_alerts/grafana_alert_update_integration_test.go +++ b/grafana_alerts/grafana_alert_update_integration_test.go @@ -17,14 +17,25 @@ func TestIntegrationGrafanaAlert_UpdateGrafanaAlert(t *testing.T) { if assert.NoError(t, err) && assert.NotNil(t, grafanaAlert) && assert.NotEmpty(t, grafanaAlert.Uid) { defer underTest.DeleteGrafanaAlertRule(grafanaAlert.Uid) time.Sleep(time.Second * 2) - createGrafanaAlert.Condition = "B" + grafanaAlert.Title = "changed" err = underTest.UpdateGrafanaAlertRule(*grafanaAlert) assert.NoError(t, err) // verify that the update was made time.Sleep(time.Second * 4) - getFolder, err := underTest.GetGrafanaAlertRule(grafanaAlert.Uid) + getAlert, err := underTest.GetGrafanaAlertRule(grafanaAlert.Uid) assert.NoError(t, err) - assert.Equal(t, createGrafanaAlert.Condition, getFolder.Condition) + assert.Equal(t, grafanaAlert.Title, getAlert.Title) } } } + +func TestIntegrationGrafanaAlert_UpdateGrafanaAlertIdNotFound(t *testing.T) { + underTest, err := setupGrafanaAlertIntegrationTest() + + if assert.NoError(t, err) { + request := getGrafanaAlertRuleObject() + request.Uid = "not-exist" + err = underTest.UpdateGrafanaAlertRule(request) + assert.Error(t, err) + } +} diff --git a/grafana_alerts/grafana_alert_update_test.go b/grafana_alerts/grafana_alert_update_test.go new file mode 100644 index 0000000..398bf15 --- /dev/null +++ b/grafana_alerts/grafana_alert_update_test.go @@ -0,0 +1,61 @@ +package grafana_alerts_test + +import ( + "encoding/json" + "github.com/logzio/logzio_terraform_client/grafana_alerts" + "github.com/stretchr/testify/assert" + "io" + "net/http" + "testing" +) + +func TestGrafanaAlert_UpdateGrafanaAlert(t *testing.T) { + underTest, err, teardown := setupGrafanaAlertRuleTest() + assert.NoError(t, err) + defer teardown() + + alertUid := "some-uid" + + mux.HandleFunc("/v1/grafana/api/v1/provisioning/alert-rules/", func(w http.ResponseWriter, r *http.Request) { + assert.Equal(t, http.MethodPut, r.Method) + assert.Contains(t, r.URL.String(), alertUid) + jsonBytes, _ := io.ReadAll(r.Body) + var target grafana_alerts.GrafanaAlertRule + err = json.Unmarshal(jsonBytes, &target) + assert.NoError(t, err) + assert.NotNil(t, target) + assert.NotEmpty(t, target.Title) + assert.Equal(t, alertUid, target.Uid) + }) + + updateAlert := getGrafanaAlertRuleObject() + updateAlert.Uid = alertUid + err = underTest.UpdateGrafanaAlertRule(updateAlert) + assert.NoError(t, err) +} + +func TestGrafanaAlert_UpdateGrafanaAlertInternalServerError(t *testing.T) { + underTest, err, teardown := setupGrafanaAlertRuleTest() + assert.NoError(t, err) + defer teardown() + + alertUid := "client_test" + + mux.HandleFunc("/v1/grafana/api/v1/provisioning/alert-rules/", func(w http.ResponseWriter, r *http.Request) { + assert.Equal(t, http.MethodPut, r.Method) + assert.Contains(t, r.URL.String(), alertUid) + jsonBytes, _ := io.ReadAll(r.Body) + var target grafana_alerts.GrafanaAlertRule + err = json.Unmarshal(jsonBytes, &target) + assert.NoError(t, err) + assert.NotNil(t, target) + assert.NotEmpty(t, target.Title) + assert.Equal(t, alertUid, target.Uid) + w.WriteHeader(http.StatusInternalServerError) + }) + + updateAlert := getGrafanaAlertRuleObject() + updateAlert.Uid = alertUid + err = underTest.UpdateGrafanaAlertRule(updateAlert) + assert.Error(t, err) +} diff --git a/utils.go b/utils.go index 04d9cd3..e5fbff9 100644 --- a/utils.go +++ b/utils.go @@ -6,6 +6,7 @@ import ( "fmt" "github.com/avast/retry-go" "github.com/logzio/logzio_terraform_client/client" + "io" "io/ioutil" "net/http" "strings" @@ -101,7 +102,7 @@ func CallLogzioApi(logzioCall LogzioApiCallDetails) ([]byte, error) { return err } - jsonBytes, _ = ioutil.ReadAll(resp.Body) + jsonBytes, _ = io.ReadAll(resp.Body) if !CheckValidStatus(resp, logzioCall.SuccessCodes) { if resp.StatusCode == logzioCall.NotFoundCode { return fmt.Errorf("API call %s failed with missing %s %d, data: %s", From 7df1557635783c71a350250d72407fa2f2ba0e19 Mon Sep 17 00:00:00 2001 From: mirii1994 Date: Mon, 2 Oct 2023 16:58:50 +0300 Subject: [PATCH 19/24] add IsPaused --- grafana_alerts/client_grafana_alert.go | 1 + 1 file changed, 1 insertion(+) diff --git a/grafana_alerts/client_grafana_alert.go b/grafana_alerts/client_grafana_alert.go index b7421d5..ba196ca 100644 --- a/grafana_alerts/client_grafana_alert.go +++ b/grafana_alerts/client_grafana_alert.go @@ -48,6 +48,7 @@ type GrafanaAlertRule struct { Title string `json:"title"` // Required Uid string `json:"uid,omitempty"` Updated time.Time `json:"updated"` + IsPaused bool `json:"isPaused"` } type GrafanaAlertQuery struct { From f00203b5274ff8ee2d958f1b203fd9396b32b351 Mon Sep 17 00:00:00 2001 From: mirii1994 Date: Sun, 15 Oct 2023 18:46:55 +0300 Subject: [PATCH 20/24] add note about for field --- grafana_alerts/client_grafana_alert.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/grafana_alerts/client_grafana_alert.go b/grafana_alerts/client_grafana_alert.go index ba196ca..e6dc359 100644 --- a/grafana_alerts/client_grafana_alert.go +++ b/grafana_alerts/client_grafana_alert.go @@ -38,7 +38,7 @@ type GrafanaAlertRule struct { Data []*GrafanaAlertQuery `json:"data"` // Required ExecErrState ExecErrState `json:"execErrState"` // Required FolderUID string `json:"folderUID"` // Required - For int64 `json:"for"` // Required + For int64 `json:"for"` // Required, representing nanosecondss Id int64 `json:"id,omitempty"` Labels map[string]string `json:"labels,omitempty"` NoDataState NoDataState `json:"noDataState"` // Required From 0d166a2dd9c451b92e70514161fd2317d0d264e0 Mon Sep 17 00:00:00 2001 From: mirii1994 Date: Mon, 16 Oct 2023 10:30:09 +0300 Subject: [PATCH 21/24] update readme --- README.md | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/README.md b/README.md index f183715..1f721e2 100644 --- a/README.md +++ b/README.md @@ -103,3 +103,8 @@ The library currently supports the following API endpoints: - Add subaccount support + + +### Trademark Disclaimer + +Terraform is a trademark of HashiCorp, Inc. From 244d56911553101e7ab36e332360e623eead0306 Mon Sep 17 00:00:00 2001 From: mirii1994 Date: Mon, 16 Oct 2023 10:32:56 +0300 Subject: [PATCH 22/24] update changelog --- README.md | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index 1f721e2..820e96b 100644 --- a/README.md +++ b/README.md @@ -34,18 +34,20 @@ The library currently supports the following API endpoints: ### Changelog +- v1.18.0 + - Add [Grafana Alert Rules API](https://docs.logz.io/api/#tag/Grafana-alerting-provisioning) support. - v1.17.0 - Add Grafana Folders API. - Remove deprecated `alerts` (v1). - v1.16.0 - Add [Grafana Dashboards API](https://docs.logz.io/api/#operation/createDashboard) support. -- v1.15.0 - - Add [S3 Fetcher](https://docs.logz.io/api/#tag/Connect-to-S3-Buckets).
Exapnd to check old versions +- v1.15.0 + - Add [S3 Fetcher](https://docs.logz.io/api/#tag/Connect-to-S3-Buckets). - v1.14.0 - `alerts_v2` - support new field `schedule` - v1.13.1 From b717e7756b897ff8a2f2783a9f0cd6532153b290 Mon Sep 17 00:00:00 2001 From: mirii1994 Date: Mon, 16 Oct 2023 10:34:51 +0300 Subject: [PATCH 23/24] fix typo --- grafana_alerts/client_grafana_alert.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/grafana_alerts/client_grafana_alert.go b/grafana_alerts/client_grafana_alert.go index e6dc359..2eb8101 100644 --- a/grafana_alerts/client_grafana_alert.go +++ b/grafana_alerts/client_grafana_alert.go @@ -38,7 +38,7 @@ type GrafanaAlertRule struct { Data []*GrafanaAlertQuery `json:"data"` // Required ExecErrState ExecErrState `json:"execErrState"` // Required FolderUID string `json:"folderUID"` // Required - For int64 `json:"for"` // Required, representing nanosecondss + For int64 `json:"for"` // Required, representing nanoseconds Id int64 `json:"id,omitempty"` Labels map[string]string `json:"labels,omitempty"` NoDataState NoDataState `json:"noDataState"` // Required From b934091fcc79427462a3845636757fa78ab7cbd7 Mon Sep 17 00:00:00 2001 From: mirii1994 Date: Mon, 16 Oct 2023 11:01:31 +0300 Subject: [PATCH 24/24] update workflows --- .github/workflows/test-daily.yml | 2 +- .github/workflows/tests.yml | 1 + 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/.github/workflows/test-daily.yml b/.github/workflows/test-daily.yml index b0642b6..9d6c332 100644 --- a/.github/workflows/test-daily.yml +++ b/.github/workflows/test-daily.yml @@ -23,7 +23,7 @@ jobs: AZURE_CONTAINER_NAME: ${{ secrets.AZURE_CONTAINER_NAME }} AZURE_TENANT_ID: ${{ secrets.AZURE_TENANT_ID }} METRICS_FOLDER_ID: ${{ secrets.METRICS_FOLDER_ID }} - + GRAFANA_FOLDER_UID: ${{ secrets.GRAFANA_FOLDER_UID }} GO111MODULE: on name: Test runs-on: ubuntu-20.04 diff --git a/.github/workflows/tests.yml b/.github/workflows/tests.yml index c12907b..f44302a 100644 --- a/.github/workflows/tests.yml +++ b/.github/workflows/tests.yml @@ -20,6 +20,7 @@ jobs: AZURE_CONTAINER_NAME: ${{ secrets.AZURE_CONTAINER_NAME }} AZURE_TENANT_ID: ${{ secrets.AZURE_TENANT_ID }} METRICS_FOLDER_ID: ${{ secrets.METRICS_FOLDER_ID }} + GRAFANA_FOLDER_UID: ${{ secrets.GRAFANA_FOLDER_UID }} GO111MODULE: on name: Test runs-on: ubuntu-20.04