mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2025-01-22 16:20:40 +01:00
9edeecabc8
This makes easier to read and debug these tests. This also reduces test lines count by 15% from 3K to 2.5K . See https://itnext.io/f-tests-as-a-replacement-for-table-driven-tests-in-go-8814a8b19e9e . While at it, consistently use t.Fatal* instead of t.Error*, since t.Error* usually leads to more complicated and fragile tests, while it doesn't bring any practical benefits over t.Fatal*.
149 lines
3.3 KiB
Go
149 lines
3.3 KiB
Go
package docker
|
|
|
|
import (
|
|
"reflect"
|
|
"sort"
|
|
"testing"
|
|
|
|
"github.com/VictoriaMetrics/VictoriaMetrics/lib/promscrape/discoveryutils"
|
|
"github.com/VictoriaMetrics/VictoriaMetrics/lib/promutils"
|
|
)
|
|
|
|
func TestAddNetworkLabels(t *testing.T) {
|
|
f := func(networks []network, labelssExpected []*promutils.Labels) {
|
|
t.Helper()
|
|
|
|
networkLabels := getNetworkLabelsByNetworkID(networks)
|
|
|
|
var networkIDs []string
|
|
for networkID := range networkLabels {
|
|
networkIDs = append(networkIDs, networkID)
|
|
}
|
|
sort.Strings(networkIDs)
|
|
var labelss []*promutils.Labels
|
|
for _, networkID := range networkIDs {
|
|
labelss = append(labelss, networkLabels[networkID])
|
|
}
|
|
discoveryutils.TestEqualLabelss(t, labelss, labelssExpected)
|
|
}
|
|
|
|
// ingress network
|
|
networks := []network{
|
|
{
|
|
ID: "qs0hog6ldlei9ct11pr3c77v1",
|
|
Ingress: true,
|
|
Scope: "swarm",
|
|
Name: "ingress",
|
|
Labels: map[string]string{
|
|
"key1": "value1",
|
|
},
|
|
},
|
|
}
|
|
labelssExpected := []*promutils.Labels{
|
|
promutils.NewLabelsFromMap(map[string]string{
|
|
"__meta_docker_network_id": "qs0hog6ldlei9ct11pr3c77v1",
|
|
"__meta_docker_network_ingress": "true",
|
|
"__meta_docker_network_internal": "false",
|
|
"__meta_docker_network_label_key1": "value1",
|
|
"__meta_docker_network_name": "ingress",
|
|
"__meta_docker_network_scope": "swarm",
|
|
}),
|
|
}
|
|
f(networks, labelssExpected)
|
|
}
|
|
|
|
func TestParseNetworks(t *testing.T) {
|
|
f := func(data string, resultExpected []network) {
|
|
t.Helper()
|
|
|
|
result, err := parseNetworks([]byte(data))
|
|
if err != nil {
|
|
t.Fatalf("parseNetworks() error: %s", err)
|
|
}
|
|
if !reflect.DeepEqual(result, resultExpected) {
|
|
t.Fatalf("unexpected networks\ngot\n%v\nwant\n%v", result, resultExpected)
|
|
}
|
|
}
|
|
|
|
// parse two networks
|
|
data := `[
|
|
{
|
|
"Name": "ingress",
|
|
"Id": "qs0hog6ldlei9ct11pr3c77v1",
|
|
"Created": "2020-10-06T08:39:58.957083331Z",
|
|
"Scope": "swarm",
|
|
"Driver": "overlay",
|
|
"EnableIPv6": false,
|
|
"IPAM": {
|
|
"Driver": "default",
|
|
"Options": null,
|
|
"Config": [
|
|
{
|
|
"Subnet": "10.0.0.0/24",
|
|
"Gateway": "10.0.0.1"
|
|
}
|
|
]
|
|
},
|
|
"Internal": false,
|
|
"Attachable": false,
|
|
"Ingress": true,
|
|
"ConfigFrom": {
|
|
"Network": ""
|
|
},
|
|
"ConfigOnly": false,
|
|
"Containers": null,
|
|
"Options": {
|
|
"com.docker.network.driver.overlay.vxlanid_list": "4096"
|
|
},
|
|
"Labels": {
|
|
"key1": "value1"
|
|
}
|
|
},
|
|
{
|
|
"Name": "host",
|
|
"Id": "317f0384d7e5f5c26304a0b04599f9f54bc08def4d0535059ece89955e9c4b7b",
|
|
"Created": "2020-10-06T08:39:52.843373136Z",
|
|
"Scope": "local",
|
|
"Driver": "host",
|
|
"EnableIPv6": false,
|
|
"IPAM": {
|
|
"Driver": "default",
|
|
"Options": null,
|
|
"Config": []
|
|
},
|
|
"Internal": false,
|
|
"Attachable": false,
|
|
"Ingress": false,
|
|
"ConfigFrom": {
|
|
"Network": ""
|
|
},
|
|
"ConfigOnly": false,
|
|
"Containers": {},
|
|
"Options": {},
|
|
"Labels": {
|
|
"key": "value"
|
|
}
|
|
}
|
|
]`
|
|
resultExpected := []network{
|
|
{
|
|
ID: "qs0hog6ldlei9ct11pr3c77v1",
|
|
Ingress: true,
|
|
Scope: "swarm",
|
|
Name: "ingress",
|
|
Labels: map[string]string{
|
|
"key1": "value1",
|
|
},
|
|
},
|
|
{
|
|
ID: "317f0384d7e5f5c26304a0b04599f9f54bc08def4d0535059ece89955e9c4b7b",
|
|
Scope: "local",
|
|
Name: "host",
|
|
Labels: map[string]string{
|
|
"key": "value",
|
|
},
|
|
},
|
|
}
|
|
f(data, resultExpected)
|
|
}
|