| // Copyright 2011 The Go 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 net |
| |
| import ( |
| "reflect" |
| "strings" |
| "testing" |
| ) |
| |
| var parseMACTests = []struct { |
| in string |
| out HardwareAddr |
| err string |
| }{ |
| // See RFC 7042, Section 2.1.1. |
| {"00:00:5e:00:53:01", HardwareAddr{0x00, 0x00, 0x5e, 0x00, 0x53, 0x01}, ""}, |
| {"00-00-5e-00-53-01", HardwareAddr{0x00, 0x00, 0x5e, 0x00, 0x53, 0x01}, ""}, |
| {"0000.5e00.5301", HardwareAddr{0x00, 0x00, 0x5e, 0x00, 0x53, 0x01}, ""}, |
| |
| // See RFC 7042, Section 2.2.2. |
| {"02:00:5e:10:00:00:00:01", HardwareAddr{0x02, 0x00, 0x5e, 0x10, 0x00, 0x00, 0x00, 0x01}, ""}, |
| {"02-00-5e-10-00-00-00-01", HardwareAddr{0x02, 0x00, 0x5e, 0x10, 0x00, 0x00, 0x00, 0x01}, ""}, |
| {"0200.5e10.0000.0001", HardwareAddr{0x02, 0x00, 0x5e, 0x10, 0x00, 0x00, 0x00, 0x01}, ""}, |
| |
| // See RFC 4391, Section 9.1.1. |
| { |
| "00:00:00:00:fe:80:00:00:00:00:00:00:02:00:5e:10:00:00:00:01", |
| HardwareAddr{ |
| 0x00, 0x00, 0x00, 0x00, |
| 0xfe, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, |
| 0x02, 0x00, 0x5e, 0x10, 0x00, 0x00, 0x00, 0x01, |
| }, |
| "", |
| }, |
| { |
| "00-00-00-00-fe-80-00-00-00-00-00-00-02-00-5e-10-00-00-00-01", |
| HardwareAddr{ |
| 0x00, 0x00, 0x00, 0x00, |
| 0xfe, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, |
| 0x02, 0x00, 0x5e, 0x10, 0x00, 0x00, 0x00, 0x01, |
| }, |
| "", |
| }, |
| { |
| "0000.0000.fe80.0000.0000.0000.0200.5e10.0000.0001", |
| HardwareAddr{ |
| 0x00, 0x00, 0x00, 0x00, |
| 0xfe, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, |
| 0x02, 0x00, 0x5e, 0x10, 0x00, 0x00, 0x00, 0x01, |
| }, |
| "", |
| }, |
| |
| {"ab:cd:ef:AB:CD:EF", HardwareAddr{0xab, 0xcd, 0xef, 0xab, 0xcd, 0xef}, ""}, |
| {"ab:cd:ef:AB:CD:EF:ab:cd", HardwareAddr{0xab, 0xcd, 0xef, 0xab, 0xcd, 0xef, 0xab, 0xcd}, ""}, |
| { |
| "ab:cd:ef:AB:CD:EF:ab:cd:ef:AB:CD:EF:ab:cd:ef:AB:CD:EF:ab:cd", |
| HardwareAddr{ |
| 0xab, 0xcd, 0xef, 0xab, |
| 0xcd, 0xef, 0xab, 0xcd, 0xef, 0xab, 0xcd, 0xef, |
| 0xab, 0xcd, 0xef, 0xab, 0xcd, 0xef, 0xab, 0xcd, |
| }, |
| "", |
| }, |
| |
| {"01.02.03.04.05.06", nil, "invalid MAC address"}, |
| {"01:02:03:04:05:06:", nil, "invalid MAC address"}, |
| {"x1:02:03:04:05:06", nil, "invalid MAC address"}, |
| {"01002:03:04:05:06", nil, "invalid MAC address"}, |
| {"01:02003:04:05:06", nil, "invalid MAC address"}, |
| {"01:02:03004:05:06", nil, "invalid MAC address"}, |
| {"01:02:03:04005:06", nil, "invalid MAC address"}, |
| {"01:02:03:04:05006", nil, "invalid MAC address"}, |
| {"01-02:03:04:05:06", nil, "invalid MAC address"}, |
| {"01:02-03-04-05-06", nil, "invalid MAC address"}, |
| {"0123:4567:89AF", nil, "invalid MAC address"}, |
| {"0123-4567-89AF", nil, "invalid MAC address"}, |
| } |
| |
| func TestParseMAC(t *testing.T) { |
| match := func(err error, s string) bool { |
| if s == "" { |
| return err == nil |
| } |
| return err != nil && strings.Contains(err.Error(), s) |
| } |
| |
| for i, tt := range parseMACTests { |
| out, err := ParseMAC(tt.in) |
| if !reflect.DeepEqual(out, tt.out) || !match(err, tt.err) { |
| t.Errorf("ParseMAC(%q) = %v, %v, want %v, %v", tt.in, out, err, tt.out, tt.err) |
| } |
| if tt.err == "" { |
| // Verify that serialization works too, and that it round-trips. |
| s := out.String() |
| out2, err := ParseMAC(s) |
| if err != nil { |
| t.Errorf("%d. ParseMAC(%q) = %v", i, s, err) |
| continue |
| } |
| if !reflect.DeepEqual(out2, out) { |
| t.Errorf("%d. ParseMAC(%q) = %v, want %v", i, s, out2, out) |
| } |
| } |
| } |
| } |