Merge pull request #14646 from mesosphere/sttts-fix-kubeproxy-test

Fix e2e tests for providers without SSH to the nodes
This commit is contained in:
Alex Robinson
2015-10-05 11:56:09 -07:00
7 changed files with 39 additions and 26 deletions

View File

@@ -47,7 +47,7 @@ mesosslave:
- MESOS_PORT=5051 - MESOS_PORT=5051
- MESOS_LOG_DIR=/var/log/mesos - MESOS_LOG_DIR=/var/log/mesos
- MESOS_LOGGING_LEVEL=INFO - MESOS_LOGGING_LEVEL=INFO
- MESOS_RESOURCES=cpus:4;mem:1280;disk:25600;ports:[21000-21099] - MESOS_RESOURCES=cpus:4;mem:1280;disk:25600;ports:[8000-21099]
- MESOS_SWITCH_USER=0 - MESOS_SWITCH_USER=0
- MESOS_CONTAINERIZERS=docker,mesos - MESOS_CONTAINERIZERS=docker,mesos
- DOCKER_DAEMON_ARGS - DOCKER_DAEMON_ARGS

View File

@@ -38,7 +38,7 @@ func CoreDump(dir string) {
provider := testContext.Provider provider := testContext.Provider
// requires ssh // requires ssh
if !providerIs("gce", "gke") { if !providerIs(providersWithSSH...) {
fmt.Printf("Skipping SSH core dump, which is not implemented for %s", provider) fmt.Printf("Skipping SSH core dump, which is not implemented for %s", provider)
return return
} }

View File

@@ -68,7 +68,10 @@ var _ = Describe("KubeProxy", func() {
config := &KubeProxyTestConfig{ config := &KubeProxyTestConfig{
f: f, f: f,
} }
It("should test kube-proxy", func() { It("should test kube-proxy", func() {
SkipUnlessProviderIs(providersWithSSH...)
By("cleaning up any pre-existing namespaces used by this test") By("cleaning up any pre-existing namespaces used by this test")
config.cleanup() config.cleanup()
@@ -164,7 +167,7 @@ func (config *KubeProxyTestConfig) hitClusterIP(epCount int) {
} }
func (config *KubeProxyTestConfig) hitNodePort(epCount int) { func (config *KubeProxyTestConfig) hitNodePort(epCount int) {
node1_IP := strings.TrimSuffix(config.nodes[0], ":22") node1_IP := config.nodes[0]
tries := epCount*epCount + 5 // + 10 if epCount == 0 tries := epCount*epCount + 5 // + 10 if epCount == 0
By("dialing(udp) node1 --> node1:nodeUdpPort") By("dialing(udp) node1 --> node1:nodeUdpPort")
config.dialFromNode("udp", node1_IP, nodeUdpPort, tries, epCount) config.dialFromNode("udp", node1_IP, nodeUdpPort, tries, epCount)
@@ -188,7 +191,7 @@ func (config *KubeProxyTestConfig) hitNodePort(epCount int) {
By("Test disabled. dialing(http) node --> 127.0.0.1:nodeHttpPort") By("Test disabled. dialing(http) node --> 127.0.0.1:nodeHttpPort")
//config.dialFromNode("http", "127.0.0.1", nodeHttpPort, tries, epCount) //config.dialFromNode("http", "127.0.0.1", nodeHttpPort, tries, epCount)
node2_IP := strings.TrimSuffix(config.nodes[1], ":22") node2_IP := config.nodes[1]
By("dialing(udp) node1 --> node2:nodeUdpPort") By("dialing(udp) node1 --> node2:nodeUdpPort")
config.dialFromNode("udp", node2_IP, nodeUdpPort, tries, epCount) config.dialFromNode("udp", node2_IP, nodeUdpPort, tries, epCount)
By("dialing(http) node1 --> node2:nodeHttpPort") By("dialing(http) node1 --> node2:nodeHttpPort")
@@ -249,7 +252,7 @@ func (config *KubeProxyTestConfig) dialFromNode(protocol, targetIP string, targe
} }
func (config *KubeProxyTestConfig) ssh(cmd string) string { func (config *KubeProxyTestConfig) ssh(cmd string) string {
stdout, _, code, err := SSH(cmd, config.nodes[0], testContext.Provider) stdout, _, code, err := SSH(cmd, config.nodes[0]+":22", testContext.Provider)
Expect(err).NotTo(HaveOccurred(), "error while SSH-ing to node: %v (code %v)", err, code) Expect(err).NotTo(HaveOccurred(), "error while SSH-ing to node: %v (code %v)", err, code)
Expect(code).Should(BeZero(), "command exited with non-zero code %v. cmd:%s", code, cmd) Expect(code).Should(BeZero(), "command exited with non-zero code %v. cmd:%s", code, cmd)
return stdout return stdout
@@ -421,10 +424,10 @@ func (config *KubeProxyTestConfig) setup() {
By("Getting ssh-able hosts") By("Getting ssh-able hosts")
hosts, err := NodeSSHHosts(config.f.Client) hosts, err := NodeSSHHosts(config.f.Client)
Expect(err).NotTo(HaveOccurred()) Expect(err).NotTo(HaveOccurred())
if len(hosts) == 0 { config.nodes = make([]string, 0, len(hosts))
Failf("No ssh-able nodes") for _, h := range hosts {
config.nodes = append(config.nodes, strings.TrimSuffix(h, ":22"))
} }
config.nodes = hosts
if enableLoadBalancerTest { if enableLoadBalancerTest {
By("Creating the LoadBalancer Service on top of the pods in kubernetes") By("Creating the LoadBalancer Service on top of the pods in kubernetes")

View File

@@ -52,6 +52,7 @@ var _ = Describe("PrivilegedPod", func() {
f: f, f: f,
} }
It("should test privileged pod", func() { It("should test privileged pod", func() {
SkipUnlessProviderIs(providersWithSSH...)
By("Getting ssh-able hosts") By("Getting ssh-able hosts")
hosts, err := NodeSSHHosts(config.f.Client) hosts, err := NodeSSHHosts(config.f.Client)

View File

@@ -238,7 +238,7 @@ var _ = Describe("Services", func() {
It("should be able to up and down services", func() { It("should be able to up and down services", func() {
// this test uses NodeSSHHosts that does not work if a Node only reports LegacyHostIP // this test uses NodeSSHHosts that does not work if a Node only reports LegacyHostIP
SkipUnlessProviderIs("gce", "gke", "aws") SkipUnlessProviderIs(providersWithSSH...)
ns := namespaces[0] ns := namespaces[0]
numPods, servicePort := 3, 80 numPods, servicePort := 3, 80
@@ -532,6 +532,8 @@ var _ = Describe("Services", func() {
ip := pickNodeIP(c) ip := pickNodeIP(c)
testReachable(ip, nodePort) testReachable(ip, nodePort)
// this test uses NodeSSHHosts that does not work if a Node only reports LegacyHostIP
if providerIs(providersWithSSH...) {
hosts, err := NodeSSHHosts(c) hosts, err := NodeSSHHosts(c)
if err != nil { if err != nil {
Expect(err).NotTo(HaveOccurred()) Expect(err).NotTo(HaveOccurred())
@@ -541,6 +543,7 @@ var _ = Describe("Services", func() {
if code != 0 { if code != 0 {
Failf("expected node port (%d) to be in use", nodePort) Failf("expected node port (%d) to be in use", nodePort)
} }
}
}) })
It("should be able to change the type and nodeport settings of a service", func() { It("should be able to change the type and nodeport settings of a service", func() {
@@ -965,6 +968,8 @@ var _ = Describe("Services", func() {
err = t.DeleteService(serviceName) err = t.DeleteService(serviceName)
Expect(err).NotTo(HaveOccurred()) Expect(err).NotTo(HaveOccurred())
// this test uses NodeSSHHosts that does not work if a Node only reports LegacyHostIP
if providerIs(providersWithSSH...) {
hosts, err := NodeSSHHosts(c) hosts, err := NodeSSHHosts(c)
if err != nil { if err != nil {
Expect(err).NotTo(HaveOccurred()) Expect(err).NotTo(HaveOccurred())
@@ -974,6 +979,7 @@ var _ = Describe("Services", func() {
if code == 0 { if code == 0 {
Failf("expected node port (%d) to not be in use", nodePort) Failf("expected node port (%d) to not be in use", nodePort)
} }
}
By(fmt.Sprintf("creating service "+serviceName+" with same NodePort %d", nodePort)) By(fmt.Sprintf("creating service "+serviceName+" with same NodePort %d", nodePort))
service = t.BuildServiceSpec() service = t.BuildServiceSpec()

View File

@@ -35,7 +35,7 @@ var _ = Describe("SSH", func() {
Expect(err).NotTo(HaveOccurred()) Expect(err).NotTo(HaveOccurred())
// When adding more providers here, also implement their functionality in util.go's getSigner(...). // When adding more providers here, also implement their functionality in util.go's getSigner(...).
SkipUnlessProviderIs("gce", "gke") SkipUnlessProviderIs(providersWithSSH...)
}) })
It("should SSH to all nodes and run commands", func() { It("should SSH to all nodes and run commands", func() {

View File

@@ -242,6 +242,9 @@ func providerIs(providers ...string) bool {
return false return false
} }
// providersWithSSH are those providers where each node is accessible with SSH
var providersWithSSH = []string{"gce", "gke", "aws"}
type podCondition func(pod *api.Pod) (bool, error) type podCondition func(pod *api.Pod) (bool, error)
// podReady returns whether pod has a condition of Ready with a status of true. // podReady returns whether pod has a condition of Ready with a status of true.