mirror of
https://github.com/vmware-tanzu/velero.git
synced 2026-01-05 04:55:22 +00:00
139 lines
4.8 KiB
Go
139 lines
4.8 KiB
Go
/*
|
|
Copyright the Velero contributors.
|
|
|
|
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 k8s
|
|
|
|
import (
|
|
"fmt"
|
|
"io/ioutil"
|
|
"os/exec"
|
|
"time"
|
|
|
|
"github.com/pkg/errors"
|
|
"golang.org/x/net/context"
|
|
corev1api "k8s.io/api/core/v1"
|
|
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
|
"k8s.io/apimachinery/pkg/util/wait"
|
|
|
|
"github.com/vmware-tanzu/velero/pkg/builder"
|
|
common "github.com/vmware-tanzu/velero/test/e2e/util/common"
|
|
)
|
|
|
|
// ensureClusterExists returns whether or not a kubernetes cluster exists for tests to be run on.
|
|
func EnsureClusterExists(ctx context.Context) error {
|
|
return exec.CommandContext(ctx, "kubectl", "cluster-info").Run()
|
|
}
|
|
|
|
func CreateSecretFromFiles(ctx context.Context, client TestClient, namespace string, name string, files map[string]string) error {
|
|
data := make(map[string][]byte)
|
|
|
|
for key, filePath := range files {
|
|
contents, err := ioutil.ReadFile(filePath)
|
|
if err != nil {
|
|
return errors.WithMessagef(err, "Failed to read secret file %q", filePath)
|
|
}
|
|
|
|
data[key] = contents
|
|
}
|
|
|
|
secret := builder.ForSecret(namespace, name).Data(data).Result()
|
|
_, err := client.ClientGo.CoreV1().Secrets(namespace).Create(ctx, secret, metav1.CreateOptions{})
|
|
return err
|
|
}
|
|
|
|
// WaitForPods waits until all of the pods have gone to PodRunning state
|
|
func WaitForPods(ctx context.Context, client TestClient, namespace string, pods []string) error {
|
|
timeout := 10 * time.Minute
|
|
interval := 5 * time.Second
|
|
err := wait.PollImmediate(interval, timeout, func() (bool, error) {
|
|
for _, podName := range pods {
|
|
checkPod, err := client.ClientGo.CoreV1().Pods(namespace).Get(ctx, podName, metav1.GetOptions{})
|
|
if err != nil {
|
|
return false, errors.WithMessage(err, fmt.Sprintf("Failed to verify pod %s/%s is %s", namespace, podName, corev1api.PodRunning))
|
|
}
|
|
// If any pod is still waiting we don't need to check any more so return and wait for next poll interval
|
|
if checkPod.Status.Phase != corev1api.PodRunning {
|
|
fmt.Printf("Pod %s is in state %s waiting for it to be %s\n", podName, checkPod.Status.Phase, corev1api.PodRunning)
|
|
return false, nil
|
|
}
|
|
}
|
|
// All pods were in PodRunning state, we're successful
|
|
return true, nil
|
|
})
|
|
if err != nil {
|
|
return errors.Wrapf(err, fmt.Sprintf("Failed to wait for pods in namespace %s to start running", namespace))
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func GetPvcByPodName(ctx context.Context, namespace, podName string) ([]string, error) {
|
|
// Example:
|
|
// NAME STATUS VOLUME CAPACITY ACCESS MODES STORAGECLASS AGE
|
|
// kibishii-data-kibishii-deployment-0 Bound pvc-94b9fdf2-c30f-4a7b-87bf-06eadca0d5b6 1Gi RWO kibishii-storage-class 115s
|
|
CmdLine1 := &common.OsCommandLine{
|
|
Cmd: "kubectl",
|
|
Args: []string{"get", "pvc", "-n", namespace},
|
|
}
|
|
CmdLine2 := &common.OsCommandLine{
|
|
Cmd: "grep",
|
|
Args: []string{podName},
|
|
}
|
|
CmdLine3 := &common.OsCommandLine{
|
|
Cmd: "awk",
|
|
Args: []string{"{print $1}"},
|
|
}
|
|
|
|
return common.GetListBy2Pipes(ctx, *CmdLine1, *CmdLine2, *CmdLine3)
|
|
}
|
|
|
|
func GetPvByPvc(ctx context.Context, pvc string) ([]string, error) {
|
|
// Example:
|
|
// NAME CAPACITY ACCESS MODES RECLAIM POLICY STATUS CLAIM STORAGECLASS REASON AGE
|
|
// pvc-3f784366-58db-40b2-8fec-77307807e74b 1Gi RWO Delete Bound bsl-deletion/kibishii-data-kibishii-deployment-0 kibishii-storage-class 6h41m
|
|
CmdLine1 := &common.OsCommandLine{
|
|
Cmd: "kubectl",
|
|
Args: []string{"get", "pv"},
|
|
}
|
|
|
|
CmdLine2 := &common.OsCommandLine{
|
|
Cmd: "grep",
|
|
Args: []string{pvc},
|
|
}
|
|
|
|
CmdLine3 := &common.OsCommandLine{
|
|
Cmd: "awk",
|
|
Args: []string{"{print $1}"},
|
|
}
|
|
|
|
return common.GetListBy2Pipes(ctx, *CmdLine1, *CmdLine2, *CmdLine3)
|
|
}
|
|
|
|
func AddLabelToPv(ctx context.Context, pv, label string) error {
|
|
return exec.CommandContext(ctx, "kubectl", "label", "pv", pv, label).Run()
|
|
}
|
|
|
|
func AddLabelToPvc(ctx context.Context, pvc, namespace, label string) error {
|
|
args := []string{"label", "pvc", pvc, "-n", namespace, label}
|
|
fmt.Println(args)
|
|
return exec.CommandContext(ctx, "kubectl", args...).Run()
|
|
}
|
|
|
|
func AddLabelToPod(ctx context.Context, podName, namespace, label string) error {
|
|
args := []string{"label", "pod", podName, "-n", namespace, label}
|
|
fmt.Println(args)
|
|
return exec.CommandContext(ctx, "kubectl", args...).Run()
|
|
}
|