name: Build
|
|
on:
|
push:
|
pull_request:
|
branches: [ master ]
|
|
jobs:
|
build-maven:
|
runs-on: ${{ matrix.os }}
|
strategy:
|
matrix:
|
java: [ '8','11','17','21','22']
|
os: [ 'ubuntu-latest', 'macos-latest', 'windows-latest' ]
|
fail-fast: false
|
steps:
|
- name: Install wine+rpm for distribution
|
if: runner.os == 'Linux'
|
shell: bash
|
run: |
|
sudo rm -f /etc/apt/sources.list.d/microsoft-prod.list
|
sudo dpkg --add-architecture i386
|
sudo mkdir -pm755 /etc/apt/keyrings && sudo wget -O /etc/apt/keyrings/winehq-archive.key https://dl.winehq.org/wine-builds/winehq.key
|
sudo wget -NP /etc/apt/sources.list.d/ https://dl.winehq.org/wine-builds/ubuntu/dists/jammy/winehq-jammy.sources
|
sudo apt-get update
|
sudo apt install --install-recommends winehq-stable
|
sudo mkdir -p /opt/wine/mono && sudo wget "https://dl.winehq.org/wine/wine-mono/8.0.0/wine-mono-8.0.0-x86.tar.xz" -P /opt/wine/mono && sudo tar -xf /opt/wine/mono/wine-mono-8.0.0-x86.tar.xz -C /opt/wine/mono && sudo rm /opt/wine/mono/wine-mono-8.0.0-x86.tar.xz
|
wine --version
|
- uses: actions/checkout@v4
|
with:
|
fetch-depth: 0
|
submodules: recursive
|
- name: Java ${{ matrix.Java }} (${{ matrix.os }})
|
uses: actions/setup-java@v4
|
with:
|
java-version: ${{ matrix.java }}
|
distribution: 'zulu'
|
- name: Cache Maven packages
|
uses: actions/cache@v4
|
with:
|
path: ~/.m2/repository
|
key: ${{ runner.os }}-m2-repository-${{ hashFiles('**/pom.xml') }}
|
restore-keys: ${{ runner.os }}-m2-repository
|
- name: Run docker cassandra
|
if: runner.os == 'Linux'
|
run: |
|
docker run --rm -it -d -p 9042:9042 --name cassandra cassandra
|
timeout 5m bash -c 'until docker logs cassandra | grep -q "Created default superuser role"; do sleep 5; done'
|
- name: Set Integration Test Environment
|
id: failsafe
|
if: runner.os != 'Windows'
|
run: |
|
echo "MAVEN_PROFILE_FLAG=-P precommit" >> $GITHUB_OUTPUT
|
- name: Build with Maven
|
timeout-minutes: 180
|
env:
|
MAVEN_OPTS: -Dhttps.protocols=TLSv1.2 -Dmaven.wagon.httpconnectionManager.ttlSeconds=120 -Dmaven.wagon.http.retryHandler.requestSentEnabled=true -Dmaven.wagon.http.retryHandler.count=10
|
run: mvn --batch-mode --errors --update-snapshots verify --file pom.xml ${{ steps.failsafe.outputs.MAVEN_PROFILE_FLAG }}
|
- name: Test on Unix
|
if: runner.os != 'Windows'
|
run: |
|
export OPENDJ_JAVA_ARGS="-server -Xmx512m"
|
opendj-server-legacy/target/package/opendj/setup -h localhost -p 1389 --ldapsPort 1636 --adminConnectorPort 4444 --enableStartTLS --generateSelfSignedCertificate --rootUserDN "cn=Directory Manager" --rootUserPassword password --baseDN dc=example,dc=com --sampleData 5000 --cli --acceptLicense --no-prompt
|
opendj-server-legacy/target/package/opendj/bin/status --bindDN "cn=Directory Manager" --bindPassword password
|
opendj-server-legacy/target/package/opendj/bin/ldapsearch --hostname localhost --port 1636 --bindDN "cn=Directory Manager" --bindPassword password --useSsl --trustAll --baseDN "dc=example,dc=com" --searchScope base "(objectClass=*)" 1.1
|
opendj-server-legacy/target/package/opendj/bin/ldapsearch --hostname localhost --port 1636 --bindDN "cn=Directory Manager" --bindPassword password --useSsl --trustAll --baseDN "ou=people,dc=example,dc=com" --searchScope sub "(uid=user.*)" dn | grep ^dn: | wc -l | grep -q 5000
|
opendj-server-legacy/target/package/opendj/bin/stop-ds
|
- name: Test LDAP in Cassandra
|
if: runner.os == 'Linux'
|
run: |
|
rm -rf opendj-server-legacy/target/package/opendj/config opendj-server-legacy/target/package/opendj/db opendj-server-legacy/target/package/opendj/changelogDb opendj-server-legacy/target/package/opendj/logs
|
export OPENDJ_JAVA_ARGS="-server -Xmx512m -Ddatastax-java-driver.basic.contact-points.0=localhost:9042 -Ddatastax-java-driver.basic.load-balancing-policy.local-datacenter=datacenter1"
|
opendj-server-legacy/target/package/opendj/setup --backendType cas -h localhost -p 1389 --ldapsPort 1636 --adminConnectorPort 4444 --enableStartTLS --generateSelfSignedCertificate --rootUserDN "cn=Directory Manager" --rootUserPassword password --baseDN dc=example,dc=com --sampleData 5000 --cli --acceptLicense --no-prompt
|
opendj-server-legacy/target/package/opendj/bin/status --bindDN "cn=Directory Manager" --bindPassword password
|
opendj-server-legacy/target/package/opendj/bin/ldapsearch --hostname localhost --port 1636 --bindDN "cn=Directory Manager" --bindPassword password --useSsl --trustAll --baseDN "dc=example,dc=com" --searchScope base "(objectClass=*)" 1.1
|
opendj-server-legacy/target/package/opendj/bin/ldapsearch --hostname localhost --port 1636 --bindDN "cn=Directory Manager" --bindPassword password --useSsl --trustAll --baseDN "ou=people,dc=example,dc=com" --searchScope sub "(uid=user.*)" dn | grep ^dn: | wc -l | grep -q 5000
|
opendj-server-legacy/target/package/opendj/bin/stop-ds
|
- name: Test on Windows
|
if: runner.os == 'Windows'
|
run: |
|
set OPENDJ_JAVA_ARGS="-server -Xmx512m"
|
opendj-server-legacy\target\package\opendj\setup.bat -h localhost -p 1389 --ldapsPort 1636 --adminConnectorPort 4444 --enableStartTLS --generateSelfSignedCertificate --rootUserDN "cn=Directory Manager" --rootUserPassword password --baseDN dc=example,dc=com --sampleData 5000 --cli --acceptLicense --no-prompt
|
opendj-server-legacy\target\package\opendj\bat\status.bat --bindDN "cn=Directory Manager" --bindPassword password
|
opendj-server-legacy\target\package\opendj\bat\ldapsearch.bat --hostname localhost --port 1636 --bindDN "cn=Directory Manager" --bindPassword password --useSsl --trustAll --baseDN "dc=example,dc=com" --searchScope base "(objectClass=*)" 1.1
|
opendj-server-legacy\target\package\opendj\bat\ldapsearch.bat --hostname localhost --port 1636 --bindDN "cn=Directory Manager" --bindPassword password --useSsl --trustAll --baseDN "dc=example,dc=com" --searchScope sub "(uid=user.*)" dn | find /c '"dn:"' | findstr "5000"
|
opendj-server-legacy\target\package\opendj\bat\stop-ds.bat
|
- name: Upload artifacts OpenDJ Server
|
uses: actions/upload-artifact@v4
|
with:
|
name: ${{ matrix.os }}-${{ matrix.java }}
|
retention-days: 5
|
path: |
|
opendj-server-legacy/target/package/*.zip
|
opendj-ldap-toolkit/target/*.zip
|
opendj-packages/opendj-deb/opendj-deb-standard/target/*.deb
|
opendj-packages/opendj-rpm/opendj-rpm-standard/target/rpm/opendj/RPMS/noarch/*.rpm
|
opendj-packages/opendj-msi/opendj-msi-standard/target/*.msi
|
opendj-packages/opendj-docker/target/Dockerfile.zip
|
opendj-packages/opendj-openshift-template/*.yaml
|
opendj-doc-generated-ref/target/*.zip
|
opendj-dsml-servlet/target/*.war
|
opendj-rest2ldap-servlet/target/*.war
|
build-docker:
|
runs-on: 'ubuntu-latest'
|
services:
|
registry:
|
image: registry:2
|
ports:
|
- 5000:5000
|
steps:
|
- uses: actions/checkout@v4
|
with:
|
fetch-depth: 0
|
submodules: recursive
|
- name: Get latest release version
|
shell: bash
|
run: |
|
export git_version_last="$(curl -i -o - --silent https://api.github.com/repos/OpenIdentityPlatform/OpenDJ/releases/latest | grep -m1 "\"name\"" | cut -d\" -f4)" ; echo "last release: $git_version_last"
|
echo "release_version=$git_version_last" >> $GITHUB_ENV
|
- name: Docker meta
|
id: meta
|
uses: docker/metadata-action@v5
|
with:
|
images: |
|
localhost:5000/${{ github.repository }}
|
tags: |
|
type=raw,value=${{ env.release_version }}
|
- name: Set up QEMU
|
uses: docker/setup-qemu-action@v3
|
- name: Set up Docker Buildx
|
uses: docker/setup-buildx-action@v3
|
with:
|
driver-opts: network=host
|
- name: Build image (default)
|
uses: docker/build-push-action@v5
|
continue-on-error: true
|
with:
|
context: ./opendj-packages/opendj-docker
|
file: ./opendj-packages/opendj-docker/Dockerfile
|
build-args: |
|
VERSION=${{ env.release_version }}
|
platforms: linux/amd64, linux/arm64/8, linux/ppc64le, linux/s390x #, linux/arm/v7
|
push: true
|
tags: ${{ steps.meta.outputs.tags }}
|
labels: ${{ steps.meta.outputs.labels }}
|
- name: Docker test
|
shell: bash
|
run: |
|
docker run --rm -it -d --memory="1g" --name=test localhost:5000/${GITHUB_REPOSITORY,,}:${{ env.release_version }}
|
timeout 3m bash -c 'until docker inspect --format="{{json .State.Health.Status}}" test | grep -q \"healthy\"; do sleep 10; done'
|
build-docker-alpine:
|
runs-on: 'ubuntu-latest'
|
services:
|
registry:
|
image: registry:2
|
ports:
|
- 5000:5000
|
steps:
|
- uses: actions/checkout@v4
|
with:
|
fetch-depth: 0
|
submodules: recursive
|
- name: Get latest release version
|
shell: bash
|
run: |
|
export git_version_last="$(curl -i -o - --silent https://api.github.com/repos/OpenIdentityPlatform/OpenDJ/releases/latest | grep -m1 "\"name\"" | cut -d\" -f4)" ; echo "last release: $git_version_last"
|
echo "release_version=$git_version_last" >> $GITHUB_ENV
|
- name: Docker meta
|
id: meta
|
uses: docker/metadata-action@v5
|
with:
|
images: |
|
localhost:5000/${{ github.repository }}
|
tags: |
|
type=raw,value=alpine
|
type=raw,value=${{ env.release_version }}-alpine
|
- name: Set up QEMU
|
uses: docker/setup-qemu-action@v3
|
- name: Set up Docker Buildx
|
uses: docker/setup-buildx-action@v3
|
with:
|
driver-opts: network=host
|
- name: Build image
|
continue-on-error: true
|
uses: docker/build-push-action@v5
|
with:
|
context: ./opendj-packages/opendj-docker
|
file: ./opendj-packages/opendj-docker/Dockerfile-alpine
|
build-args: |
|
VERSION=${{ env.release_version }}
|
platforms: linux/amd64,linux/arm64/8, linux/s390x, linux/386, linux/arm/v7, linux/arm/v6, linux/ppc64le
|
push: true
|
tags: ${{ steps.meta.outputs.tags }}
|
labels: ${{ steps.meta.outputs.labels }}
|
- name: Docker test
|
shell: bash
|
run: |
|
docker run --rm -it -d --memory="1g" --name=test localhost:5000/${GITHUB_REPOSITORY,,}:${{ env.release_version }}-alpine
|
timeout 3m bash -c 'until docker inspect --format="{{json .State.Health.Status}}" test | grep -q \"healthy\"; do sleep 10; done'
|