From ec88d7d85ad9807d79c71bfcac6c61cceed62501 Mon Sep 17 00:00:00 2001 From: Feargus O'Gorman Date: Thu, 2 Nov 2023 09:55:51 +0000 Subject: [PATCH] alert - add runbookLinks and alertTriageDashboards (#56) Adding parameters that are present in the Wavefront API but not in this client: - runbookLinks - alertTriageDashboards --- alert.go | 12 ++++++++++++ alert_test.go | 18 +++++++++++++++--- 2 files changed, 27 insertions(+), 3 deletions(-) diff --git a/alert.go b/alert.go index d31f79e..4075d51 100644 --- a/alert.go +++ b/alert.go @@ -11,6 +11,12 @@ const ( AlertTypeClassic = "CLASSIC" ) +type AlertTriageDashboard struct { + DashboardId string `json:"dashboardId"` + Parameters map[string]map[string]string `json:"parameters"` + Description string `json:"description"` +} + // Alert represents a single Wavefront Alert type Alert struct { // Name is the name given to an Alert @@ -81,6 +87,12 @@ type Alert struct { // Include obsolete metrics in alert query IncludeObsoleteMetrics bool `json:"includeObsoleteMetrics,omitempty"` + + // User-supplied runbook links for this alert + RunbookLinks []string `json:"runbookLinks"` + + // User-supplied dashboard and parameters to create dashboard links + AlertTriageDashboards []AlertTriageDashboard `json:"alertTriageDashboards"` } type SourceLabelPair struct { diff --git a/alert_test.go b/alert_test.go index 4077840..87f4a7c 100644 --- a/alert_test.go +++ b/alert_test.go @@ -54,7 +54,7 @@ func (m *MockCrudAlertClient) Do(req *http.Request) (io.ReadCloser, error) { return testDo(m.T, req, "./fixtures/create-alert-response.json", m.method, &Alert{}) } -func TestAlerts_CreateUpdateDeleteAlert(t *testing.T) { +func TestAlerts_CRUDAlert(t *testing.T) { assert := asserts.New(t) baseurl, _ := url.Parse("http://testing.wavefront.com") a := &Alerts{ @@ -81,13 +81,19 @@ func TestAlerts_CreateUpdateDeleteAlert(t *testing.T) { AdditionalInfo: "please resolve this alert", Tags: []string{"mytag1", "mytag2"}, } + var readAlert Alert + alertId := "1234" // Update should fail because no ID is set assert.Error(a.Update(&alert)) a.client.(*MockCrudAlertClient).method = "POST" assert.NoError(a.Create(&alert)) - assert.Equal("1234", *alert.ID) + assert.Equal(alertId, *alert.ID) + + a.client.(*MockCrudAlertClient).method = "GET" + readAlert.ID = &alertId + assert.NoError(a.Get(&readAlert)) a.client.(*MockCrudAlertClient).method = "PUT" assert.NoError(a.Update(&alert)) @@ -130,13 +136,19 @@ func TestMultiThresholdAlerts_CreateUpdateDeleteAlert(t *testing.T) { AdditionalInfo: "please resolve this alert", Tags: []string{"mytag1", "mytag2"}, } + var readAlert Alert + alertId := "1234" // Update should fail because no ID is set assert.Error(a.Update(&alert)) a.client.(*MockCrudAlertClient).method = "POST" assert.NoError(a.Create(&alert)) - assert.Equal("1234", *alert.ID) + assert.Equal(alertId, *alert.ID) + + a.client.(*MockCrudAlertClient).method = "GET" + readAlert.ID = &alertId + assert.NoError(a.Get(&readAlert)) a.client.(*MockCrudAlertClient).method = "PUT" assert.NoError(a.Update(&alert))