mirror of
https://github.com/tailscale/tailscale.git
synced 2025-05-08 16:47:11 +00:00
64 lines
1.2 KiB
Go
64 lines
1.2 KiB
Go
![]() |
package deepprint
|
||
|
|
||
|
import (
|
||
|
"bytes"
|
||
|
"testing"
|
||
|
|
||
|
"github.com/tailscale/wireguard-go/wgcfg"
|
||
|
"inet.af/netaddr"
|
||
|
"tailscale.com/wgengine/router"
|
||
|
)
|
||
|
|
||
|
func TestDeepPrint(t *testing.T) {
|
||
|
// v contains the types of values we care about for our current callers.
|
||
|
// Mostly we're just testing that we don't panic on handled types.
|
||
|
v := getVal()
|
||
|
|
||
|
var buf bytes.Buffer
|
||
|
Print(&buf, v)
|
||
|
t.Logf("Got: %s", buf.Bytes())
|
||
|
|
||
|
hash1 := Hash(v)
|
||
|
t.Logf("hash: %v", hash1)
|
||
|
for i := 0; i < 20; i++ {
|
||
|
hash2 := Hash(getVal())
|
||
|
if hash1 != hash2 {
|
||
|
t.Error("second hash didn't match")
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func getVal() []interface{} {
|
||
|
return []interface{}{
|
||
|
&wgcfg.Config{
|
||
|
Name: "foo",
|
||
|
Addresses: []wgcfg.CIDR{{Mask: 5, IP: wgcfg.IP{Addr: [16]byte{3: 3}}}},
|
||
|
ListenPort: 5,
|
||
|
Peers: []wgcfg.Peer{
|
||
|
{
|
||
|
Endpoints: []wgcfg.Endpoint{
|
||
|
{
|
||
|
Host: "foo",
|
||
|
Port: 5,
|
||
|
},
|
||
|
},
|
||
|
},
|
||
|
},
|
||
|
},
|
||
|
&router.Config{
|
||
|
DNS: []netaddr.IP{netaddr.IPv4(8, 8, 8, 8)},
|
||
|
},
|
||
|
map[string]string{
|
||
|
"key1": "val1",
|
||
|
"key2": "val2",
|
||
|
"key3": "val3",
|
||
|
"key4": "val4",
|
||
|
"key5": "val5",
|
||
|
"key6": "val6",
|
||
|
"key7": "val7",
|
||
|
"key8": "val8",
|
||
|
"key9": "val9",
|
||
|
},
|
||
|
}
|
||
|
}
|