89866da252
Motivation: As JDK17 is really close to be released we should add a CI job for it to ensure netty works correctly when using it. Modifications: Add docker config and workflow config to run CI job for JDK17 Result: Ensure netty works on JDK17 as well
207 lines
7.8 KiB
YAML
207 lines
7.8 KiB
YAML
# ----------------------------------------------------------------------------
|
|
# 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: [ "master"]
|
|
|
|
# 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
|