generated from hashicorp/terraform-provider-scaffolding
-
Notifications
You must be signed in to change notification settings - Fork 3
/
alert_test.go
156 lines (152 loc) · 7.27 KB
/
alert_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
package acc_tests
import (
"github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource"
"regexp"
"testing"
)
const (
notificationChannelConf = `
resource "pfptmeta_notification_channel" "channel" {
name = "mail-channel"
email_config {
recipients = ["user1@example.com", "user2@example.com"]
}
}`
spikeConditionAlert = `
resource "pfptmeta_alert" "alert" {
name = "alert-name"
description = "alert-description"
channels = [pfptmeta_notification_channel.channel.id]
group_by = "src_id"
notify_message = "metaport disconnected"
query_text = "event:keepalive AND src_type:MetaPort"
source_type = "traffic_audit"
spike_condition {
spike_ratio = 100
spike_type = "down"
time_diff = 5
}
window = 5
}`
spikeConditionAlertStep2 = `
resource "pfptmeta_alert" "alert" {
name = "alert-name1"
description = "alert-description1"
channels = [pfptmeta_notification_channel.channel.id]
group_by = "src_id"
notify_message = "metaport disconnected1"
query_text = "event:keepalive"
source_type = "traffic_audit"
spike_condition {
spike_ratio = 99
spike_type = "down"
time_diff = 60
}
window = 60
}`
thresholdConditionAlert = `
resource "pfptmeta_alert" "alert2" {
name = "alert-name1"
description = "alert-description1"
channels = [pfptmeta_notification_channel.channel.id]
notify_message = "device onboarded"
query_text = "action:CREATE AND resource_type:Device"
source_type = "api_audit"
threshold_condition {
formula = "count"
op = "greater"
threshold = 0
}
window = 60
}`
alertDataSource = `
data "pfptmeta_alert" "alert" {
id = pfptmeta_alert.alert.id
}
`
)
func TestAccResourceAlert(t *testing.T) {
resource.ParallelTest(t, resource.TestCase{
PreCheck: func() { testAccPreCheck(t) },
ProviderFactories: providerFactories,
CheckDestroy: validateResourceDestroyed("alert", "v1/alerts"),
Steps: []resource.TestStep{
{
Config: notificationChannelConf + spikeConditionAlert,
Check: resource.ComposeTestCheckFunc(
resource.TestMatchResourceAttr("pfptmeta_alert.alert", "id", regexp.MustCompile("^alr-.+$")),
resource.TestCheckResourceAttr("pfptmeta_alert.alert", "name", "alert-name"),
resource.TestCheckResourceAttr("pfptmeta_alert.alert", "description", "alert-description"),
resource.TestMatchResourceAttr("pfptmeta_alert.alert", "channels.0", regexp.MustCompile("^nch-.+$")),
resource.TestCheckResourceAttr("pfptmeta_alert.alert", "group_by", "src_id"),
resource.TestCheckResourceAttr("pfptmeta_alert.alert", "notify_message", "metaport disconnected"),
resource.TestCheckResourceAttr("pfptmeta_alert.alert", "query_text", "event:keepalive AND src_type:MetaPort"),
resource.TestCheckResourceAttr("pfptmeta_alert.alert", "source_type", "traffic_audit"),
resource.TestCheckResourceAttr("pfptmeta_alert.alert", "spike_condition.0.spike_ratio", "100"),
resource.TestCheckResourceAttr("pfptmeta_alert.alert", "spike_condition.0.spike_type", "down"),
resource.TestCheckResourceAttr("pfptmeta_alert.alert", "spike_condition.0.time_diff", "5"),
resource.TestCheckResourceAttr("pfptmeta_alert.alert", "window", "5"),
),
},
{
Config: notificationChannelConf + spikeConditionAlertStep2,
Check: resource.ComposeTestCheckFunc(
resource.TestMatchResourceAttr("pfptmeta_alert.alert", "id", regexp.MustCompile("^alr-.+$")),
resource.TestCheckResourceAttr("pfptmeta_alert.alert", "name", "alert-name1"),
resource.TestCheckResourceAttr("pfptmeta_alert.alert", "description", "alert-description1"),
resource.TestMatchResourceAttr("pfptmeta_alert.alert", "channels.0", regexp.MustCompile("^nch-.+$")),
resource.TestCheckResourceAttr("pfptmeta_alert.alert", "group_by", "src_id"),
resource.TestCheckResourceAttr("pfptmeta_alert.alert", "notify_message", "metaport disconnected1"),
resource.TestCheckResourceAttr("pfptmeta_alert.alert", "query_text", "event:keepalive"),
resource.TestCheckResourceAttr("pfptmeta_alert.alert", "source_type", "traffic_audit"),
resource.TestCheckResourceAttr("pfptmeta_alert.alert", "spike_condition.0.spike_ratio", "99"),
resource.TestCheckResourceAttr("pfptmeta_alert.alert", "spike_condition.0.spike_type", "down"),
resource.TestCheckResourceAttr("pfptmeta_alert.alert", "spike_condition.0.time_diff", "60"),
resource.TestCheckResourceAttr("pfptmeta_alert.alert", "window", "60"),
),
},
{
Config: notificationChannelConf + thresholdConditionAlert,
Check: resource.ComposeTestCheckFunc(
resource.TestMatchResourceAttr("pfptmeta_alert.alert2", "id", regexp.MustCompile("^alr-.+$")),
resource.TestCheckResourceAttr("pfptmeta_alert.alert2", "name", "alert-name1"),
resource.TestCheckResourceAttr("pfptmeta_alert.alert2", "description", "alert-description1"),
resource.TestMatchResourceAttr("pfptmeta_alert.alert2", "channels.0", regexp.MustCompile("^nch-.+$")),
resource.TestCheckResourceAttr("pfptmeta_alert.alert2", "notify_message", "device onboarded"),
resource.TestCheckResourceAttr("pfptmeta_alert.alert2", "query_text", "action:CREATE AND resource_type:Device"),
resource.TestCheckResourceAttr("pfptmeta_alert.alert2", "source_type", "api_audit"),
resource.TestCheckResourceAttr("pfptmeta_alert.alert2", "threshold_condition.0.formula", "count"),
resource.TestCheckResourceAttr("pfptmeta_alert.alert2", "threshold_condition.0.op", "greater"),
resource.TestCheckResourceAttr("pfptmeta_alert.alert2", "threshold_condition.0.threshold", "0"),
resource.TestCheckResourceAttr("pfptmeta_alert.alert2", "window", "60"),
),
},
},
})
}
func TestAccDataSourceAlert(t *testing.T) {
resource.Test(t, resource.TestCase{
PreCheck: func() { testAccPreCheck(t) },
ProviderFactories: providerFactories,
CheckDestroy: validateResourceDestroyed("alert", "v1/alerts"),
Steps: []resource.TestStep{
{
Config: notificationChannelConf + spikeConditionAlert + alertDataSource,
Check: resource.ComposeTestCheckFunc(
resource.TestMatchResourceAttr("data.pfptmeta_alert.alert", "id", regexp.MustCompile("^alr-.+$")),
resource.TestCheckResourceAttr("data.pfptmeta_alert.alert", "name", "alert-name"),
resource.TestCheckResourceAttr("data.pfptmeta_alert.alert", "description", "alert-description"),
resource.TestMatchResourceAttr("data.pfptmeta_alert.alert", "channels.0", regexp.MustCompile("^nch-.+$")),
resource.TestCheckResourceAttr("data.pfptmeta_alert.alert", "group_by", "src_id"),
resource.TestCheckResourceAttr("data.pfptmeta_alert.alert", "notify_message", "metaport disconnected"),
resource.TestCheckResourceAttr("data.pfptmeta_alert.alert", "query_text", "event:keepalive AND src_type:MetaPort"),
resource.TestCheckResourceAttr("data.pfptmeta_alert.alert", "source_type", "traffic_audit"),
resource.TestCheckResourceAttr("data.pfptmeta_alert.alert", "spike_condition.0.spike_ratio", "100"),
resource.TestCheckResourceAttr("data.pfptmeta_alert.alert", "spike_condition.0.spike_type", "down"),
resource.TestCheckResourceAttr("data.pfptmeta_alert.alert", "spike_condition.0.time_diff", "5"),
resource.TestCheckResourceAttr("data.pfptmeta_alert.alert", "window", "5"),
),
},
},
})
}