123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138 |
- #
- # 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
|