2025-01-13 20:06:48 +01:00
|
|
|
name: UI test with TestDriverAI
|
|
|
|
|
|
|
|
on:
|
|
|
|
push:
|
|
|
|
branches: ["master", "UITest", "testdriver"]
|
|
|
|
|
|
|
|
permissions:
|
|
|
|
contents: read
|
|
|
|
|
|
|
|
jobs:
|
|
|
|
deploy:
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
steps:
|
|
|
|
- name: Harden Runner
|
|
|
|
uses: step-security/harden-runner@c95a14d0e5bab51a9f56296a4eb0e416910cd350 # v2.10.3
|
|
|
|
with:
|
|
|
|
egress-policy: audit
|
2025-01-13 23:26:05 +01:00
|
|
|
|
2025-01-13 20:06:48 +01:00
|
|
|
- name: Checkout repository
|
2025-01-13 23:26:05 +01:00
|
|
|
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
|
2025-01-13 20:06:48 +01:00
|
|
|
|
|
|
|
- name: Set up JDK
|
2025-01-13 23:26:05 +01:00
|
|
|
uses: actions/setup-java@7a6d8a8234af8eb26422e24e3006232cccaa061b # v4.6.0
|
2025-01-13 20:06:48 +01:00
|
|
|
with:
|
|
|
|
java-version: '17'
|
|
|
|
distribution: 'temurin'
|
|
|
|
|
|
|
|
- name: Build with Gradle
|
|
|
|
run: ./gradlew clean build
|
|
|
|
env:
|
|
|
|
DOCKER_ENABLE_SECURITY: false
|
|
|
|
|
|
|
|
- name: Set up Docker Buildx
|
|
|
|
uses: docker/setup-buildx-action@6524bf65af31da8d45b59e8c27de4bd072b392f5 # v3.8.0
|
|
|
|
|
|
|
|
- name: Get version number
|
|
|
|
id: versionNumber
|
|
|
|
run: |
|
|
|
|
VERSION=$(grep "^version =" build.gradle | awk -F'"' '{print $2}')
|
|
|
|
echo "versionNumber=$VERSION" >> $GITHUB_OUTPUT
|
|
|
|
|
|
|
|
- name: Login to Docker Hub
|
|
|
|
uses: docker/login-action@9780b0c442fbb1117ed29e0efdff1e18412f7567 # v3.3.0
|
|
|
|
with:
|
|
|
|
username: ${{ secrets.DOCKER_HUB_USERNAME }}
|
|
|
|
password: ${{ secrets.DOCKER_HUB_API }}
|
|
|
|
|
|
|
|
- name: Build and push test image
|
|
|
|
uses: docker/build-push-action@48aba3b46d1b1fec4febb7c5d0c644b249a11355 # v6.10.0
|
|
|
|
with:
|
|
|
|
context: .
|
|
|
|
file: ./Dockerfile
|
|
|
|
push: true
|
|
|
|
tags: ${{ secrets.DOCKER_HUB_USERNAME }}/test:test-${{ github.sha }}
|
|
|
|
build-args: VERSION_TAG=${{ steps.versionNumber.outputs.versionNumber }}
|
|
|
|
platforms: linux/amd64
|
|
|
|
|
|
|
|
- name: Set up SSH
|
|
|
|
run: |
|
|
|
|
mkdir -p ~/.ssh/
|
|
|
|
echo "${{ secrets.VPS_SSH_KEY }}" > ../private.key
|
|
|
|
sudo chmod 600 ../private.key
|
|
|
|
|
|
|
|
- name: Deploy to VPS
|
|
|
|
run: |
|
|
|
|
cat > docker-compose.yml << EOF
|
|
|
|
version: '3.3'
|
|
|
|
services:
|
|
|
|
stirling-pdf:
|
|
|
|
container_name: stirling-pdf-test-${{ github.sha }}
|
|
|
|
image: ${{ secrets.DOCKER_HUB_USERNAME }}/test:test-${{ github.sha }}
|
|
|
|
ports:
|
|
|
|
- "1337:8080"
|
|
|
|
volumes:
|
|
|
|
- /stirling/test-${{ github.sha }}/data:/usr/share/tessdata:rw
|
|
|
|
- /stirling/test-${{ github.sha }}/config:/configs:rw
|
|
|
|
- /stirling/test-${{ github.sha }}/logs:/logs:rw
|
|
|
|
environment:
|
|
|
|
DOCKER_ENABLE_SECURITY: "false"
|
|
|
|
SECURITY_ENABLELOGIN: "false"
|
|
|
|
SYSTEM_DEFAULTLOCALE: en-GB
|
|
|
|
UI_APPNAME: "Stirling-PDF Test"
|
|
|
|
UI_HOMEDESCRIPTION: "Test Deployment"
|
|
|
|
UI_APPNAMENAVBAR: "Test"
|
|
|
|
SYSTEM_MAXFILESIZE: "100"
|
|
|
|
METRICS_ENABLED: "true"
|
|
|
|
SYSTEM_GOOGLEVISIBILITY: "false"
|
|
|
|
SYSTEM_ENABLEANALYTICS: "false"
|
|
|
|
restart: on-failure:5
|
|
|
|
EOF
|
|
|
|
|
|
|
|
scp -i ../private.key -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null docker-compose.yml ${{ secrets.VPS_USERNAME }}@${{ secrets.VPS_HOST }}:/tmp/docker-compose.yml
|
|
|
|
|
|
|
|
ssh -i ../private.key -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null ${{ secrets.VPS_USERNAME }}@${{ secrets.VPS_HOST }} << EOF
|
|
|
|
mkdir -p /stirling/test-${{ github.sha }}/{data,config,logs}
|
|
|
|
mv /tmp/docker-compose.yml /stirling/test-${{ github.sha }}/docker-compose.yml
|
|
|
|
cd /stirling/test-${{ github.sha }}
|
|
|
|
docker-compose pull
|
|
|
|
docker-compose up -d
|
|
|
|
EOF
|
|
|
|
|
|
|
|
test:
|
|
|
|
needs: deploy
|
|
|
|
runs-on: ubuntu-latest
|
2025-01-13 23:26:05 +01:00
|
|
|
|
2025-01-13 20:06:48 +01:00
|
|
|
steps:
|
|
|
|
- name: Harden Runner
|
|
|
|
uses: step-security/harden-runner@c95a14d0e5bab51a9f56296a4eb0e416910cd350 # v2.10.3
|
|
|
|
with:
|
|
|
|
egress-policy: audit
|
2025-01-13 23:26:05 +01:00
|
|
|
|
|
|
|
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
|
2025-01-13 20:06:48 +01:00
|
|
|
|
|
|
|
- name: Run TestDriver.ai
|
|
|
|
uses: testdriverai/action@47e87c5d50beeeb3da624b2d9b5c1391269d6d22 #1.0.0
|
|
|
|
with:
|
|
|
|
key: ${{secrets.TESTDRIVER_API_KEY}}
|
|
|
|
prerun: |
|
|
|
|
npm install
|
|
|
|
npm run build
|
|
|
|
npm install dashcam-chrome --save
|
|
|
|
Start-Process "C:/Program Files/Google/Chrome/Application/chrome.exe" -ArgumentList "--start-maximized", "--load-extension=$(pwd)/node_modules/dashcam-chrome/build", "http://${{ secrets.VPS_HOST }}:1337"
|
|
|
|
Start-Sleep -Seconds 20
|
|
|
|
prompt: |
|
|
|
|
1. /run testdriver/test.yml
|
|
|
|
env:
|
|
|
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
|
|
FORCE_COLOR: "3"
|
|
|
|
|
|
|
|
cleanup:
|
|
|
|
needs: [deploy, test]
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
if: always()
|
2025-01-13 23:26:05 +01:00
|
|
|
|
2025-01-13 20:06:48 +01:00
|
|
|
steps:
|
|
|
|
- name: Harden Runner
|
|
|
|
uses: step-security/harden-runner@c95a14d0e5bab51a9f56296a4eb0e416910cd350 # v2.10.3
|
|
|
|
with:
|
|
|
|
egress-policy: audit
|
2025-01-13 23:26:05 +01:00
|
|
|
|
2025-01-13 20:06:48 +01:00
|
|
|
- name: Set up SSH
|
|
|
|
run: |
|
|
|
|
mkdir -p ~/.ssh/
|
|
|
|
echo "${{ secrets.VPS_SSH_KEY }}" > ../private.key
|
|
|
|
sudo chmod 600 ../private.key
|
|
|
|
|
|
|
|
- name: Cleanup deployment
|
|
|
|
run: |
|
|
|
|
ssh -i ../private.key -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null ${{ secrets.VPS_USERNAME }}@${{ secrets.VPS_HOST }} << EOF
|
|
|
|
cd /stirling/test-${{ github.sha }}
|
|
|
|
docker-compose down
|
|
|
|
cd /stirling
|
|
|
|
rm -rf test-${{ github.sha }}
|
|
|
|
EOF
|