summaryrefslogtreecommitdiffhomepage
path: root/types/netmap/netmap_test.go
diff options
context:
space:
mode:
authorAleksandar Pesic <peske.nis@gmail.com>2021-02-17 15:29:21 +0100
committerAleksandar Pesic <peske.nis@gmail.com>2021-02-17 15:29:21 +0100
commit419edfca05a253a44161915bd96c1cc1df5fa163 (patch)
tree86de633a8529d6cc9f275d567d529aecfe4a037b /types/netmap/netmap_test.go
parent3e2d69a26c407093523edf352744c689ae155d52 (diff)
parent7038c09bc91c7f65ff33afb777187ef9acca214c (diff)
downloadtailscale-peske/elnotfound.tar.xz
tailscale-peske/elnotfound.zip
Merge branch 'main' into peske/elnotfoundpeske/elnotfound
Diffstat (limited to 'types/netmap/netmap_test.go')
-rw-r--r--types/netmap/netmap_test.go284
1 files changed, 284 insertions, 0 deletions
diff --git a/types/netmap/netmap_test.go b/types/netmap/netmap_test.go
new file mode 100644
index 000000000..977a64cf0
--- /dev/null
+++ b/types/netmap/netmap_test.go
@@ -0,0 +1,284 @@
+// Copyright (c) 2020 Tailscale Inc & AUTHORS All rights reserved.
+// Use of this source code is governed by a BSD-style
+// license that can be found in the LICENSE file.
+
+package netmap
+
+import (
+ "encoding/hex"
+ "testing"
+
+ "inet.af/netaddr"
+ "tailscale.com/tailcfg"
+)
+
+func testNodeKey(b byte) (ret tailcfg.NodeKey) {
+ for i := range ret {
+ ret[i] = b
+ }
+ return
+}
+
+func testDiscoKey(hexPrefix string) (ret tailcfg.DiscoKey) {
+ b, err := hex.DecodeString(hexPrefix)
+ if err != nil {
+ panic(err)
+ }
+ copy(ret[:], b)
+ return
+}
+
+func TestNetworkMapConcise(t *testing.T) {
+ for _, tt := range []struct {
+ name string
+ nm *NetworkMap
+ want string
+ }{
+ {
+ name: "basic",
+ nm: &NetworkMap{
+ NodeKey: testNodeKey(1),
+ Peers: []*tailcfg.Node{
+ {
+ Key: testNodeKey(2),
+ DERP: "127.3.3.40:2",
+ Endpoints: []string{"192.168.0.100:12", "192.168.0.100:12354"},
+ },
+ {
+ Key: testNodeKey(3),
+ DERP: "127.3.3.40:4",
+ Endpoints: []string{"10.2.0.100:12", "10.1.0.100:12345"},
+ },
+ },
+ },
+ want: "netmap: self: [AQEBA] auth=machine-unknown u=? []\n [AgICA] D2 : 192.168.0.100:12 192.168.0.100:12354\n [AwMDA] D4 : 10.2.0.100:12 10.1.0.100:12345\n",
+ },
+ {
+ name: "debug_non_nil",
+ nm: &NetworkMap{
+ NodeKey: testNodeKey(1),
+ Debug: &tailcfg.Debug{},
+ },
+ want: "netmap: self: [AQEBA] auth=machine-unknown u=? debug={} []\n",
+ },
+ {
+ name: "debug_values",
+ nm: &NetworkMap{
+ NodeKey: testNodeKey(1),
+ Debug: &tailcfg.Debug{LogHeapPprof: true},
+ },
+ want: "netmap: self: [AQEBA] auth=machine-unknown u=? debug={\"LogHeapPprof\":true} []\n",
+ },
+ } {
+ t.Run(tt.name, func(t *testing.T) {
+ var got string
+ n := int(testing.AllocsPerRun(1000, func() {
+ got = tt.nm.Concise()
+ }))
+ t.Logf("Allocs = %d", n)
+ if got != tt.want {
+ t.Errorf("Wrong output\n Got: %q\nWant: %q\n## Got (unescaped):\n%s\n## Want (unescaped):\n%s\n", got, tt.want, got, tt.want)
+ }
+ })
+ }
+}
+
+func TestConciseDiffFrom(t *testing.T) {
+ for _, tt := range []struct {
+ name string
+ a, b *NetworkMap
+ want string
+ }{
+ {
+ name: "no_change",
+ a: &NetworkMap{
+ NodeKey: testNodeKey(1),
+ Peers: []*tailcfg.Node{
+ {
+ Key: testNodeKey(2),
+ DERP: "127.3.3.40:2",
+ Endpoints: []string{"192.168.0.100:12", "192.168.0.100:12354"},
+ },
+ },
+ },
+ b: &NetworkMap{
+ NodeKey: testNodeKey(1),
+ Peers: []*tailcfg.Node{
+ {
+ Key: testNodeKey(2),
+ DERP: "127.3.3.40:2",
+ Endpoints: []string{"192.168.0.100:12", "192.168.0.100:12354"},
+ },
+ },
+ },
+ want: "",
+ },
+ {
+ name: "header_change",
+ a: &NetworkMap{
+ NodeKey: testNodeKey(1),
+ Peers: []*tailcfg.Node{
+ {
+ Key: testNodeKey(2),
+ DERP: "127.3.3.40:2",
+ Endpoints: []string{"192.168.0.100:12", "192.168.0.100:12354"},
+ },
+ },
+ },
+ b: &NetworkMap{
+ NodeKey: testNodeKey(2),
+ Peers: []*tailcfg.Node{
+ {
+ Key: testNodeKey(2),
+ DERP: "127.3.3.40:2",
+ Endpoints: []string{"192.168.0.100:12", "192.168.0.100:12354"},
+ },
+ },
+ },
+ want: "-netmap: self: [AQEBA] auth=machine-unknown u=? []\n+netmap: self: [AgICA] auth=machine-unknown u=? []\n",
+ },
+ {
+ name: "peer_add",
+ a: &NetworkMap{
+ NodeKey: testNodeKey(1),
+ Peers: []*tailcfg.Node{
+ {
+ ID: 2,
+ Key: testNodeKey(2),
+ DERP: "127.3.3.40:2",
+ Endpoints: []string{"192.168.0.100:12", "192.168.0.100:12354"},
+ },
+ },
+ },
+ b: &NetworkMap{
+ NodeKey: testNodeKey(1),
+ Peers: []*tailcfg.Node{
+ {
+ ID: 1,
+ Key: testNodeKey(1),
+ DERP: "127.3.3.40:1",
+ Endpoints: []string{"192.168.0.100:12", "192.168.0.100:12354"},
+ },
+ {
+ ID: 2,
+ Key: testNodeKey(2),
+ DERP: "127.3.3.40:2",
+ Endpoints: []string{"192.168.0.100:12", "192.168.0.100:12354"},
+ },
+ {
+ ID: 3,
+ Key: testNodeKey(3),
+ DERP: "127.3.3.40:3",
+ Endpoints: []string{"192.168.0.100:12", "192.168.0.100:12354"},
+ },
+ },
+ },
+ want: "+ [AQEBA] D1 : 192.168.0.100:12 192.168.0.100:12354\n+ [AwMDA] D3 : 192.168.0.100:12 192.168.0.100:12354\n",
+ },
+ {
+ name: "peer_remove",
+ a: &NetworkMap{
+ NodeKey: testNodeKey(1),
+ Peers: []*tailcfg.Node{
+ {
+ ID: 1,
+ Key: testNodeKey(1),
+ DERP: "127.3.3.40:1",
+ Endpoints: []string{"192.168.0.100:12", "192.168.0.100:12354"},
+ },
+ {
+ ID: 2,
+ Key: testNodeKey(2),
+ DERP: "127.3.3.40:2",
+ Endpoints: []string{"192.168.0.100:12", "192.168.0.100:12354"},
+ },
+ {
+ ID: 3,
+ Key: testNodeKey(3),
+ DERP: "127.3.3.40:3",
+ Endpoints: []string{"192.168.0.100:12", "192.168.0.100:12354"},
+ },
+ },
+ },
+ b: &NetworkMap{
+ NodeKey: testNodeKey(1),
+ Peers: []*tailcfg.Node{
+ {
+ ID: 2,
+ Key: testNodeKey(2),
+ DERP: "127.3.3.40:2",
+ Endpoints: []string{"192.168.0.100:12", "192.168.0.100:12354"},
+ },
+ },
+ },
+ want: "- [AQEBA] D1 : 192.168.0.100:12 192.168.0.100:12354\n- [AwMDA] D3 : 192.168.0.100:12 192.168.0.100:12354\n",
+ },
+ {
+ name: "peer_port_change",
+ a: &NetworkMap{
+ NodeKey: testNodeKey(1),
+ Peers: []*tailcfg.Node{
+ {
+ ID: 2,
+ Key: testNodeKey(2),
+ DERP: "127.3.3.40:2",
+ Endpoints: []string{"192.168.0.100:12", "1.1.1.1:1"},
+ },
+ },
+ },
+ b: &NetworkMap{
+ NodeKey: testNodeKey(1),
+ Peers: []*tailcfg.Node{
+ {
+ ID: 2,
+ Key: testNodeKey(2),
+ DERP: "127.3.3.40:2",
+ Endpoints: []string{"192.168.0.100:12", "1.1.1.1:2"},
+ },
+ },
+ },
+ want: "- [AgICA] D2 : 192.168.0.100:12 1.1.1.1:1 \n+ [AgICA] D2 : 192.168.0.100:12 1.1.1.1:2 \n",
+ },
+ {
+ name: "disco_key_only_change",
+ a: &NetworkMap{
+ NodeKey: testNodeKey(1),
+ Peers: []*tailcfg.Node{
+ {
+ ID: 2,
+ Key: testNodeKey(2),
+ DERP: "127.3.3.40:2",
+ Endpoints: []string{"192.168.0.100:41641", "1.1.1.1:41641"},
+ DiscoKey: testDiscoKey("f00f00f00f"),
+ AllowedIPs: []netaddr.IPPrefix{{IP: netaddr.IPv4(100, 102, 103, 104), Bits: 32}},
+ },
+ },
+ },
+ b: &NetworkMap{
+ NodeKey: testNodeKey(1),
+ Peers: []*tailcfg.Node{
+ {
+ ID: 2,
+ Key: testNodeKey(2),
+ DERP: "127.3.3.40:2",
+ Endpoints: []string{"192.168.0.100:41641", "1.1.1.1:41641"},
+ DiscoKey: testDiscoKey("ba4ba4ba4b"),
+ AllowedIPs: []netaddr.IPPrefix{{IP: netaddr.IPv4(100, 102, 103, 104), Bits: 32}},
+ },
+ },
+ },
+ want: "- [AgICA] d:f00f00f00f000000 D2 100.102.103.104 : 192.168.0.100:41641 1.1.1.1:41641\n+ [AgICA] d:ba4ba4ba4b000000 D2 100.102.103.104 : 192.168.0.100:41641 1.1.1.1:41641\n",
+ },
+ } {
+ t.Run(tt.name, func(t *testing.T) {
+ var got string
+ n := int(testing.AllocsPerRun(50, func() {
+ got = tt.b.ConciseDiffFrom(tt.a)
+ }))
+ t.Logf("Allocs = %d", n)
+ if got != tt.want {
+ t.Errorf("Wrong output\n Got: %q\nWant: %q\n## Got (unescaped):\n%s\n## Want (unescaped):\n%s\n", got, tt.want, got, tt.want)
+ }
+ })
+ }
+}