Compatibility E2E Test(API v1 - Golang Client) #125
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Compatibility E2E Test(API v1 - Golang Client) | |
on: | |
push: | |
branches: [main, release-*] | |
paths-ignore: ["**.md", "**.png", "**.jpg", "**.svg", "**/docs/**"] | |
pull_request: | |
branches: [main, release-*] | |
paths-ignore: ["**.md", "**.png", "**.jpg", "**.svg", "**/docs/**"] | |
schedule: | |
- cron: '0 4 * * *' | |
env: | |
KIND_VERSION: v0.12.0 | |
CONTAINERD_VERSION: v1.5.2 | |
KIND_CONFIG_PATH: test/testdata/kind/config.yaml | |
DRAGONFLY_CHARTS_PATH: deploy/helm-charts/charts/dragonfly | |
DRAGONFLY_CHARTS_CONFIG_PATH: test/testdata/charts/config-compatibility.yaml | |
DRAGONFLY_FILE_SERVER_PATH: test/testdata/k8s/file-server.yaml | |
DRAGONFLY_FILE_SERVER_NO_CONTENT_LENGTH_PATH: test/testdata/k8s/file-server-no-content-length.yaml | |
DRAGONFLY_PROXY_SERVER_PATH: test/testdata/k8s/proxy.yaml | |
jobs: | |
compatibility_e2e_tests: | |
timeout-minutes: 60 | |
runs-on: ubuntu-latest | |
strategy: | |
matrix: | |
module: ["manager", "scheduler", "dfdaemon", "seed-peer"] | |
include: | |
- module: manager | |
image: manager | |
image-tag: v2.0.9 | |
chart-name: manager | |
- module: scheduler | |
image: scheduler | |
image-tag: v2.0.9 | |
chart-name: scheduler | |
- module: dfdaemon | |
image: dfdaemon | |
image-tag: v2.0.2 | |
chart-name: dfdaemon | |
- module: seed-peer | |
image: dfdaemon | |
image-tag: v2.0.9 | |
chart-name: seedPeer | |
steps: | |
- name: Free Disk Space (Ubuntu) | |
uses: jlumbroso/free-disk-space@main | |
with: | |
tool-cache: false | |
android: true | |
dotnet: true | |
haskell: true | |
large-packages: true | |
docker-images: true | |
swap-storage: true | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
with: | |
submodules: recursive | |
- name: Install Go | |
uses: actions/setup-go@v5 | |
with: | |
go-version-file: go.mod | |
- name: Get dependencies | |
run: | | |
go install github.com/onsi/ginkgo/v2/[email protected] | |
mkdir -p /tmp/artifact | |
go mod vendor | |
- name: Setup buildx | |
uses: docker/setup-buildx-action@v3 | |
id: buildx | |
with: | |
install: true | |
- name: Cache Docker layers | |
uses: actions/cache@v4 | |
with: | |
path: /tmp/.buildx-cache | |
key: ${{ runner.os }}-buildx-${{ github.sha }} | |
restore-keys: | | |
${{ runner.os }}-buildx- | |
- name: Build Scheduler Image | |
uses: docker/build-push-action@v6 | |
with: | |
context: . | |
file: build/images/scheduler/Dockerfile | |
push: false | |
load: true | |
tags: dragonflyoss/scheduler:latest | |
cache-from: type=local,src=/tmp/.buildx-cache | |
cache-to: type=local,dest=/tmp/.buildx-cache-new | |
- name: Build Manager Image | |
uses: docker/build-push-action@v6 | |
with: | |
context: . | |
file: build/images/manager/Dockerfile | |
push: false | |
load: true | |
tags: dragonflyoss/manager:latest | |
cache-from: type=local,src=/tmp/.buildx-cache | |
cache-to: type=local,dest=/tmp/.buildx-cache-new | |
- name: Build Dfdaemon Image | |
uses: docker/build-push-action@v6 | |
with: | |
context: . | |
file: build/images/dfdaemon/Dockerfile | |
push: false | |
load: true | |
tags: dragonflyoss/dfdaemon:latest | |
cache-from: type=local,src=/tmp/.buildx-cache | |
cache-to: type=local,dest=/tmp/.buildx-cache-new | |
- name: Build No Content Length Image | |
uses: docker/build-push-action@v6 | |
with: | |
context: test/tools/no-content-length/ | |
file: test/tools/no-content-length/Dockerfile | |
push: false | |
load: true | |
tags: dragonflyoss/no-content-length:latest | |
cache-from: type=local,src=/tmp/.buildx-cache | |
cache-to: type=local,dest=/tmp/.buildx-cache-new | |
- name: Setup Kind | |
uses: helm/[email protected] | |
with: | |
version: ${{ env.KIND_VERSION }} | |
config: ${{ env.KIND_CONFIG_PATH }} | |
cluster_name: kind | |
- name: Kind load images | |
run: | | |
kind load docker-image dragonflyoss/manager:latest | |
kind load docker-image dragonflyoss/scheduler:latest | |
kind load docker-image dragonflyoss/dfdaemon:latest | |
kind load docker-image dragonflyoss/no-content-length:latest | |
- name: Setup dragonfly | |
run: | | |
helm install --wait --timeout 10m --dependency-update --create-namespace --namespace dragonfly-system --set ${{ matrix.chart-name }}.image.tag=${{ matrix.image-tag }} --set ${{ matrix.chart-name }}.image.repository=dragonflyoss/${{ matrix.image }} -f ${{ env.DRAGONFLY_CHARTS_CONFIG_PATH }} dragonfly ${{ env.DRAGONFLY_CHARTS_PATH }} | |
kubectl apply -f ${{ env.DRAGONFLY_FILE_SERVER_PATH }} | |
kubectl apply -f ${{ env.DRAGONFLY_FILE_SERVER_NO_CONTENT_LENGTH_PATH }} | |
kubectl apply -f ${{ env.DRAGONFLY_PROXY_SERVER_PATH }} | |
kubectl wait po file-server-0 --namespace dragonfly-e2e --for=condition=ready --timeout=10m | |
kubectl wait po file-server-no-content-length-0 --namespace dragonfly-e2e --for=condition=ready --timeout=10m | |
kubectl wait po proxy-0 --namespace dragonfly-e2e --for=condition=ready --timeout=10m | |
kubectl wait po proxy-1 --namespace dragonfly-e2e --for=condition=ready --timeout=10m | |
kubectl wait po proxy-2 --namespace dragonfly-e2e --for=condition=ready --timeout=10m | |
- name: Run Compatibility E2E test | |
env: | |
DRAGONFLY_COMPATIBILITY_E2E_TEST_MODE: ${{ matrix.module }} | |
DRAGONFLY_COMPATIBILITY_E2E_TEST_IMAGE: ${{ matrix.image }} | |
DRAGONFLY_STABLE_IMAGE_TAG: ${{ matrix.image-tag }} | |
run: | | |
ginkgo -v -r --race --fail-fast --cover --trace --show-node-events test/e2e/v1 | |
cat coverprofile.out >> coverage.txt | |
- name: Move cache | |
run: | | |
rm -rf /tmp/.buildx-cache | |
mv /tmp/.buildx-cache-new /tmp/.buildx-cache | |
- name: Upload coverage to Codecov | |
uses: codecov/codecov-action@v4 | |
with: | |
token: ${{ secrets.CODECOV_TOKEN }} | |
files: ./coverage.txt | |
flags: ${{ matrix }}-compatibility-e2etests | |
- name: Upload Logs | |
uses: actions/upload-artifact@v4 | |
if: always() | |
with: | |
name: ${{ matrix.module }}-compatibility-e2e-tests-logs | |
path: | | |
/tmp/artifact/**/*.log |