You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
138 lines
4.4 KiB
138 lines
4.4 KiB
# |
|
# 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: Backend |
|
|
|
on: |
|
push: |
|
branches: |
|
- dev |
|
paths: |
|
- '.github/workflows/backend.yml' |
|
- 'package.xml' |
|
- 'pom.xml' |
|
- 'dolphinscheduler-alert/**' |
|
- 'dolphinscheduler-api/**' |
|
- 'dolphinscheduler-common/**' |
|
- 'dolphinscheduler-dao/**' |
|
- 'dolphinscheduler-rpc/**' |
|
pull_request: |
|
|
|
concurrency: |
|
group: backend-${{ github.event.pull_request.number || github.ref }} |
|
cancel-in-progress: true |
|
|
|
jobs: |
|
paths-filter: |
|
name: Backend-Path-Filter |
|
runs-on: ubuntu-latest |
|
outputs: |
|
not-ignore: ${{ steps.filter.outputs.not-ignore }} |
|
steps: |
|
- uses: actions/checkout@v2 |
|
- uses: dorny/paths-filter@b2feaf19c27470162a626bd6fa8438ae5b263721 |
|
id: filter |
|
with: |
|
filters: | |
|
not-ignore: |
|
- '!(docs/**)' |
|
build: |
|
name: Backend-Build |
|
needs: paths-filter |
|
if: ${{ (needs.paths-filter.outputs.not-ignore == 'true') || (github.event_name == 'push') }} |
|
runs-on: ubuntu-latest |
|
strategy: |
|
matrix: |
|
java: [ '8', '11' ] |
|
timeout-minutes: 30 |
|
steps: |
|
- uses: actions/checkout@v2 |
|
with: |
|
submodules: true |
|
- name: Set up JDK ${{ matrix.java }} |
|
uses: actions/setup-java@v2 |
|
with: |
|
java-version: ${{ matrix.java }} |
|
distribution: 'adopt' |
|
- name: Sanity Check |
|
uses: ./.github/actions/sanity-check |
|
with: |
|
token: ${{ secrets.GITHUB_TOKEN }} |
|
- uses: actions/cache@v3 |
|
with: |
|
path: ~/.m2/repository |
|
key: ${{ runner.os }}-maven |
|
- name: Build and Package on ${{ matrix.java }} |
|
run: | |
|
./mvnw -B clean install \ |
|
-Prelease,docker \ |
|
-Dmaven.test.skip=true \ |
|
-Dcheckstyle.skip=true \ |
|
-Dhttp.keepAlive=false \ |
|
-Dmaven.wagon.http.pool=false \ |
|
-Dmaven.wagon.httpconnectionManager.ttlSeconds=120 |
|
- name: Check dependency license |
|
run: tools/dependencies/check-LICENSE.sh |
|
- uses: actions/upload-artifact@v2 |
|
if: ${{ matrix.java == '8' }} |
|
name: Upload Binary Package |
|
with: |
|
name: binary-package-${{ matrix.java }} |
|
path: ./dolphinscheduler-dist/target/apache-dolphinscheduler-*-SNAPSHOT-bin.tar.gz |
|
retention-days: 1 |
|
cluster-test: |
|
name: ${{ matrix.case.name }} |
|
needs: build |
|
runs-on: ubuntu-latest |
|
timeout-minutes: 20 |
|
strategy: |
|
matrix: |
|
case: |
|
- name: cluster-test-mysql |
|
script: .github/workflows/cluster-test/mysql/start-job.sh |
|
- name: cluster-test-postgresql |
|
script: .github/workflows/cluster-test/postgresql/start-job.sh |
|
steps: |
|
- uses: actions/checkout@v2 |
|
with: |
|
submodules: true |
|
- uses: actions/download-artifact@v2 |
|
name: Download Binary Package |
|
with: |
|
# Only run cluster test on jdk8 |
|
name: binary-package-8 |
|
path: ./ |
|
- name: Running cluster test |
|
run: | |
|
/bin/bash ${{ matrix.case.script }} |
|
result: |
|
name: Build |
|
runs-on: ubuntu-latest |
|
timeout-minutes: 30 |
|
needs: [ build, paths-filter, cluster-test ] |
|
if: always() |
|
steps: |
|
- name: Status |
|
run: | |
|
if [[ ${{ needs.paths-filter.outputs.not-ignore }} == 'false' && ${{ github.event_name }} == 'pull_request' ]]; then |
|
echo "Skip Build!" |
|
exit 0 |
|
fi |
|
if [[ ${{ needs.build.result }} != 'success' || ${{ needs.cluster-test.result }} != 'success' ]]; then |
|
echo "Build Failed!" |
|
exit -1 |
|
fi
|
|
|