Skip to content

Commit

Permalink
[type:feat] support k8s as e2e test case enviroment (apache#5217)
Browse files Browse the repository at this point in the history
* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] support e2e contain in k8s

* [type:feat] update shenyu k8s yml

* [type:feat] update shenyu k8s yml

* [type:feat] update shenyu k8s yml

* [type:feat] update shenyu k8s yml

* [type:feat] update shenyu k8s yml

* [type:feat] update shenyu k8s yml

* [type:feat] update shenyu k8s yml

* [type:feat] update shenyu k8s yml

* [type:feat] update shenyu k8s yml

* [type:feat] update shenyu k8s yml

* [type:feat] update shenyu k8s yml

* [type:feat] update shenyu k8s yml

* [type:feat] update shenyu k8s yml

* [type:feat] update shenyu k8s yml

* [type:feat] update shenyu k8s yml

* [type:feat] update shenyu k8s yml

* [type:feat] update shenyu k8s yml

* [type:feat] update shenyu k8s yml

* [type:feat] update shenyu k8s yml

* [type:feat] update shenyu k8s yml

* [type:feat] update shenyu k8s yml

* [type:feat] update shenyu k8s yml

* [type:fix] duplicate response header

* [type:fix] duplicate response header

* [type:fix] duplicate response header

* [type:fix] duplicate response header

* [type:fix] duplicate response header

* [type:fix] duplicate response header

* [type:fix] duplicate response header

* [type:fix] duplicate response header

* [type:fix] duplicate response header

* [type:fix] duplicate response header

* [type:fix] duplicate response header

* [type:fix] duplicate response header

* [type:fix] duplicate response header

* [type:fix] duplicate response header

* [type:fix] duplicate response header

* [type:fix] duplicate response header

* [type:fix] duplicate response header

* [type:fix] duplicate response header

* [type:fix] duplicate response header

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* 更新 DataSynEtcdTest.java

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* Update pom.xml

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s

* [type:fix] e2e k8s.

* [type:fix] e2e k8s.

* [type:fix] e2e k8s

* [type:fix] e2e k8s.

* [type:fix] e2e k8s

* [type:fix] e2e k8s.

* [type:fix] e2e k8s

* [type:fix] e2e k8s.

* move to sync

* comment code

* [type:fix] e2e k8s.

* [type:fix] e2e k8s.

* [type:fix] e2e k8s.

* refactor code

* refactor code

* refactor code

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* add dubbo sync test

* modify action

* modify action

---------

Co-authored-by: yunlongn <[email protected]>
  • Loading branch information
moremind and yunlongn authored Oct 13, 2023
1 parent e8ba821 commit 52871ce
Show file tree
Hide file tree
Showing 127 changed files with 7,003 additions and 5,164 deletions.
2 changes: 1 addition & 1 deletion .github/PULL_REQUEST_TEMPLATE.md
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
<!-- Describe your PR here; eg. Fixes #issueNo -->
<!-- Describe your PR here; e.g. Fixes #issueNo -->

<!--
Thank you for proposing a pull request. This template will guide you through the essential steps necessary for a pull request.
Expand Down
303 changes: 303 additions & 0 deletions .github/workflows/e2e-k8s.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,303 @@
# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements. See the NOTICE file distributed with
# this work for additional information regarding copyright ownership.
# The ASF licenses this file to You 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.

name: e2e

on:
pull_request:
push:
branches:
- master

jobs:
changes:
runs-on: ubuntu-latest
outputs:
e2e: ${{ steps.filter.outputs.e2e }}
steps:
- uses: actions/checkout@v3
with:
submodules: true
- name: Free disk space
run: |
df --human-readable
sudo apt clean
docker rmi $(docker image ls --all --quiet)
rm --recursive --force "$AGENT_TOOLSDIRECTORY"
df --human-readable
- uses: dorny/paths-filter@v2
id: filter
with:
filters: '.github/filters.yml'
list-files: json

build-docker-images:
needs: changes
if: ${{ needs.changes.outputs.e2e == 'true' }}
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
with:
submodules: true
- name: Free disk space
run: |
df --human-readable
sudo apt clean
docker rmi $(docker image ls --all --quiet)
rm --recursive --force "$AGENT_TOOLSDIRECTORY"
df --human-readable
- name: Set up JDK 8 for Building ShenYu
uses: actions/setup-java@v3
with:
java-version: '8'
distribution: 'temurin'

- uses: dorny/paths-filter@v2
id: filter
with:
filters: '.github/filters.yml'
list-files: json

- name: Build with Maven
if: steps.filter.outputs.changed == 'true'
run: ./mvnw -B clean install -Prelease,docker -Dmaven.javadoc.skip=true -B -Drat.skip=true -Dmaven.test.skip=true -Djacoco.skip=true -DskipITs -DskipTests package -T1C

- name: Save ShenYu Maven Repos
if: steps.filter.outputs.changed == 'true' && steps.restore-maven-cache.outputs.cache-hit != 'true'
uses: actions/cache/save@v3
with:
path: ~/.m2/repository
key: ${{ runner.os }}-maven-${{ hashFiles('**/pom.xml') }}

# - name: Build shenyu-e2e-engine with Maven
# run: ./mvnw -B -f ./shenyu-e2e/pom.xml -pl shenyu-e2e-engine -am clean install

# - name: Save ShenYu E2E Maven Repos
# if: steps.restore-e2e-maven-cache.outputs.cache-hit != 'true'
# uses: actions/cache/save@v3
# with:
# path: ~/.m2/repository
# key: ${{ runner.os }}-e2e-maven-${{ hashFiles('**/pom.xml') }}

- name: Build Docker Image
run: |
docker save apache/shenyu-admin:latest > /tmp/apache-shenyu-admin.tar
docker save apache/shenyu-bootstrap:latest > /tmp/apache-shenyu-bootstrap.tar
- name: Upload Docker Image Artifacts
uses: actions/upload-artifact@v3
with:
name: shenyu-images
path: /tmp/apache-shenyu-*.tar
retention-days: 1

e2e-storage:
runs-on: ubuntu-latest
needs:
- changes
- build-docker-images
if: (github.repository == 'apache/shenyu' && ${{ needs.changes.outputs.e2e == 'true' }})
strategy:
matrix:
include:
- case: shenyu-e2e-case-http
script: e2e-http-h2
- case: shenyu-e2e-case-http
script: e2e-http-mysql
- case: shenyu-e2e-case-http
script: e2e-http-postgres
steps:
- uses: actions/checkout@v2
with:
submodules: true

- name: Free disk space
run: |
df --human-readable
sudo apt clean
docker rmi $(docker image ls --all --quiet)
rm --recursive --force "$AGENT_TOOLSDIRECTORY"
df --human-readable
- uses: dorny/paths-filter@v2
id: filter
with:
filters: '.github/filters.yml'
list-files: json

- name: Install k8s
if: steps.filter.outputs.changed == 'true'
run: |
curl -sfL https://get.k3s.io | K3S_KUBECONFIG_MODE=777 sh -
cat /etc/rancher/k3s/k3s.yaml
mkdir -p ~/.kube
cp /etc/rancher/k3s/k3s.yaml ~/.kube/config
- name: Set up JDK 8 for Building ShenYu
uses: actions/setup-java@v3
with:
java-version: '8'
distribution: 'temurin'

- name: Restore ShenYu Maven Repos
if: steps.filter.outputs.changed == 'true'
uses: actions/cache/restore@v3
with:
path: ~/.m2/repository
key: ${{ runner.os }}-maven-${{ hashFiles('**/pom.xml') }}
restore-keys: |
${{ runner.os }}-maven-
- uses: actions/download-artifact@v3
with:
name: shenyu-images
path: /tmp/

- name: Build k8s Cluster
if: steps.filter.outputs.changed == 'true'
run: |
sudo k3s ctr images import /tmp/apache-shenyu-admin.tar
sudo k3s ctr images import /tmp/apache-shenyu-bootstrap.tar
# - name: Setup Debug Session
# uses: mxschmitt/action-tmate@v3
# timeout-minutes: 15
# with:
# detached: true

- name: Run E2E Tests
if: steps.filter.outputs.changed == 'true'
run: |
bash ./shenyu-e2e/shenyu-e2e-case/${{ matrix.case }}/k8s/script/${{ matrix.script }}.sh
- name: Cluster Test after Healthcheck
if: steps.filter.outputs.changed == 'true'
run: |
kubectl get all
kubectl get events --all-namespaces
kubectl logs -l app=shenyu-admin-mysql
e2e-case:
runs-on: ubuntu-latest
needs:
- changes
- build-docker-images
if: (github.repository == 'apache/shenyu' && ${{ needs.changes.outputs.e2e == 'true' }})
strategy:
matrix:
include:
- case: shenyu-e2e-case-spring-cloud
script: e2e-springcloud-sync
- case: shenyu-e2e-case-apache-dubbo
script: e2e-apache-dubbo-sync
- case: shenyu-e2e-case-sofa
script: e2e-sofa-sync
- case: shenyu-e2e-case-grpc
script: e2e-grpc-sync
steps:
- uses: actions/checkout@v2
with:
submodules: true

- name: Free disk space
run: |
df --human-readable
sudo apt clean
docker rmi $(docker image ls --all --quiet)
rm --recursive --force "$AGENT_TOOLSDIRECTORY"
df --human-readable
- uses: dorny/paths-filter@v2
id: filter
with:
filters: '.github/filters.yml'
list-files: json

- name: Install k8s
if: steps.filter.outputs.changed == 'true'
run: |
curl -sfL https://get.k3s.io | K3S_KUBECONFIG_MODE=777 sh -
cat /etc/rancher/k3s/k3s.yaml
mkdir -p ~/.kube
cp /etc/rancher/k3s/k3s.yaml ~/.kube/config
- name: Set up JDK 8 for Building ShenYu
uses: actions/setup-java@v3
with:
java-version: '8'
distribution: 'temurin'

- name: Restore ShenYu Maven Repos
if: steps.filter.outputs.changed == 'true'
uses: actions/cache/restore@v3
with:
path: ~/.m2/repository
key: ${{ runner.os }}-maven-${{ hashFiles('**/pom.xml') }}
restore-keys: |
${{ runner.os }}-maven-
# - name: Restore ShenYu E2E Maven Repos
# uses: actions/cache/restore@v3
# with:
# path: ~/.m2/repository
# key: ${{ runner.os }}-e2e-maven-${{ hashFiles('**/pom.xml') }}
# restore-keys: |
# ${{ runner.os }}-e2e-maven-

- name: Build examples with Maven
run: ./mvnw -B clean install -Pexample -Dmaven.javadoc.skip=true -Dmaven.test.skip=true -am -f ./shenyu-examples/pom.xml

- uses: actions/download-artifact@v3
with:
name: shenyu-images
path: /tmp/

- name: Build k8s Cluster
if: steps.filter.outputs.changed == 'true'
run: |
sudo k3s ctr images import /tmp/apache-shenyu-admin.tar
sudo k3s ctr images import /tmp/apache-shenyu-bootstrap.tar
# - name: Setup Debug Session
# uses: mxschmitt/action-tmate@v3
# timeout-minutes: 15
# with:
# detached: true

- name: Run E2E Tests
if: steps.filter.outputs.changed == 'true'
run: |
bash ./shenyu-e2e/shenyu-e2e-case/${{ matrix.case }}/k8s/script/${{ matrix.script }}.sh
- name: Cluster Test after Healthcheck
if: steps.filter.outputs.changed == 'true'
run: |
kubectl get all
kubectl get events --all-namespaces
requirement:
name: e2e
if: ${{ needs.changes.outputs.e2e == 'true' }}
needs:
- changes
- e2e-storage
- e2e-case
runs-on: ubuntu-latest
steps:
- name: checking job status
run: |
[[ "${{ needs.e2e-storage.result }}" == "success" ]] || exit -1
[[ "${{ needs.e2e-case.result }}" == "success" ]] || exit -1
Loading

0 comments on commit 52871ce

Please sign in to comment.