func TestTwoHostsMultiVlanPingFailure_sanity(t *testing.T) { defer func() { utils.ConfigCleanupCommon(t, testbed.GetNodes()) utils.StopOnError(t.Failed()) }() jsonCfg := `{ "Hosts" : [{ "Name" : "host1", "Intf" : "eth2" }, { "Name" : "host2", "Intf" : "eth2" }], "Tenants" : [ { "Name" : "tenant-one", "DefaultNetType" : "vlan", "SubnetPool" : "11.1.0.0/16", "AllocSubnetLen" : 24, "Vlans" : "11-48", "Networks" : [ { "Name" : "orange", "Endpoints" : [ { "Container" : "myContainer1", "Host" : "host1" } ] }, { "Name" : "purple", "Endpoints" : [ { "Container" : "myContainer2", "Host" : "host2" } ] } ] } ] }` utils.ConfigSetupCommon(t, jsonCfg, testbed.GetNodes()) node1 := testbed.GetNodes()[0] node2 := testbed.GetNodes()[1] utils.StartServer(t, node1, "myContainer1") defer func() { utils.DockerCleanup(t, node1, "myContainer1") }() ipAddress := utils.GetIPAddress(t, node1, "orange-myContainer1", u.EtcdNameStr) utils.StartClientFailure(t, node2, "myContainer2", ipAddress) defer func() { utils.DockerCleanup(t, node2, "myContainer2") }() }
func TestMultipleEpsInContainer_regress(t *testing.T) { defer func() { utils.ConfigCleanupCommon(t, testbed.GetNodes()) utils.StopOnError(t.Failed()) }() cfgFile := utils.GetCfgFile("multiple_eps_in_container") jsonCfg, err := ioutil.ReadFile(cfgFile) if err != nil { t.Fatalf("failed to read config file %s \n", err) } utils.ConfigSetupCommon(t, string(jsonCfg), testbed.GetNodes()) node1 := testbed.GetNodes()[0] node2 := testbed.GetNodes()[1] // Container2 is reachable on both orange and purple networks utils.StartServer(t, node1, "myContainer2") defer func() { utils.DockerCleanup(t, node1, "myContainer2") }() ipAddress := utils.GetIPAddress(t, node1, "orange-myContainer2", u.EtcdNameStr) utils.StartClient(t, node1, "myContainer3", ipAddress) defer func() { utils.DockerCleanup(t, node1, "myContainer3") }() ipAddress = utils.GetIPAddress(t, node1, "purple-myContainer2", u.EtcdNameStr) utils.StartClient(t, node2, "myContainer4", ipAddress) defer func() { utils.DockerCleanup(t, node2, "myContainer4") }() // Container1 is reachable on only on orange network utils.StartServer(t, node1, "myContainer1") defer func() { utils.DockerCleanup(t, node1, "myContainer1") }() ipAddress = utils.GetIPAddress(t, node1, "orange-myContainer1", u.EtcdNameStr) utils.StartClient(t, node2, "myContainer3", ipAddress) defer func() { utils.DockerCleanup(t, node2, "myContainer3") }() utils.DockerCleanup(t, node2, "myContainer4") utils.StartClientFailure(t, node2, "myContainer4", ipAddress) defer func() { utils.DockerCleanup(t, node2, "myContainer4") }() }
func TestTwoHostsVxlanAddDelEp_sanity(t *testing.T) { defer func() { utils.ConfigCleanupCommon(t, testbed.GetNodes()) utils.StopOnError(t.Failed()) }() jsonCfg := `{ "Hosts" : [{ "Name" : "host1", "VtepIp" : "192.168.2.10" }, { "Name" : "host2", "VtepIp" : "192.168.2.11" }], "Tenants" : [ { "Name" : "tenant-one", "DefaultNetType" : "vxlan", "SubnetPool" : "11.1.0.0/16", "AllocSubnetLen" : 24, "VXlans" : "10001-11000", "Networks" : [ { "Name" : "orange", "Endpoints" : [ { "Container" : "myContainer1", "Host" : "host1" }, { "Container" : "myContainer2", "Host" : "host2" } ] }, { "Name" : "purple", "Endpoints" : [ { "Container" : "myContainer3", "Host" : "host1" }, { "Container" : "myContainer4", "Host" : "host2" } ] } ] } ] }` utils.ConfigSetupCommon(t, jsonCfg, testbed.GetNodes()) node1 := testbed.GetNodes()[0] node2 := testbed.GetNodes()[1] utils.StartServer(t, node1, "myContainer1") defer func() { utils.DockerCleanup(t, node1, "myContainer1") }() utils.StartServer(t, node1, "myContainer3") defer func() { utils.DockerCleanup(t, node1, "myContainer3") }() ipAddress := utils.GetIPAddress(t, node1, "orange-myContainer1", u.EtcdNameStr) utils.StartClient(t, node2, "myContainer2", ipAddress) defer func() { utils.DockerCleanup(t, node2, "myContainer2") }() ipAddress = utils.GetIPAddress(t, node1, "purple-myContainer3", u.EtcdNameStr) utils.StartClient(t, node2, "myContainer4", ipAddress) defer func() { utils.DockerCleanup(t, node2, "myContainer4") }() jsonCfg = ` { "Tenants" : [ { "Name" : "tenant-one", "Networks" : [ { "Name" : "orange", "Endpoints" : [ { "Container" : "myContainer5", "Host" : "host1" } ] } ] } ] }` utils.AddConfig(t, jsonCfg, testbed.GetNodes()[0]) utils.StartServer(t, node1, "myContainer5") defer func() { utils.DockerCleanup(t, node1, "myContainer5") }() ipAddress = utils.GetIPAddress(t, node1, "orange-myContainer5", u.EtcdNameStr) utils.DockerCleanup(t, node2, "myContainer2") utils.StartClient(t, node2, "myContainer2", ipAddress) defer func() { utils.DockerCleanup(t, node2, "myContainer2") }() utils.DelConfig(t, jsonCfg, testbed.GetNodes()[0]) utils.DockerCleanup(t, node2, "myContainer2") utils.StartClientFailure(t, node2, "myContainer2", ipAddress) defer func() { utils.DockerCleanup(t, node2, "myContainer2") }() jsonCfg = ` { "Tenants" : [ { "Name" : "tenant-one", "Networks" : [ { "Name" : "purple", "Endpoints" : [ { "Container" : "myContainer5", "Host" : "host1" } ] } ] } ] }` utils.AddConfig(t, jsonCfg, testbed.GetNodes()[0]) ipAddress = utils.GetIPAddress(t, node1, "purple-myContainer5", u.EtcdNameStr) utils.DockerCleanup(t, node2, "myContainer4") utils.StartClient(t, node2, "myContainer4", ipAddress) defer func() { utils.DockerCleanup(t, node2, "myContainer4") }() }
func TestTwoHostsMultiVxlanPingFailureStatefulStart_sanity(t *testing.T) { defer func() { utils.ConfigCleanupCommon(t, testbed.GetNodes()) utils.StopOnError(t.Failed()) }() //create a single vlan network, with two endpoints jsonCfg := `{ "Hosts" : [{ "Name" : "host1", "VtepIp" : "192.168.2.10" }, { "Name" : "host2", "VtepIp" : "192.168.2.11" }], "Tenants" : [ { "Name" : "tenant-one", "DefaultNetType" : "vxlan", "SubnetPool" : "11.1.0.0/16", "AllocSubnetLen" : 24, "VXlans" : "10001-11000", "Networks" : [ { "Name" : "orange", "Endpoints" : [ { "Container" : "myContainer1", "Host" : "host1" }, { "Container" : "myContainer2", "Host" : "host2" } ] }, { "Name" : "purple", "Endpoints" : [ { "Container" : "myContainer3", "Host" : "host1" }, { "Container" : "myContainer4", "Host" : "host2" } ] } ] } ] }` utils.ConfigSetupCommon(t, jsonCfg, testbed.GetNodes()) node1 := testbed.GetNodes()[0] node2 := testbed.GetNodes()[1] utils.StartServer(t, node1, "myContainer1") defer func() { utils.DockerCleanup(t, node1, "myContainer1") }() ipAddress := utils.GetIPAddress(t, node1, "orange-myContainer1", u.EtcdNameStr) utils.StartClientFailure(t, node2, "myContainer4", ipAddress) defer func() { utils.DockerCleanup(t, node2, "myContainer4") }() utils.StartClientFailure(t, node2, "myContainer3", ipAddress) defer func() { utils.DockerCleanup(t, node2, "myContainer3") }() // Wait for Netplugin to cleanup time.Sleep(1 * time.Second) //restart the netplugin and retry the pings utils.StopNetPlugin(t, testbed.GetNodes()) utils.StartNetPlugin(t, testbed.GetNodes(), false) utils.DockerCleanup(t, node2, "myContainer3") utils.DockerCleanup(t, node2, "myContainer4") ipAddress = utils.GetIPAddress(t, node1, "orange-myContainer1", u.EtcdNameStr) utils.StartClientFailure(t, node2, "myContainer4", ipAddress) defer func() { utils.DockerCleanup(t, node2, "myContainer4") }() utils.StartClientFailure(t, node2, "myContainer3", ipAddress) defer func() { utils.DockerCleanup(t, node2, "myContainer3") }() }
func TestTwoHostsVxlanAddDelNetworkConsul_sanity(t *testing.T) { defer func() { utils.ConfigCleanupCommon(t, testbed.GetNodes()) utils.StopOnError(t.Failed()) }() jsonCfg := `{ "Hosts" : [{ "Name" : "host1", "VtepIp" : "192.168.2.10" }, { "Name" : "host2", "VtepIp" : "192.168.2.11" }], "Tenants" : [ { "Name" : "tenant-one", "DefaultNetType" : "vxlan", "SubnetPool" : "11.1.0.0/16", "AllocSubnetLen" : 24, "VXlans" : "10001-11000", "Networks" : [ { "Name" : "orange", "Endpoints" : [ { "Container" : "myContainer1", "Host" : "host1" }, { "Container" : "myContainer2", "Host" : "host2" } ] }, { "Name" : "purple", "Endpoints" : [ { "Container" : "myContainer3", "Host" : "host1" }, { "Container" : "myContainer4", "Host" : "host2" } ] } ] } ] }` utils.ConfigSetupCommonWithConsul(t, jsonCfg, testbed.GetNodes()) node1 := testbed.GetNodes()[0] node2 := testbed.GetNodes()[1] utils.StartServer(t, node1, "myContainer1") defer func() { utils.DockerCleanup(t, node1, "myContainer1") }() utils.StartServer(t, node1, "myContainer3") defer func() { utils.DockerCleanup(t, node1, "myContainer3") }() ipAddress := utils.GetIPAddress(t, node1, "orange-myContainer1", u.ConsulNameStr) utils.StartClient(t, node2, "myContainer2", ipAddress) defer func() { utils.DockerCleanup(t, node2, "myContainer2") }() ipAddress = utils.GetIPAddress(t, node1, "purple-myContainer3", u.ConsulNameStr) utils.StartClient(t, node2, "myContainer4", ipAddress) defer func() { utils.DockerCleanup(t, node2, "myContainer4") }() jsonCfg = ` { "Tenants" : [ { "Name" : "tenant-one", "Networks" : [ { "Name" : "green", "Endpoints" : [ { "Container" : "myContainer5", "Host" : "host1" }, { "Container" : "myContainer6", "Host" : "host2" } ] } ] } ] }` utils.AddConfigConsul(t, jsonCfg, testbed.GetNodes()[0]) utils.StartServer(t, node1, "myContainer5") defer func() { utils.DockerCleanup(t, node1, "myContainer5") }() ipAddress = utils.GetIPAddress(t, node1, "green-myContainer5", u.ConsulNameStr) utils.StartClient(t, node2, "myContainer6", ipAddress) defer func() { utils.DockerCleanup(t, node2, "myContainer6") }() utils.DelConfigConsul(t, jsonCfg, testbed.GetNodes()[0]) utils.DockerCleanup(t, node2, "myContainer6") utils.StartClientFailure(t, node2, "myContainer6", ipAddress) defer func() { utils.DockerCleanup(t, node2, "myContainer6") }() jsonCfg = ` { "Tenants" : [ { "Name" : "tenant-one", "Networks" : [ { "Name" : "green" } ] } ] }` utils.DelConfigConsul(t, jsonCfg, testbed.GetNodes()[0]) time.Sleep(1 * time.Second) if utils.NetworkStateExists(node2, "green", u.ConsulNameStr) == nil { t.Fatalf("Error - network %s doesn't seem to be deleted \n", "green") } }