mirror of
https://github.com/prometheus/alertmanager
synced 2025-01-21 21:42:53 +00:00
a6d10bd5bc
* Copy latest golangci-lint files from Prometheus Signed-off-by: Matthias Loibl <mail@matthiasloibl.com> * Use grafana/regexp over stdlib regexp Signed-off-by: Matthias Loibl <mail@matthiasloibl.com> * Fix typos in comments Signed-off-by: Matthias Loibl <mail@matthiasloibl.com> * Fix goimports complains in import sorting Signed-off-by: Matthias Loibl <mail@matthiasloibl.com> * gofumpt all Go files Signed-off-by: Matthias Loibl <mail@matthiasloibl.com> * Update naming to comply with revive linter Signed-off-by: Matthias Loibl <mail@matthiasloibl.com> * config: Fix error messages to be lower case Signed-off-by: Matthias Loibl <mail@matthiasloibl.com> * test/cli: Fix error messages to be lower case Signed-off-by: Matthias Loibl <mail@matthiasloibl.com> * .golangci.yaml: Remove obsolete space Signed-off-by: Matthias Loibl <mail@matthiasloibl.com> * config: Fix expected victorOps error Signed-off-by: Matthias Loibl <mail@matthiasloibl.com> * Use stdlib regexp Signed-off-by: Matthias Loibl <mail@matthiasloibl.com> * Clean up Go modules Signed-off-by: Matthias Loibl <mail@matthiasloibl.com>
93 lines
2.2 KiB
Go
93 lines
2.2 KiB
Go
// Copyright 2018 Prometheus Team
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
package nflogpb
|
|
|
|
import (
|
|
"testing"
|
|
)
|
|
|
|
func TestIsFiringSubset(t *testing.T) {
|
|
e := &Entry{
|
|
FiringAlerts: []uint64{1, 2, 3},
|
|
}
|
|
|
|
tests := []struct {
|
|
subset map[uint64]struct{}
|
|
expected bool
|
|
}{
|
|
{newSubset(), true}, // empty subset
|
|
{newSubset(1), true},
|
|
{newSubset(2), true},
|
|
{newSubset(3), true},
|
|
{newSubset(1, 2), true},
|
|
{newSubset(1, 2), true},
|
|
{newSubset(1, 2, 3), true},
|
|
{newSubset(4), false},
|
|
{newSubset(1, 5), false},
|
|
{newSubset(1, 2, 3, 6), false},
|
|
}
|
|
|
|
for _, test := range tests {
|
|
if result := e.IsFiringSubset(test.subset); result != test.expected {
|
|
t.Errorf("Expected %t, got %t for subset %v", test.expected, result, elements(test.subset))
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestIsResolvedSubset(t *testing.T) {
|
|
e := &Entry{
|
|
ResolvedAlerts: []uint64{1, 2, 3},
|
|
}
|
|
|
|
tests := []struct {
|
|
subset map[uint64]struct{}
|
|
expected bool
|
|
}{
|
|
{newSubset(), true}, // empty subset
|
|
{newSubset(1), true},
|
|
{newSubset(2), true},
|
|
{newSubset(3), true},
|
|
{newSubset(1, 2), true},
|
|
{newSubset(1, 2), true},
|
|
{newSubset(1, 2, 3), true},
|
|
{newSubset(4), false},
|
|
{newSubset(1, 5), false},
|
|
{newSubset(1, 2, 3, 6), false},
|
|
}
|
|
|
|
for _, test := range tests {
|
|
if result := e.IsResolvedSubset(test.subset); result != test.expected {
|
|
t.Errorf("Expected %t, got %t for subset %v", test.expected, result, elements(test.subset))
|
|
}
|
|
}
|
|
}
|
|
|
|
func newSubset(elements ...uint64) map[uint64]struct{} {
|
|
subset := make(map[uint64]struct{})
|
|
for _, el := range elements {
|
|
subset[el] = struct{}{}
|
|
}
|
|
|
|
return subset
|
|
}
|
|
|
|
func elements(m map[uint64]struct{}) []uint64 {
|
|
els := make([]uint64, 0, len(m))
|
|
for k := range m {
|
|
els = append(els, k)
|
|
}
|
|
|
|
return els
|
|
}
|