2020-07-02 22:19:43 +01:00
|
|
|
// 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 natlab
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"inet.af/netaddr"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestAllocIPs(t *testing.T) {
|
|
|
|
n := NewInternet()
|
|
|
|
saw := map[netaddr.IP]bool{}
|
|
|
|
for i := 0; i < 255; i++ {
|
|
|
|
for _, f := range []func(*Machine) netaddr.IP{n.allocIPv4, n.allocIPv6} {
|
|
|
|
ip := f(nil)
|
|
|
|
if saw[ip] {
|
|
|
|
t.Fatalf("got duplicate %v", ip)
|
|
|
|
}
|
|
|
|
saw[ip] = true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// This should work:
|
|
|
|
n.allocIPv6(nil)
|
|
|
|
|
|
|
|
// But allocating another IPv4 should panic, exhausting the
|
|
|
|
// limited /24 range:
|
|
|
|
defer func() {
|
|
|
|
if e := recover(); fmt.Sprint(e) != "pool exhausted" {
|
|
|
|
t.Errorf("unexpected panic: %v", e)
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
n.allocIPv4(nil)
|
|
|
|
t.Fatalf("expected panic from IPv4")
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSendPacket(t *testing.T) {
|
|
|
|
internet := NewInternet()
|
|
|
|
|
|
|
|
foo := NewMachine("foo")
|
|
|
|
bar := NewMachine("bar")
|
|
|
|
ifFoo := foo.Attach("eth0", internet)
|
|
|
|
ifBar := bar.Attach("enp0s1", internet)
|
|
|
|
|
|
|
|
fooAddr := netaddr.IPPort{IP: ifFoo.V4(), Port: 123}
|
|
|
|
barAddr := netaddr.IPPort{IP: ifBar.V4(), Port: 456}
|
|
|
|
|
|
|
|
fooPC, err := foo.ListenPacket("udp4", fooAddr.String())
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
barPC, err := bar.ListenPacket("udp4", barAddr.String())
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
const msg = "some message"
|
|
|
|
if _, err := fooPC.WriteTo([]byte(msg), barAddr.UDPAddr()); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
buf := make([]byte, 1500) // TODO: care about MTUs in the natlab package somewhere
|
|
|
|
n, addr, err := barPC.ReadFrom(buf)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
buf = buf[:n]
|
|
|
|
if string(buf) != msg {
|
|
|
|
t.Errorf("read %q; want %q", buf, msg)
|
|
|
|
}
|
|
|
|
if addr.String() != fooAddr.String() {
|
|
|
|
t.Errorf("addr = %q; want %q", addr, fooAddr)
|
|
|
|
}
|
|
|
|
}
|
2020-07-03 01:52:58 +01:00
|
|
|
|
|
|
|
func TestLAN(t *testing.T) {
|
|
|
|
// TODO: very duplicate-ey with the previous test, but important
|
|
|
|
// right now to test explicit construction of Networks.
|
|
|
|
lan := Network{
|
|
|
|
Name: "lan1",
|
|
|
|
Prefix4: mustPrefix("192.168.0.0/24"),
|
|
|
|
}
|
|
|
|
|
|
|
|
foo := NewMachine("foo")
|
|
|
|
bar := NewMachine("bar")
|
|
|
|
ifFoo := foo.Attach("eth0", &lan)
|
|
|
|
ifBar := bar.Attach("eth0", &lan)
|
|
|
|
|
|
|
|
fooPC, err := foo.ListenPacket("udp4", ":123")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
barPC, err := bar.ListenPacket("udp4", ":456")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
const msg = "message"
|
|
|
|
barAddr := netaddr.IPPort{IP: ifBar.V4(), Port: 456}
|
|
|
|
if _, err := fooPC.WriteTo([]byte(msg), barAddr.UDPAddr()); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
buf := make([]byte, 1500)
|
|
|
|
n, addr, err := barPC.ReadFrom(buf)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
buf = buf[:n]
|
|
|
|
if string(buf) != msg {
|
|
|
|
t.Errorf("read %q; want %q", buf, msg)
|
|
|
|
}
|
|
|
|
fooAddr := netaddr.IPPort{IP: ifFoo.V4(), Port: 123}
|
|
|
|
if addr.String() != fooAddr.String() {
|
|
|
|
t.Errorf("addr = %q; want %q", addr, fooAddr)
|
|
|
|
}
|
|
|
|
}
|