2017-02-20 17:34:32 +00:00
|
|
|
// +build linux
|
|
|
|
|
2015-11-26 10:50:07 +00:00
|
|
|
package netlink
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net"
|
|
|
|
"testing"
|
2017-10-20 20:38:07 +00:00
|
|
|
|
|
|
|
"golang.org/x/sys/unix"
|
2015-11-26 10:50:07 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestRuleAddDel(t *testing.T) {
|
2017-02-06 16:14:07 +00:00
|
|
|
skipUnlessRoot(t)
|
|
|
|
|
2015-11-26 10:50:07 +00:00
|
|
|
srcNet := &net.IPNet{IP: net.IPv4(172, 16, 0, 1), Mask: net.CIDRMask(16, 32)}
|
|
|
|
dstNet := &net.IPNet{IP: net.IPv4(172, 16, 1, 1), Mask: net.CIDRMask(24, 32)}
|
|
|
|
|
2017-10-20 20:38:07 +00:00
|
|
|
rulesBegin, err := RuleList(unix.AF_INET)
|
2015-11-26 10:50:07 +00:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
2015-12-09 13:07:11 +00:00
|
|
|
rule := NewRule()
|
2017-10-20 20:38:07 +00:00
|
|
|
rule.Table = unix.RT_TABLE_MAIN
|
2015-12-09 13:07:11 +00:00
|
|
|
rule.Src = srcNet
|
|
|
|
rule.Dst = dstNet
|
|
|
|
rule.Priority = 5
|
|
|
|
rule.OifName = "lo"
|
|
|
|
rule.IifName = "lo"
|
2015-11-26 10:50:07 +00:00
|
|
|
if err := RuleAdd(rule); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
2017-10-20 20:38:07 +00:00
|
|
|
rules, err := RuleList(unix.AF_INET)
|
2015-11-26 10:50:07 +00:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
2016-03-20 00:12:26 +00:00
|
|
|
if len(rules) != len(rulesBegin)+1 {
|
2015-11-26 10:50:07 +00:00
|
|
|
t.Fatal("Rule not added properly")
|
|
|
|
}
|
|
|
|
|
|
|
|
// find this rule
|
|
|
|
var found bool
|
|
|
|
for i := range rules {
|
|
|
|
if rules[i].Table == rule.Table &&
|
|
|
|
rules[i].Src != nil && rules[i].Src.String() == srcNet.String() &&
|
|
|
|
rules[i].Dst != nil && rules[i].Dst.String() == dstNet.String() &&
|
|
|
|
rules[i].OifName == rule.OifName &&
|
|
|
|
rules[i].Priority == rule.Priority &&
|
|
|
|
rules[i].IifName == rule.IifName {
|
|
|
|
found = true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if !found {
|
|
|
|
t.Fatal("Rule has diffrent options than one added")
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := RuleDel(rule); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
2017-10-20 20:38:07 +00:00
|
|
|
rulesEnd, err := RuleList(unix.AF_INET)
|
2015-11-26 10:50:07 +00:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
2016-03-20 00:12:26 +00:00
|
|
|
if len(rulesEnd) != len(rulesBegin) {
|
2015-11-26 10:50:07 +00:00
|
|
|
t.Fatal("Rule not removed properly")
|
|
|
|
}
|
|
|
|
}
|