Files
kubevela/test/e2e-multicluster-test/multicluster_cli_test.go

107 lines
3.3 KiB
Go

/*
Copyright 2021 The KubeVela Authors.
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_multicluster_test
import (
"context"
"io/ioutil"
"net/http"
"os/exec"
"strings"
"time"
. "github.com/onsi/ginkgo"
. "github.com/onsi/gomega"
"github.com/onsi/gomega/gexec"
v1 "k8s.io/api/core/v1"
"sigs.k8s.io/controller-runtime/pkg/client"
"sigs.k8s.io/yaml"
"github.com/oam-dev/kubevela/apis/core.oam.dev/v1beta1"
)
var _ = Describe("Test multicluster CLI commands", func() {
var namespace string
var hubCtx context.Context
var workerCtx context.Context
var app *v1beta1.Application
BeforeEach(func() {
hubCtx, workerCtx, namespace = initializeContextAndNamespace()
app = &v1beta1.Application{}
bs, err := ioutil.ReadFile("./testdata/app/example-vela-cli-tool-test-app.yaml")
Expect(err).Should(Succeed())
appYaml := strings.ReplaceAll(string(bs), "TEST_NAMESPACE", namespace)
Expect(yaml.Unmarshal([]byte(appYaml), app)).Should(Succeed())
app.SetNamespace(namespace)
Expect(k8sClient.Create(hubCtx, app)).Should(Succeed())
Expect(err).Should(Succeed())
Eventually(func(g Gomega) {
pods := &v1.PodList{}
g.Expect(k8sClient.List(workerCtx, pods, client.InNamespace(namespace))).Should(Succeed())
g.Expect(len(pods.Items)).Should(Equal(1))
g.Expect(pods.Items[0].Status.Phase).Should(Equal(v1.PodRunning))
g.Expect(k8sClient.Get(hubCtx, client.ObjectKeyFromObject(app), app)).Should(Succeed())
g.Expect(len(app.Status.AppliedResources)).ShouldNot(Equal(0))
}, 2*time.Minute).Should(Succeed())
})
AfterEach(func() {
Expect(k8sClient.Get(hubCtx, client.ObjectKeyFromObject(app), app)).Should(Succeed())
Expect(k8sClient.Delete(hubCtx, app)).Should(Succeed())
cleanUpNamespace(hubCtx, workerCtx, namespace)
})
Context("Test debugging tools in multicluster", func() {
It("Test vela exec", func() {
command := exec.Command("vela", "exec", app.Name, "-n", namespace, "-i=false", "-t=false", "--", "pwd")
outputs, err := command.CombinedOutput()
Expect(err).Should(Succeed())
Expect(string(outputs)).Should(ContainSubstring("/"))
})
It("Test vela port-forward", func() {
stopChannel := make(chan struct{}, 1)
go func() {
defer GinkgoRecover()
command := exec.Command("vela", "port-forward", app.Name, "-n", namespace)
session, err := gexec.Start(command, ioutil.Discard, ioutil.Discard)
Expect(err).Should(Succeed())
<-stopChannel
session.Terminate()
}()
defer func() {
stopChannel <- struct{}{}
}()
var resp *http.Response
var err error
Eventually(func(g Gomega) {
resp, err = http.Get("http://127.0.0.1:8000")
g.Expect(err).Should(Succeed())
}, time.Minute).Should(Succeed())
bs := make([]byte, 128)
_, err = resp.Body.Read(bs)
Expect(err).Should(Succeed())
Expect(string(bs)).Should(ContainSubstring("Hello World"))
})
})
})