2021-01-12 12:03:41 -08:00
|
|
|
// Copyright (c) 2021 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 packet
|
|
|
|
|
|
|
|
import (
|
2022-07-25 20:55:44 -07:00
|
|
|
"net/netip"
|
2021-01-12 12:03:41 -08:00
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestTailscaleRejectedHeader(t *testing.T) {
|
|
|
|
tests := []struct {
|
|
|
|
h TailscaleRejectedHeader
|
|
|
|
wantStr string
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
h: TailscaleRejectedHeader{
|
2022-07-25 20:55:44 -07:00
|
|
|
IPSrc: netip.MustParseAddr("5.5.5.5"),
|
|
|
|
IPDst: netip.MustParseAddr("1.2.3.4"),
|
|
|
|
Src: netip.MustParseAddrPort("1.2.3.4:567"),
|
|
|
|
Dst: netip.MustParseAddrPort("5.5.5.5:443"),
|
2021-01-12 12:03:41 -08:00
|
|
|
Proto: TCP,
|
|
|
|
Reason: RejectedDueToACLs,
|
|
|
|
},
|
|
|
|
wantStr: "TSMP-reject-flow{TCP 1.2.3.4:567 > 5.5.5.5:443}: acl",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
h: TailscaleRejectedHeader{
|
2022-07-25 20:55:44 -07:00
|
|
|
IPSrc: netip.MustParseAddr("2::2"),
|
|
|
|
IPDst: netip.MustParseAddr("1::1"),
|
|
|
|
Src: netip.MustParseAddrPort("[1::1]:567"),
|
|
|
|
Dst: netip.MustParseAddrPort("[2::2]:443"),
|
2021-01-12 12:03:41 -08:00
|
|
|
Proto: UDP,
|
|
|
|
Reason: RejectedDueToShieldsUp,
|
|
|
|
},
|
|
|
|
wantStr: "TSMP-reject-flow{UDP [1::1]:567 > [2::2]:443}: shields",
|
|
|
|
},
|
2021-02-02 15:05:51 -08:00
|
|
|
{
|
|
|
|
h: TailscaleRejectedHeader{
|
2022-07-25 20:55:44 -07:00
|
|
|
IPSrc: netip.MustParseAddr("2::2"),
|
|
|
|
IPDst: netip.MustParseAddr("1::1"),
|
|
|
|
Src: netip.MustParseAddrPort("[1::1]:567"),
|
|
|
|
Dst: netip.MustParseAddrPort("[2::2]:443"),
|
2021-02-02 15:05:51 -08:00
|
|
|
Proto: UDP,
|
|
|
|
Reason: RejectedDueToIPForwarding,
|
|
|
|
MaybeBroken: true,
|
|
|
|
},
|
|
|
|
wantStr: "TSMP-reject-flow{UDP [1::1]:567 > [2::2]:443}: host-ip-forwarding-unavailable",
|
|
|
|
},
|
2021-01-12 12:03:41 -08:00
|
|
|
}
|
|
|
|
for i, tt := range tests {
|
|
|
|
gotStr := tt.h.String()
|
|
|
|
if gotStr != tt.wantStr {
|
|
|
|
t.Errorf("%v. String = %q; want %q", i, gotStr, tt.wantStr)
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
pkt := make([]byte, tt.h.Len())
|
|
|
|
tt.h.Marshal(pkt)
|
|
|
|
|
|
|
|
var p Parsed
|
|
|
|
p.Decode(pkt)
|
|
|
|
t.Logf("Parsed: %+v", p)
|
|
|
|
t.Logf("Parsed: %s", p.String())
|
|
|
|
back, ok := p.AsTailscaleRejectedHeader()
|
|
|
|
if !ok {
|
|
|
|
t.Errorf("%v. %q (%02x) didn't parse back", i, gotStr, pkt)
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
if back != tt.h {
|
|
|
|
t.Errorf("%v. %q parsed back as %q", i, tt.h, back)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|