mirror of https://github.com/kubevela/kubevela.git
143 lines
5.8 KiB
Makefile
143 lines
5.8 KiB
Makefile
.PHONY: e2e-setup-core-pre-hook
|
|
e2e-setup-core-pre-hook:
|
|
sh ./hack/e2e/modify_charts.sh
|
|
|
|
.PHONY: e2e-setup-core-post-hook
|
|
e2e-setup-core-post-hook:
|
|
kubectl wait --for=condition=Available deployment/kubevela-vela-core -n vela-system --timeout=180s
|
|
helm install kruise https://github.com/openkruise/charts/releases/download/kruise-1.1.0/kruise-1.1.0.tgz --set featureGates="PreDownloadImageForInPlaceUpdate=true" --set daemon.socketLocation=/run/k3s/containerd/
|
|
kill -9 $(lsof -it:9098) || true
|
|
go run ./e2e/addon/mock &
|
|
bin/vela addon enable ./e2e/addon/mock/testdata/fluxcd
|
|
bin/vela addon enable ./e2e/addon/mock/testdata/terraform
|
|
bin/vela addon enable ./e2e/addon/mock/testdata/terraform-alibaba ALICLOUD_ACCESS_KEY=xxx ALICLOUD_SECRET_KEY=yyy ALICLOUD_REGION=cn-beijing
|
|
|
|
timeout 600s bash -c -- 'while true; do kubectl get ns flux-system; if [ $$? -eq 0 ] ; then break; else sleep 5; fi;done'
|
|
kubectl wait --for=condition=Ready pod -l app.kubernetes.io/name=vela-core,app.kubernetes.io/instance=kubevela -n vela-system --timeout=600s
|
|
kubectl wait --for=condition=Ready pod -l app=source-controller -n flux-system --timeout=600s
|
|
kubectl wait --for=condition=Ready pod -l app=helm-controller -n flux-system --timeout=600s
|
|
|
|
.PHONY: e2e-setup-core-wo-auth
|
|
e2e-setup-core-wo-auth:
|
|
helm upgrade --install \
|
|
--create-namespace \
|
|
--namespace vela-system \
|
|
--set image.pullPolicy=IfNotPresent \
|
|
--set image.repository=vela-core-test \
|
|
--set applicationRevisionLimit=5 \
|
|
--set controllerArgs.reSyncPeriod=1m \
|
|
--set optimize.disableComponentRevision=false \
|
|
--set image.tag=$(GIT_COMMIT) \
|
|
--set multicluster.clusterGateway.image.repository=ghcr.io/oam-dev/cluster-gateway \
|
|
--set admissionWebhooks.patch.image.repository=ghcr.io/oam-dev/kube-webhook-certgen/kube-webhook-certgen \
|
|
--set featureGates.enableCueValidation=true \
|
|
--set featureGates.validateResourcesExist=true \
|
|
--wait kubevela ./charts/vela-core \
|
|
--debug
|
|
|
|
.PHONY: e2e-setup-core-w-auth
|
|
e2e-setup-core-w-auth:
|
|
helm upgrade --install \
|
|
--create-namespace \
|
|
--namespace vela-system \
|
|
--set image.pullPolicy=IfNotPresent \
|
|
--set image.repository=vela-core-test \
|
|
--set applicationRevisionLimit=5 \
|
|
--set optimize.disableComponentRevision=false \
|
|
--set image.tag=$(GIT_COMMIT) \
|
|
--wait kubevela \
|
|
./charts/vela-core \
|
|
--set authentication.enabled=true \
|
|
--set authentication.withUser=true \
|
|
--set authentication.groupPattern='*' \
|
|
--set featureGates.zstdResourceTracker=true \
|
|
--set featureGates.zstdApplicationRevision=true \
|
|
--set featureGates.validateComponentWhenSharding=true \
|
|
--set featureGates.validateResourcesExist=true \
|
|
--set multicluster.clusterGateway.enabled=true \
|
|
--set multicluster.clusterGateway.image.repository=ghcr.io/oam-dev/cluster-gateway \
|
|
--set admissionWebhooks.patch.image.repository=ghcr.io/oam-dev/kube-webhook-certgen/kube-webhook-certgen \
|
|
--set sharding.enabled=true \
|
|
--debug
|
|
kubectl get deploy kubevela-vela-core -oyaml -n vela-system | \
|
|
sed 's/schedulable-shards=/shard-id=shard-0/g' | \
|
|
sed 's/instance: kubevela/instance: kubevela-shard/g' | \
|
|
sed 's/shard-id: master/shard-id: shard-0/g' | \
|
|
sed 's/name: kubevela/name: kubevela-shard/g' | \
|
|
kubectl apply -f -
|
|
kubectl wait deployment -n vela-system kubevela-shard-vela-core --for condition=Available=True --timeout=90s
|
|
|
|
|
|
.PHONY: e2e-setup-core
|
|
e2e-setup-core: e2e-setup-core-pre-hook e2e-setup-core-wo-auth e2e-setup-core-post-hook
|
|
|
|
.PHONY: e2e-setup-core-auth
|
|
e2e-setup-core-auth: e2e-setup-core-pre-hook e2e-setup-core-w-auth e2e-setup-core-post-hook
|
|
|
|
.PHONY: e2e-api-test
|
|
e2e-api-test:
|
|
# Run e2e test
|
|
ginkgo -v -skipPackage capability,setup,application -r e2e
|
|
ginkgo -v -r e2e/application
|
|
|
|
|
|
.PHONY: e2e-test
|
|
e2e-test:
|
|
# Run e2e test
|
|
ginkgo -v ./test/e2e-test
|
|
@$(OK) tests pass
|
|
|
|
# Run e2e tests with k3d and webhook validation
|
|
.PHONY: e2e-test-local
|
|
e2e-test-local:
|
|
# Create k3d cluster if needed
|
|
@k3d cluster create kubevela-debug --servers 1 --agents 1 || true
|
|
# Build and load image
|
|
docker build -t vela-core:e2e-test -f Dockerfile . --build-arg=VERSION=e2e-test --build-arg=GITVERSION=test
|
|
k3d image import vela-core:e2e-test -c kubevela-debug
|
|
# Deploy with Helm
|
|
kubectl delete validatingwebhookconfiguration kubevela-vela-core-admission 2>/dev/null || true
|
|
helm upgrade --install kubevela ./charts/vela-core \
|
|
--namespace vela-system --create-namespace \
|
|
--set image.repository=vela-core \
|
|
--set image.tag=e2e-test \
|
|
--set image.pullPolicy=IfNotPresent \
|
|
--set admissionWebhooks.enabled=true \
|
|
--set featureGates.enableCueValidation=true \
|
|
--set featureGates.validateResourcesExist=true \
|
|
--set applicationRevisionLimit=5 \
|
|
--set controllerArgs.reSyncPeriod=1m \
|
|
--wait --timeout 3m
|
|
# Run tests
|
|
ginkgo -v ./test/e2e-test
|
|
@$(OK) tests pass
|
|
|
|
|
|
.PHONY: e2e-addon-test
|
|
e2e-addon-test:
|
|
cp bin/vela /tmp/
|
|
ginkgo -v ./test/e2e-addon-test
|
|
@$(OK) tests pass
|
|
|
|
.PHONY: e2e-multicluster-test
|
|
e2e-multicluster-test:
|
|
cd ./test/e2e-multicluster-test && go test -v -ginkgo.v -ginkgo.trace -coverpkg=./... -coverprofile=/tmp/e2e_multicluster_test.out
|
|
@$(OK) tests pass
|
|
|
|
.PHONY: e2e-cleanup
|
|
e2e-cleanup:
|
|
# Clean up
|
|
rm -rf ~/.vela
|
|
|
|
.PHONY: end-e2e-core
|
|
end-e2e-core:
|
|
sh ./hack/e2e/end_e2e_core.sh
|
|
|
|
.PHONY: end-e2e-core-shards
|
|
end-e2e-core-shards: end-e2e-core
|
|
CORE_NAME=kubevela-shard sh ./hack/e2e/end_e2e_core.sh
|
|
|
|
.PHONY: end-e2e
|
|
end-e2e:
|
|
sh ./hack/e2e/end_e2e.sh
|