2023-01-27 13:37:20 -08:00
|
|
|
// Copyright (c) Tailscale Inc & AUTHORS
|
|
|
|
// SPDX-License-Identifier: BSD-3-Clause
|
2020-07-06 22:33:29 -07:00
|
|
|
|
|
|
|
package tsaddr
|
|
|
|
|
2020-12-28 16:48:43 -08:00
|
|
|
import (
|
2022-07-25 20:55:44 -07:00
|
|
|
"net/netip"
|
2020-12-28 16:48:43 -08:00
|
|
|
"testing"
|
|
|
|
|
2024-09-25 11:08:58 +02:00
|
|
|
"github.com/google/go-cmp/cmp"
|
|
|
|
"github.com/google/go-cmp/cmp/cmpopts"
|
2022-07-24 20:08:42 -07:00
|
|
|
"tailscale.com/net/netaddr"
|
2024-09-25 11:08:58 +02:00
|
|
|
"tailscale.com/types/views"
|
2020-12-28 16:48:43 -08:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestInCrostiniRange(t *testing.T) {
|
|
|
|
tests := []struct {
|
all: convert more code to use net/netip directly
perl -i -npe 's,netaddr.IPPrefixFrom,netip.PrefixFrom,' $(git grep -l -F netaddr.)
perl -i -npe 's,netaddr.IPPortFrom,netip.AddrPortFrom,' $(git grep -l -F netaddr. )
perl -i -npe 's,netaddr.IPPrefix,netip.Prefix,g' $(git grep -l -F netaddr. )
perl -i -npe 's,netaddr.IPPort,netip.AddrPort,g' $(git grep -l -F netaddr. )
perl -i -npe 's,netaddr.IP\b,netip.Addr,g' $(git grep -l -F netaddr. )
perl -i -npe 's,netaddr.IPv6Raw\b,netip.AddrFrom16,g' $(git grep -l -F netaddr. )
goimports -w .
Then delete some stuff from the net/netaddr shim package which is no
longer neeed.
Updates #5162
Change-Id: Ia7a86893fe21c7e3ee1ec823e8aba288d4566cd8
Signed-off-by: Brad Fitzpatrick <bradfitz@tailscale.com>
2022-07-25 21:14:09 -07:00
|
|
|
ip netip.Addr
|
2020-12-28 16:48:43 -08:00
|
|
|
want bool
|
|
|
|
}{
|
|
|
|
{netaddr.IPv4(192, 168, 0, 1), false},
|
|
|
|
{netaddr.IPv4(100, 101, 102, 103), false},
|
|
|
|
{netaddr.IPv4(100, 115, 92, 0), true},
|
|
|
|
{netaddr.IPv4(100, 115, 92, 5), true},
|
|
|
|
{netaddr.IPv4(100, 115, 92, 255), true},
|
|
|
|
{netaddr.IPv4(100, 115, 93, 40), true},
|
|
|
|
{netaddr.IPv4(100, 115, 94, 1), false},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, test := range tests {
|
|
|
|
if got := ChromeOSVMRange().Contains(test.ip); got != test.want {
|
|
|
|
t.Errorf("inCrostiniRange(%q) = %v, want %v", test.ip, got, test.want)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2020-07-06 22:33:29 -07:00
|
|
|
|
2022-11-16 11:38:25 -08:00
|
|
|
func TestTailscaleServiceIP(t *testing.T) {
|
|
|
|
got := TailscaleServiceIP().String()
|
|
|
|
want := "100.100.100.100"
|
|
|
|
if got != want {
|
|
|
|
t.Errorf("got %q; want %q", got, want)
|
|
|
|
}
|
|
|
|
if TailscaleServiceIPString != want {
|
|
|
|
t.Error("TailscaleServiceIPString is not consistent")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-01-04 13:33:08 -08:00
|
|
|
func TestTailscaleServiceIPv6(t *testing.T) {
|
|
|
|
got := TailscaleServiceIPv6().String()
|
|
|
|
want := "fd7a:115c:a1e0::53"
|
|
|
|
if got != want {
|
|
|
|
t.Errorf("got %q; want %q", got, want)
|
|
|
|
}
|
2022-11-16 11:38:25 -08:00
|
|
|
if TailscaleServiceIPv6String != want {
|
|
|
|
t.Error("TailscaleServiceIPv6String is not consistent")
|
|
|
|
}
|
2022-01-04 13:33:08 -08:00
|
|
|
}
|
|
|
|
|
2020-07-06 22:33:29 -07:00
|
|
|
func TestChromeOSVMRange(t *testing.T) {
|
|
|
|
if got, want := ChromeOSVMRange().String(), "100.115.92.0/23"; got != want {
|
|
|
|
t.Errorf("got %q; want %q", got, want)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestCGNATRange(t *testing.T) {
|
|
|
|
if got, want := CGNATRange().String(), "100.64.0.0/10"; got != want {
|
|
|
|
t.Errorf("got %q; want %q", got, want)
|
|
|
|
}
|
|
|
|
}
|
2021-03-29 18:28:57 -07:00
|
|
|
|
all: convert more code to use net/netip directly
perl -i -npe 's,netaddr.IPPrefixFrom,netip.PrefixFrom,' $(git grep -l -F netaddr.)
perl -i -npe 's,netaddr.IPPortFrom,netip.AddrPortFrom,' $(git grep -l -F netaddr. )
perl -i -npe 's,netaddr.IPPrefix,netip.Prefix,g' $(git grep -l -F netaddr. )
perl -i -npe 's,netaddr.IPPort,netip.AddrPort,g' $(git grep -l -F netaddr. )
perl -i -npe 's,netaddr.IP\b,netip.Addr,g' $(git grep -l -F netaddr. )
perl -i -npe 's,netaddr.IPv6Raw\b,netip.AddrFrom16,g' $(git grep -l -F netaddr. )
goimports -w .
Then delete some stuff from the net/netaddr shim package which is no
longer neeed.
Updates #5162
Change-Id: Ia7a86893fe21c7e3ee1ec823e8aba288d4566cd8
Signed-off-by: Brad Fitzpatrick <bradfitz@tailscale.com>
2022-07-25 21:14:09 -07:00
|
|
|
var sinkIP netip.Addr
|
2021-05-28 20:13:01 -07:00
|
|
|
|
|
|
|
func BenchmarkTailscaleServiceAddr(b *testing.B) {
|
2021-08-30 20:43:18 -07:00
|
|
|
b.ReportAllocs()
|
2024-04-16 13:15:13 -07:00
|
|
|
for range b.N {
|
2021-05-28 20:13:01 -07:00
|
|
|
sinkIP = TailscaleServiceIP()
|
|
|
|
}
|
|
|
|
}
|
2022-03-30 08:47:16 -07:00
|
|
|
|
|
|
|
func TestUnmapVia(t *testing.T) {
|
|
|
|
tests := []struct {
|
|
|
|
ip string
|
|
|
|
want string
|
|
|
|
}{
|
|
|
|
{"1.2.3.4", "1.2.3.4"}, // unchanged v4
|
|
|
|
{"fd7a:115c:a1e0:b1a::bb:10.2.1.3", "10.2.1.3"},
|
|
|
|
{"fd7a:115c:a1e0:b1b::bb:10.2.1.4", "fd7a:115c:a1e0:b1b:0:bb:a02:104"}, // "b1b",not "bia"
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
2022-07-25 20:55:44 -07:00
|
|
|
if got := UnmapVia(netip.MustParseAddr(tt.ip)).String(); got != tt.want {
|
2022-03-30 08:47:16 -07:00
|
|
|
t.Errorf("for %q: got %q, want %q", tt.ip, got, tt.want)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2024-09-25 11:08:58 +02:00
|
|
|
|
|
|
|
func TestIsExitNodeRoute(t *testing.T) {
|
|
|
|
tests := []struct {
|
|
|
|
pref netip.Prefix
|
|
|
|
want bool
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
pref: AllIPv4(),
|
|
|
|
want: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
pref: AllIPv6(),
|
|
|
|
want: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
pref: netip.MustParsePrefix("1.1.1.1/0"),
|
|
|
|
want: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
pref: netip.MustParsePrefix("1.1.1.1/1"),
|
|
|
|
want: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
pref: netip.MustParsePrefix("192.168.0.0/24"),
|
|
|
|
want: false,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tt := range tests {
|
|
|
|
if got := IsExitRoute(tt.pref); got != tt.want {
|
|
|
|
t.Errorf("for %q: got %v, want %v", tt.pref, got, tt.want)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestWithoutExitRoutes(t *testing.T) {
|
|
|
|
tests := []struct {
|
|
|
|
prefs []netip.Prefix
|
|
|
|
want []netip.Prefix
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
prefs: []netip.Prefix{AllIPv4(), AllIPv6()},
|
|
|
|
want: []netip.Prefix{},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
prefs: []netip.Prefix{AllIPv4()},
|
|
|
|
want: []netip.Prefix{AllIPv4()},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
prefs: []netip.Prefix{AllIPv4(), AllIPv6(), netip.MustParsePrefix("10.0.0.0/10")},
|
|
|
|
want: []netip.Prefix{netip.MustParsePrefix("10.0.0.0/10")},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
prefs: []netip.Prefix{AllIPv6(), netip.MustParsePrefix("10.0.0.0/10")},
|
|
|
|
want: []netip.Prefix{AllIPv6(), netip.MustParsePrefix("10.0.0.0/10")},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tt := range tests {
|
|
|
|
got := WithoutExitRoutes(views.SliceOf(tt.prefs))
|
|
|
|
if diff := cmp.Diff(tt.want, got.AsSlice(), cmpopts.EquateEmpty(), cmp.Comparer(func(a, b netip.Prefix) bool { return a == b })); diff != "" {
|
|
|
|
t.Errorf("unexpected route difference (-want +got):\n%s", diff)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestWithoutExitRoute(t *testing.T) {
|
|
|
|
tests := []struct {
|
|
|
|
prefs []netip.Prefix
|
|
|
|
want []netip.Prefix
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
prefs: []netip.Prefix{AllIPv4(), AllIPv6()},
|
|
|
|
want: []netip.Prefix{},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
prefs: []netip.Prefix{AllIPv4()},
|
|
|
|
want: []netip.Prefix{},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
prefs: []netip.Prefix{AllIPv4(), AllIPv6(), netip.MustParsePrefix("10.0.0.0/10")},
|
|
|
|
want: []netip.Prefix{netip.MustParsePrefix("10.0.0.0/10")},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
prefs: []netip.Prefix{AllIPv6(), netip.MustParsePrefix("10.0.0.0/10")},
|
|
|
|
want: []netip.Prefix{netip.MustParsePrefix("10.0.0.0/10")},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tt := range tests {
|
|
|
|
got := WithoutExitRoute(views.SliceOf(tt.prefs))
|
|
|
|
if diff := cmp.Diff(tt.want, got.AsSlice(), cmpopts.EquateEmpty(), cmp.Comparer(func(a, b netip.Prefix) bool { return a == b })); diff != "" {
|
|
|
|
t.Errorf("unexpected route difference (-want +got):\n%s", diff)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestContainsExitRoute(t *testing.T) {
|
|
|
|
tests := []struct {
|
|
|
|
prefs []netip.Prefix
|
|
|
|
want bool
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
prefs: []netip.Prefix{AllIPv4(), AllIPv6()},
|
|
|
|
want: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
prefs: []netip.Prefix{AllIPv4()},
|
|
|
|
want: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
prefs: []netip.Prefix{AllIPv4(), AllIPv6(), netip.MustParsePrefix("10.0.0.0/10")},
|
|
|
|
want: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
prefs: []netip.Prefix{AllIPv6(), netip.MustParsePrefix("10.0.0.0/10")},
|
|
|
|
want: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
prefs: []netip.Prefix{netip.MustParsePrefix("10.0.0.0/10")},
|
|
|
|
want: false,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tt := range tests {
|
|
|
|
if got := ContainsExitRoute(views.SliceOf(tt.prefs)); got != tt.want {
|
|
|
|
t.Errorf("for %q: got %v, want %v", tt.prefs, got, tt.want)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2024-11-20 12:28:25 -08:00
|
|
|
|
|
|
|
func TestIsTailscaleIPv4(t *testing.T) {
|
|
|
|
tests := []struct {
|
|
|
|
in netip.Addr
|
|
|
|
want bool
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
in: netip.MustParseAddr("100.67.19.57"),
|
|
|
|
want: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
in: netip.MustParseAddr("10.10.10.10"),
|
|
|
|
want: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
|
|
|
|
in: netip.MustParseAddr("fd7a:115c:a1e0:3f2b:7a1d:4e88:9c2b:7f01"),
|
|
|
|
want: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
in: netip.MustParseAddr("bc9d:0aa0:1f0a:69ab:eb5c:28e0:5456:a518"),
|
|
|
|
want: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
in: netip.MustParseAddr("100.115.92.157"),
|
|
|
|
want: false,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
|
|
if got := IsTailscaleIPv4(tt.in); got != tt.want {
|
2024-11-20 16:14:13 -08:00
|
|
|
t.Errorf("IsTailscaleIPv4(%v) = %v, want %v", tt.in, got, tt.want)
|
2024-11-20 12:28:25 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestIsTailscaleIP(t *testing.T) {
|
|
|
|
tests := []struct {
|
|
|
|
in netip.Addr
|
|
|
|
want bool
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
in: netip.MustParseAddr("100.67.19.57"),
|
|
|
|
want: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
in: netip.MustParseAddr("10.10.10.10"),
|
|
|
|
want: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
|
|
|
|
in: netip.MustParseAddr("fd7a:115c:a1e0:3f2b:7a1d:4e88:9c2b:7f01"),
|
|
|
|
want: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
in: netip.MustParseAddr("bc9d:0aa0:1f0a:69ab:eb5c:28e0:5456:a518"),
|
|
|
|
want: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
in: netip.MustParseAddr("100.115.92.157"),
|
|
|
|
want: false,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
|
|
if got := IsTailscaleIP(tt.in); got != tt.want {
|
2024-11-20 16:14:13 -08:00
|
|
|
t.Errorf("IsTailscaleIP(%v) = %v, want %v", tt.in, got, tt.want)
|
2024-11-20 12:28:25 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|