# ---------------------------------------------------------------------------- # Copyright 2021 The Netty Project # # The Netty Project 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: # # https://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: Build PR on: pull_request: branches: [ "main"] # Allows you to run this workflow manually from the Actions tab workflow_dispatch: env: MAVEN_OPTS: -Dhttp.keepAlive=false -Dmaven.wagon.http.pool=false -Dmaven.wagon.http.retryhandler.count=5 -Dmaven.wagon.httpconnectionManager.ttlSeconds=240 jobs: verify-pr: runs-on: ubuntu-18.04 steps: - uses: actions/checkout@v2 - name: Set up JDK 11 uses: actions/setup-java@v1 with: java-version: '11' # Cache .m2/repository - name: Cache local Maven repository uses: actions/cache@v2 with: path: ~/.m2/repository key: ${{ runner.os }}-maven-verify-pr-${{ hashFiles('**/pom.xml') }} restore-keys: | ${{ runner.os }}-maven-verify-pr- ${{ runner.os }}-maven- - name: Verify with Maven run: ./mvnw -B -ntp --file pom.xml verify -DskipTests=true build-pr-windows: runs-on: windows-2016 name: windows-x86_64-java11-boringssl needs: verify-pr steps: - uses: actions/checkout@v2 - name: Set up JDK 11 uses: actions/setup-java@v1 with: java-version: 11 # Cache .m2/repository # Caching of maven dependencies - uses: actions/cache@v2 with: path: ~/.m2/repository key: pr-windows-x86_64-maven-cache-${{ hashFiles('**/pom.xml') }} restore-keys: | pr-windows-x86_64-maven-cache- - name: Build project run: ./mvnw.cmd -B -ntp --file pom.xml clean package -Pboringssl -DskipHttp2Testsuite=true -DskipAutobahnTestsuite=true - name: Upload Test Results if: always() uses: actions/upload-artifact@v2 with: name: test-results-windows-x86_64-java11-boringssl path: '**/target/surefire-reports/TEST-*.xml' - uses: actions/upload-artifact@v2 if: ${{ failure() }} with: name: build-pr-windows-target path: | **/target/surefire-reports/ **/hs_err*.log build-pr-aarch64: name: linux-aarch64-verify-native # The host should always be Linux runs-on: ubuntu-20.04 needs: verify-pr steps: - uses: actions/checkout@v2 # Cache .m2/repository - name: Cache local Maven repository uses: actions/cache@v2 with: path: ~/.m2/repository key: ${{ runner.os }}-maven-build-pr-aarch64-${{ hashFiles('**/pom.xml') }} restore-keys: | ${{ runner.os }}-maven-build-pr-aarch64- ${{ runner.os }}-maven- - uses: uraimo/run-on-arch-action@v2.0.9 name: Run commands id: runcmd with: arch: aarch64 distro: ubuntu20.04 # Not required, but speeds up builds by storing container images in # a GitHub package registry. githubToken: ${{ github.token }} # Mount the .m2/repository dockerRunArgs: | --volume "/home/runner/.m2/repository/:/root/.m2/repository" # Install dependencies install: | apt-get update -q -y apt-get install -q -y openjdk-11-jdk autoconf automake libtool make tar maven git # Compile native code and the modules it depend on and run NativeLoadingTest. This is enough to ensure # we can load the native module on aarch64 # # Use tcnative.classifier that is empty as we don't support using the shared lib version on ubuntu. run: | JAVA_HOME=/usr/lib/jvm/java-11-openjdk-arm64 ./mvnw -B -ntp -pl testsuite-native -am clean package -DskipTests=true -Dcheckstyle.skip=true -DskipNativeTestsuite=false -Dtcnative.classifier= build-pr: runs-on: ubuntu-latest strategy: matrix: include: - setup: linux-x86_64-java11 docker-compose-build: "-f docker/docker-compose.yaml -f docker/docker-compose.centos-6.111.yaml build" docker-compose-run: "-f docker/docker-compose.yaml -f docker/docker-compose.centos-6.111.yaml run build-leak" - setup: linux-x86_64-java11-graal docker-compose-build: "-f docker/docker-compose.yaml -f docker/docker-compose.centos-6.graalvm111.yaml build" docker-compose-run: "-f docker/docker-compose.yaml -f docker/docker-compose.centos-6.graalvm111.yaml run build-leak" - setup: linux-x86_64-java16 docker-compose-build: "-f docker/docker-compose.yaml -f docker/docker-compose.centos-6.116.yaml build" docker-compose-run: "-f docker/docker-compose.yaml -f docker/docker-compose.centos-6.116.yaml run build-leak" - setup: linux-x86_64-java17 docker-compose-build: "-f docker/docker-compose.yaml -f docker/docker-compose.centos-6.117.yaml build" docker-compose-run: "-f docker/docker-compose.yaml -f docker/docker-compose.centos-6.117.yaml run build-leak" - setup: linux-x86_64-java11-boringssl docker-compose-build: "-f docker/docker-compose.yaml -f docker/docker-compose.centos-6.111.yaml build" docker-compose-run: "-f docker/docker-compose.yaml -f docker/docker-compose.centos-6.111.yaml run build-leak-boringssl-static" - setup: linux-x86_64-java11-unsafe-buffer docker-compose-build: "-f docker/docker-compose.yaml -f docker/docker-compose.centos-6.111.yaml build" docker-compose-run: "-f docker/docker-compose.yaml -f docker/docker-compose.centos-6.111.yaml run build-unsafe-buffer" name: ${{ matrix.setup }} build needs: verify-pr steps: - uses: actions/checkout@v2 # Cache .m2/repository - name: Cache local Maven repository uses: actions/cache@v2 with: path: ~/.m2/repository key: ${{ runner.os }}-maven-${{ matrix.setup }}-${{ hashFiles('**/pom.xml') }} restore-keys: | ${{ runner.os }}-maven-${{ matrix.setup }}- ${{ runner.os }}-maven- # Enable caching of Docker layers - uses: satackey/action-docker-layer-caching@v0.0.11 continue-on-error: true with: key: build-docker-cache-${{ matrix.setup }}-{hash} restore-keys: | build-docker-cache-${{ matrix.setup }}- build-docker-cache- - name: Build docker image run: docker-compose ${{ matrix.docker-compose-build }} - name: Build project with leak detection run: docker-compose ${{ matrix.docker-compose-run }} | tee build-leak.output - name: Checking for test failures run: ./.github/scripts/check_build_result.sh build-leak.output - name: Checking for detected leak run: ./.github/scripts/check_leak.sh build-leak.output - name: Upload Test Results if: always() uses: actions/upload-artifact@v2 with: name: test-results-${{ matrix.setup }} path: '**/target/surefire-reports/TEST-*.xml' - uses: actions/upload-artifact@v2 if: ${{ failure() }} with: name: build-${{ matrix.setup }}-target path: | **/target/surefire-reports/ **/hs_err*.log