2015-08-21 01:23:24 +00:00
|
|
|
/*
|
2016-06-03 00:25:58 +00:00
|
|
|
Copyright 2014 The Kubernetes Authors.
|
2015-08-21 01:23:24 +00:00
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
package e2e
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"os/exec"
|
|
|
|
"regexp"
|
|
|
|
"strings"
|
2015-10-07 20:48:28 +00:00
|
|
|
"time"
|
2015-09-17 22:21:55 +00:00
|
|
|
|
|
|
|
"github.com/golang/glog"
|
2016-04-07 17:21:31 +00:00
|
|
|
|
2016-04-27 00:39:48 +00:00
|
|
|
"k8s.io/kubernetes/pkg/cloudprovider/providers/gce"
|
2016-04-07 17:21:31 +00:00
|
|
|
"k8s.io/kubernetes/test/e2e/framework"
|
2015-08-21 01:23:24 +00:00
|
|
|
)
|
|
|
|
|
Improve the error handling when creating/delete GCE IPs in e2e tests.
Prior to this, test failures caused by errors in these helpers printed
out long exec.ExitErrors structs that didn't contain any useful info,
for example:
```
Expected error:
<*exec.ExitError | 0xc20804e518>: {
ProcessState: {
pid: 22855,
status: 256,
rusage: {
Utime: {Sec: 0, Usec: 312000},
Stime: {Sec: 0, Usec: 96000},
Maxrss: 42912,
Ixrss: 0,
Idrss: 0,
Isrss: 0,
Minflt: 21667,
Majflt: 0,
Nswap: 0,
Inblock: 0,
Oublock: 40,
Msgsnd: 0,
Msgrcv: 0,
Nsignals: 0,
Nvcsw: 52,
Nivcsw: 34,
},
},
}
exit status 1
not to have occurred
```
2015-10-09 22:29:42 +00:00
|
|
|
// TODO: These should really just use the GCE API client library or at least use
|
|
|
|
// better formatted output from the --format flag.
|
|
|
|
|
2015-08-21 01:23:24 +00:00
|
|
|
func createGCEStaticIP(name string) (string, error) {
|
|
|
|
// gcloud compute --project "abshah-kubernetes-001" addresses create "test-static-ip" --region "us-central1"
|
|
|
|
// abshah@abhidesk:~/go/src/code.google.com/p/google-api-go-client/compute/v1$ gcloud compute --project "abshah-kubernetes-001" addresses create "test-static-ip" --region "us-central1"
|
|
|
|
// Created [https://www.googleapis.com/compute/v1/projects/abshah-kubernetes-001/regions/us-central1/addresses/test-static-ip].
|
|
|
|
// NAME REGION ADDRESS STATUS
|
|
|
|
// test-static-ip us-central1 104.197.143.7 RESERVED
|
|
|
|
|
Improve the error handling when creating/delete GCE IPs in e2e tests.
Prior to this, test failures caused by errors in these helpers printed
out long exec.ExitErrors structs that didn't contain any useful info,
for example:
```
Expected error:
<*exec.ExitError | 0xc20804e518>: {
ProcessState: {
pid: 22855,
status: 256,
rusage: {
Utime: {Sec: 0, Usec: 312000},
Stime: {Sec: 0, Usec: 96000},
Maxrss: 42912,
Ixrss: 0,
Idrss: 0,
Isrss: 0,
Minflt: 21667,
Majflt: 0,
Nswap: 0,
Inblock: 0,
Oublock: 40,
Msgsnd: 0,
Msgrcv: 0,
Nsignals: 0,
Nvcsw: 52,
Nivcsw: 34,
},
},
}
exit status 1
not to have occurred
```
2015-10-09 22:29:42 +00:00
|
|
|
var outputBytes []byte
|
2015-10-07 20:48:28 +00:00
|
|
|
var err error
|
2016-04-27 00:39:48 +00:00
|
|
|
region, err := gce.GetGCERegion(framework.TestContext.CloudConfig.Zone)
|
|
|
|
if err != nil {
|
|
|
|
return "", fmt.Errorf("failed to convert zone to region: %v", err)
|
|
|
|
}
|
|
|
|
glog.Infof("Creating static IP with name %q in project %q in region %q", name, framework.TestContext.CloudConfig.ProjectID, region)
|
2015-10-07 20:48:28 +00:00
|
|
|
for attempts := 0; attempts < 4; attempts++ {
|
Improve the error handling when creating/delete GCE IPs in e2e tests.
Prior to this, test failures caused by errors in these helpers printed
out long exec.ExitErrors structs that didn't contain any useful info,
for example:
```
Expected error:
<*exec.ExitError | 0xc20804e518>: {
ProcessState: {
pid: 22855,
status: 256,
rusage: {
Utime: {Sec: 0, Usec: 312000},
Stime: {Sec: 0, Usec: 96000},
Maxrss: 42912,
Ixrss: 0,
Idrss: 0,
Isrss: 0,
Minflt: 21667,
Majflt: 0,
Nswap: 0,
Inblock: 0,
Oublock: 40,
Msgsnd: 0,
Msgrcv: 0,
Nsignals: 0,
Nvcsw: 52,
Nivcsw: 34,
},
},
}
exit status 1
not to have occurred
```
2015-10-09 22:29:42 +00:00
|
|
|
outputBytes, err = exec.Command("gcloud", "compute", "addresses", "create",
|
2016-04-07 17:21:31 +00:00
|
|
|
name, "--project", framework.TestContext.CloudConfig.ProjectID,
|
2016-04-27 00:39:48 +00:00
|
|
|
"--region", region, "-q").CombinedOutput()
|
2015-10-07 20:48:28 +00:00
|
|
|
if err == nil {
|
|
|
|
break
|
|
|
|
}
|
Improve the error handling when creating/delete GCE IPs in e2e tests.
Prior to this, test failures caused by errors in these helpers printed
out long exec.ExitErrors structs that didn't contain any useful info,
for example:
```
Expected error:
<*exec.ExitError | 0xc20804e518>: {
ProcessState: {
pid: 22855,
status: 256,
rusage: {
Utime: {Sec: 0, Usec: 312000},
Stime: {Sec: 0, Usec: 96000},
Maxrss: 42912,
Ixrss: 0,
Idrss: 0,
Isrss: 0,
Minflt: 21667,
Majflt: 0,
Nswap: 0,
Inblock: 0,
Oublock: 40,
Msgsnd: 0,
Msgrcv: 0,
Nsignals: 0,
Nvcsw: 52,
Nivcsw: 34,
},
},
}
exit status 1
not to have occurred
```
2015-10-09 22:29:42 +00:00
|
|
|
glog.Errorf("output from failed attempt to create static IP: %s", outputBytes)
|
2015-10-07 20:48:28 +00:00
|
|
|
time.Sleep(time.Duration(5*attempts) * time.Second)
|
|
|
|
}
|
|
|
|
if err != nil {
|
Improve the error handling when creating/delete GCE IPs in e2e tests.
Prior to this, test failures caused by errors in these helpers printed
out long exec.ExitErrors structs that didn't contain any useful info,
for example:
```
Expected error:
<*exec.ExitError | 0xc20804e518>: {
ProcessState: {
pid: 22855,
status: 256,
rusage: {
Utime: {Sec: 0, Usec: 312000},
Stime: {Sec: 0, Usec: 96000},
Maxrss: 42912,
Ixrss: 0,
Idrss: 0,
Isrss: 0,
Minflt: 21667,
Majflt: 0,
Nswap: 0,
Inblock: 0,
Oublock: 40,
Msgsnd: 0,
Msgrcv: 0,
Nsignals: 0,
Nvcsw: 52,
Nivcsw: 34,
},
},
}
exit status 1
not to have occurred
```
2015-10-09 22:29:42 +00:00
|
|
|
// Ditch the error, since the stderr in the output is what actually contains
|
|
|
|
// any useful info.
|
|
|
|
return "", fmt.Errorf("failed to create static IP: %s", outputBytes)
|
2015-08-21 01:23:24 +00:00
|
|
|
}
|
Improve the error handling when creating/delete GCE IPs in e2e tests.
Prior to this, test failures caused by errors in these helpers printed
out long exec.ExitErrors structs that didn't contain any useful info,
for example:
```
Expected error:
<*exec.ExitError | 0xc20804e518>: {
ProcessState: {
pid: 22855,
status: 256,
rusage: {
Utime: {Sec: 0, Usec: 312000},
Stime: {Sec: 0, Usec: 96000},
Maxrss: 42912,
Ixrss: 0,
Idrss: 0,
Isrss: 0,
Minflt: 21667,
Majflt: 0,
Nswap: 0,
Inblock: 0,
Oublock: 40,
Msgsnd: 0,
Msgrcv: 0,
Nsignals: 0,
Nvcsw: 52,
Nivcsw: 34,
},
},
}
exit status 1
not to have occurred
```
2015-10-09 22:29:42 +00:00
|
|
|
output := string(outputBytes)
|
|
|
|
if strings.Contains(output, "RESERVED") {
|
2015-08-21 01:23:24 +00:00
|
|
|
r, _ := regexp.Compile("[0-9]+\\.[0-9]+\\.[0-9]+\\.[0-9]+")
|
Improve the error handling when creating/delete GCE IPs in e2e tests.
Prior to this, test failures caused by errors in these helpers printed
out long exec.ExitErrors structs that didn't contain any useful info,
for example:
```
Expected error:
<*exec.ExitError | 0xc20804e518>: {
ProcessState: {
pid: 22855,
status: 256,
rusage: {
Utime: {Sec: 0, Usec: 312000},
Stime: {Sec: 0, Usec: 96000},
Maxrss: 42912,
Ixrss: 0,
Idrss: 0,
Isrss: 0,
Minflt: 21667,
Majflt: 0,
Nswap: 0,
Inblock: 0,
Oublock: 40,
Msgsnd: 0,
Msgrcv: 0,
Nsignals: 0,
Nvcsw: 52,
Nivcsw: 34,
},
},
}
exit status 1
not to have occurred
```
2015-10-09 22:29:42 +00:00
|
|
|
staticIP := r.FindString(output)
|
2015-08-21 01:23:24 +00:00
|
|
|
if staticIP == "" {
|
Improve the error handling when creating/delete GCE IPs in e2e tests.
Prior to this, test failures caused by errors in these helpers printed
out long exec.ExitErrors structs that didn't contain any useful info,
for example:
```
Expected error:
<*exec.ExitError | 0xc20804e518>: {
ProcessState: {
pid: 22855,
status: 256,
rusage: {
Utime: {Sec: 0, Usec: 312000},
Stime: {Sec: 0, Usec: 96000},
Maxrss: 42912,
Ixrss: 0,
Idrss: 0,
Isrss: 0,
Minflt: 21667,
Majflt: 0,
Nswap: 0,
Inblock: 0,
Oublock: 40,
Msgsnd: 0,
Msgrcv: 0,
Nsignals: 0,
Nvcsw: 52,
Nivcsw: 34,
},
},
}
exit status 1
not to have occurred
```
2015-10-09 22:29:42 +00:00
|
|
|
return "", fmt.Errorf("static IP not found in gcloud command output: %v", output)
|
2015-08-21 01:23:24 +00:00
|
|
|
} else {
|
|
|
|
return staticIP, nil
|
|
|
|
}
|
|
|
|
} else {
|
Improve the error handling when creating/delete GCE IPs in e2e tests.
Prior to this, test failures caused by errors in these helpers printed
out long exec.ExitErrors structs that didn't contain any useful info,
for example:
```
Expected error:
<*exec.ExitError | 0xc20804e518>: {
ProcessState: {
pid: 22855,
status: 256,
rusage: {
Utime: {Sec: 0, Usec: 312000},
Stime: {Sec: 0, Usec: 96000},
Maxrss: 42912,
Ixrss: 0,
Idrss: 0,
Isrss: 0,
Minflt: 21667,
Majflt: 0,
Nswap: 0,
Inblock: 0,
Oublock: 40,
Msgsnd: 0,
Msgrcv: 0,
Nsignals: 0,
Nvcsw: 52,
Nivcsw: 34,
},
},
}
exit status 1
not to have occurred
```
2015-10-09 22:29:42 +00:00
|
|
|
return "", fmt.Errorf("static IP %q could not be reserved: %v", name, output)
|
2015-08-21 01:23:24 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func deleteGCEStaticIP(name string) error {
|
|
|
|
// gcloud compute --project "abshah-kubernetes-001" addresses create "test-static-ip" --region "us-central1"
|
|
|
|
// abshah@abhidesk:~/go/src/code.google.com/p/google-api-go-client/compute/v1$ gcloud compute --project "abshah-kubernetes-001" addresses create "test-static-ip" --region "us-central1"
|
|
|
|
// Created [https://www.googleapis.com/compute/v1/projects/abshah-kubernetes-001/regions/us-central1/addresses/test-static-ip].
|
|
|
|
// NAME REGION ADDRESS STATUS
|
|
|
|
// test-static-ip us-central1 104.197.143.7 RESERVED
|
|
|
|
|
2016-04-27 00:39:48 +00:00
|
|
|
region, err := gce.GetGCERegion(framework.TestContext.CloudConfig.Zone)
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("failed to convert zone to region: %v", err)
|
|
|
|
}
|
|
|
|
glog.Infof("Deleting static IP with name %q in project %q in region %q", name, framework.TestContext.CloudConfig.ProjectID, region)
|
Improve the error handling when creating/delete GCE IPs in e2e tests.
Prior to this, test failures caused by errors in these helpers printed
out long exec.ExitErrors structs that didn't contain any useful info,
for example:
```
Expected error:
<*exec.ExitError | 0xc20804e518>: {
ProcessState: {
pid: 22855,
status: 256,
rusage: {
Utime: {Sec: 0, Usec: 312000},
Stime: {Sec: 0, Usec: 96000},
Maxrss: 42912,
Ixrss: 0,
Idrss: 0,
Isrss: 0,
Minflt: 21667,
Majflt: 0,
Nswap: 0,
Inblock: 0,
Oublock: 40,
Msgsnd: 0,
Msgrcv: 0,
Nsignals: 0,
Nvcsw: 52,
Nivcsw: 34,
},
},
}
exit status 1
not to have occurred
```
2015-10-09 22:29:42 +00:00
|
|
|
outputBytes, err := exec.Command("gcloud", "compute", "addresses", "delete",
|
2016-04-07 17:21:31 +00:00
|
|
|
name, "--project", framework.TestContext.CloudConfig.ProjectID,
|
2016-04-27 00:39:48 +00:00
|
|
|
"--region", region, "-q").CombinedOutput()
|
Improve the error handling when creating/delete GCE IPs in e2e tests.
Prior to this, test failures caused by errors in these helpers printed
out long exec.ExitErrors structs that didn't contain any useful info,
for example:
```
Expected error:
<*exec.ExitError | 0xc20804e518>: {
ProcessState: {
pid: 22855,
status: 256,
rusage: {
Utime: {Sec: 0, Usec: 312000},
Stime: {Sec: 0, Usec: 96000},
Maxrss: 42912,
Ixrss: 0,
Idrss: 0,
Isrss: 0,
Minflt: 21667,
Majflt: 0,
Nswap: 0,
Inblock: 0,
Oublock: 40,
Msgsnd: 0,
Msgrcv: 0,
Nsignals: 0,
Nvcsw: 52,
Nivcsw: 34,
},
},
}
exit status 1
not to have occurred
```
2015-10-09 22:29:42 +00:00
|
|
|
if err != nil {
|
|
|
|
// Ditch the error, since the stderr in the output is what actually contains
|
|
|
|
// any useful info.
|
|
|
|
return fmt.Errorf("failed to delete static IP %q: %v", name, string(outputBytes))
|
|
|
|
}
|
|
|
|
return nil
|
2015-08-21 01:23:24 +00:00
|
|
|
}
|