Skip to content

tests/java

tests/java #554

Workflow file for this run

name: tests/java
on:
schedule:
- cron: "0 10 * * 6"
push:
branches: [ v6.0 ]
pull_request:
branches: [ v6.0 ]
workflow_dispatch:
inputs:
ravendb_version:
description: 'RavenDB Version'
required: true
type: string
jobs:
build:
runs-on: ubuntu-latest
env:
RAVENDB_JAVA_TEST_SERVER_PATH: ./RavenDB/Server/Raven.Server
RAVENDB_JAVA_TEST_CERTIFICATE_PATH: certs/server.pfx
RAVENDB_JAVA_TEST_CA_PATH: /usr/local/share/ca-certificates/ca.crt
RAVENDB_JAVA_TEST_HTTPS_SERVER_URL: https://localhost:7325
RAVENDB_BUILD_TYPE: nightly
RAVEN_License: ${{ secrets.RAVEN_LICENSE }}
strategy:
matrix:
java-version: [8, 11, 14, 16, 17, 21]
serverVersion: ["6.0", "6.2"]
fail-fast: false
steps:
- uses: actions/checkout@v4
- name: Set up JDK ${{ matrix.java-version }}
uses: actions/setup-java@v4
with:
java-version: ${{ matrix.java-version }}
distribution: "zulu"
- name: Download RavenDB Server
run: |
if [[ -n "${{ inputs.ravendb_version }}" ]]; then
wget -O RavenDB.tar.bz2 "https://daily-builds.s3.amazonaws.com/RavenDB-${{ inputs.ravendb_version }}-linux-x64.tar.bz2"
else
wget -O RavenDB.tar.bz2 "https://hibernatingrhinos.com/downloads/RavenDB%20for%20Linux%20x64/latest?buildType=${{ env.RAVENDB_BUILD_TYPE }}&version=${{ matrix.serverVersion }}"
fi
- run: mkdir certs
- run: openssl genrsa -traditional -out certs/ca.key 2048
- run: openssl req -new -x509 -key certs/ca.key -out certs/ca.crt -subj "/C=US/ST=Arizona/L=Nevada/O=RavenDB Test CA/OU=RavenDB test CA/CN=localhost/[email protected]"
- run: openssl genrsa -out certs/localhost.key 2048
- run: openssl req -new -key certs/localhost.key -out certs/localhost.csr -subj "/C=US/ST=Arizona/L=Nevada/O=RavenDB Test/OU=RavenDB test/CN=localhost/[email protected]" -addext "subjectAltName = DNS:localhost"
- run: openssl x509 -req -extensions ext -extfile src/test/cert/test_cert.conf -in certs/localhost.csr -CA certs/ca.crt -CAkey certs/ca.key -CAcreateserial -out certs/localhost.crt
- run: cat certs/localhost.key certs/localhost.crt > certs/java.pem
- run: openssl pkcs12 -passout pass:"" -export -out certs/server.pfx -inkey certs/localhost.key -in certs/localhost.crt
- run: sudo cp certs/ca.crt /usr/local/share/ca-certificates/ca.crt
- run: sudo update-ca-certificates
- name: Extract RavenDB Server
run: tar xjf RavenDB.tar.bz2
- name: Deploy server certificate
run: mkdir RavenDB/Server/certs && cp certs/server.pfx RavenDB/Server/certs/
- name: Run Maven Tests
run: mvn clean test