Skip to content

Commit

Permalink
Fix scheme required for webhook url in amtool (#3509)
Browse files Browse the repository at this point in the history
* Fix scheme required for webhook url in amtool

This commit fixes issue #3505 where amtool would fail with
"error: scheme required for webhook url" when using amtool
with --alertmanager.url.

The issue here is that UnmarshalYaml for WebhookConfig checks
if the scheme is present when c.URL is non-nil. However,
UnmarshalYaml for SecretURL returns a non-nil, default value
url.URL{} if the response from api/v2/status contains <secret>
as the webhook URL.

Signed-off-by: George Robinson <george.robinson@grafana.com>

* Add test for config routes test

Signed-off-by: George Robinson <george.robinson@grafana.com>

---------

Signed-off-by: George Robinson <george.robinson@grafana.com>
  • Loading branch information
grobinson-grafana authored Sep 5, 2023
1 parent 0ac174a commit 6ce841c
Show file tree
Hide file tree
Showing 3 changed files with 88 additions and 5 deletions.
5 changes: 0 additions & 5 deletions config/notifiers.go
Original file line number Diff line number Diff line change
Expand Up @@ -503,11 +503,6 @@ func (c *WebhookConfig) UnmarshalYAML(unmarshal func(interface{}) error) error {
if c.URL != nil && c.URLFile != "" {
return fmt.Errorf("at most one of url & url_file must be configured")
}
if c.URL != nil {
if c.URL.Scheme != "https" && c.URL.Scheme != "http" {
return fmt.Errorf("scheme required for webhook url")
}
}
return nil
}

Expand Down
22 changes: 22 additions & 0 deletions test/cli/acceptance.go
Original file line number Diff line number Diff line change
Expand Up @@ -658,6 +658,28 @@ func (am *Alertmanager) UpdateConfig(conf string) {
}
}

func (am *Alertmanager) ShowRoute() ([]byte, error) {
return am.showRouteCommand()
}

func (am *Alertmanager) showRouteCommand() ([]byte, error) {
amURLFlag := "--alertmanager.url=" + am.getURL("/")
args := []string{amURLFlag, "config", "routes", "show"}
cmd := exec.Command(amtool, args...)
return cmd.CombinedOutput()
}

func (am *Alertmanager) TestRoute() ([]byte, error) {
return am.testRouteCommand()
}

func (am *Alertmanager) testRouteCommand() ([]byte, error) {
amURLFlag := "--alertmanager.url=" + am.getURL("/")
args := []string{amURLFlag, "config", "routes", "test"}
cmd := exec.Command(amtool, args...)
return cmd.CombinedOutput()
}

func (am *Alertmanager) getURL(path string) string {
return fmt.Sprintf("http://%s%s%s", am.apiAddr, am.opts.RoutePrefix, path)
}
66 changes: 66 additions & 0 deletions test/cli/acceptance/cli_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -168,3 +168,69 @@ receivers:
t.Errorf("Incorrect number of silences queried, expected: %v, actual: %v", expectedSils, len(sils))
}
}

func TestRoutesShow(t *testing.T) {
t.Parallel()

conf := `
route:
receiver: "default"
group_by: [alertname]
group_wait: 1s
group_interval: 1s
repeat_interval: 1ms
receivers:
- name: "default"
webhook_configs:
- url: 'http://%s'
send_resolved: true
`

at := NewAcceptanceTest(t, &AcceptanceOpts{
Tolerance: 1 * time.Second,
})
co := at.Collector("webhook")
wh := NewWebhook(co)

amc := at.AlertmanagerCluster(fmt.Sprintf(conf, wh.Address()), 1)
require.NoError(t, amc.Start())
defer amc.Terminate()

am := amc.Members()[0]
_, err := am.ShowRoute()
require.NoError(t, err)
}

func TestRoutesTest(t *testing.T) {
t.Parallel()

conf := `
route:
receiver: "default"
group_by: [alertname]
group_wait: 1s
group_interval: 1s
repeat_interval: 1ms
receivers:
- name: "default"
webhook_configs:
- url: 'http://%s'
send_resolved: true
`

at := NewAcceptanceTest(t, &AcceptanceOpts{
Tolerance: 1 * time.Second,
})
co := at.Collector("webhook")
wh := NewWebhook(co)

amc := at.AlertmanagerCluster(fmt.Sprintf(conf, wh.Address()), 1)
require.NoError(t, amc.Start())
defer amc.Terminate()

am := amc.Members()[0]
_, err := am.TestRoute()
require.NoError(t, err)
}

0 comments on commit 6ce841c

Please sign in to comment.