test: use setup directly #45
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Verify Dockerfile | |
on: | |
push: | |
branches: | |
- saga | |
pull_request: | |
workflow_dispatch: | |
env: | |
IMAGE_TAGGED: mqtt:${{ github.sha }} | |
REPO_IMAGE_TAGGED: ${{ vars.REGISTRY_LOGIN_SERVER }}/mqtt:${{ github.sha }} | |
REPO_IMAGE_LATEST: ${{ vars.REGISTRY_LOGIN_SERVER }}/mqtt:latest | |
jobs: | |
test: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: actions/setup-node@v4 | |
with: | |
node-version: "20.x" | |
- run: mkdir certs | |
- name: Prepare self-signed cert | |
working-directory: certs | |
run: | | |
# CA key and certificate | |
openssl genrsa -out CA.key 2048 | |
openssl req -new -x509 -nodes -key CA.key -sha256 -days 365 -extensions v3_ca -out ca.pem -subj '/OU=Nordic Developer Academy' | |
# Server key | |
openssl genrsa -out privkey.pem 2048 | |
# CSR | |
openssl req -out server.csr -key privkey.pem -new -subj '/CN=mqtt.academy.nordicsemi.com' | |
# Sign CSR | |
openssl x509 -req -in server.csr -CA ca.pem -CAkey CA.key -CAcreateserial -out cert.pem -days 365 | |
sudo chown 105:106 ./* | |
- name: Build image | |
run: docker build -t ${{ env.IMAGE_TAGGED }} . | |
- name: Run image | |
run: docker run -p 1883:1883 -p 8883:8883 -v ./certs:/etc/cert/live/mqtt.nordicsemi.academy/ -d ${{ env.IMAGE_TAGGED }} | |
- name: Get container ID | |
run: | | |
CONTAINER_ID=$(docker ps -q --filter "ancestor=${{ env.IMAGE_TAGGED }}") | |
echo "CONTAINER_ID=$CONTAINER_ID" >> $GITHUB_ENV | |
- run: docker container logs ${{ env.CONTAINER_ID }} | |
- name: Install dependencies | |
run: npm ci | |
- name: Run tests | |
env: | |
VALIDATE_TLS_CERT: 0 | |
run: npx tsx --test test.ts | |
- name: Wait for metrics collection | |
# Runs every minute | |
run: sleep 15 | |
- name: Get metrics process logs | |
run: docker exec ${{ env.CONTAINER_ID }} bash -c 'cat /var/log/metrics.log' | |
- name: Get log file | |
run: | | |
LOG_FILES=`docker exec ${{ env.CONTAINER_ID }} bash -c 'ls /var/log/academy/'` | |
echo $LOG_FILES | |
echo $LOG_FILES | tr ' ' '\n' | while read file ; do | |
echo $file | |
docker cp ${{ env.CONTAINER_ID }}:/var/log/academy/$file ./ | |
done | |
- name: Test log files | |
run: | | |
cat mqtt-*.log > all-mqtt.log | |
cat all-mqtt.log | |
grep -E "^20[0-9]{2}-[0-9]{2}-[0-9]{2}T[0-9]{2}:[0-9]{2}:[0-9]{2}+,mqtt,connect$" all-mqtt.log | |
grep -E "^20[0-9]{2}-[0-9]{2}-[0-9]{2}T[0-9]{2}:[0-9]{2}:[0-9]{2}+,mqtt,publish$" all-mqtt.log | |
- uses: actions/upload-artifact@v4 | |
with: | |
name: metric-logs-${{ github.sha }} | |
path: | | |
mqtt-*.log | |
- name: Docker logs | |
if: always() | |
run: docker container logs ${{ env.CONTAINER_ID }} | |
- name: Push image to the infrastructure container registry as latest | |
if: github.ref == 'refs/heads/saga' | |
run: | | |
docker login -u ${{ vars.REGISTRY_USERNAME }} -p ${{ secrets.REGISTRY_PASSWORD }} ${{ vars.REGISTRY_LOGIN_SERVER }} | |
docker tag ${{ env.IMAGE_TAGGED }} ${{ env.REPO_IMAGE_TAGGED }} | |
docker push ${{ env.REPO_IMAGE_TAGGED }} | |
docker tag ${{ env.IMAGE_TAGGED }} ${{ env.REPO_IMAGE_LATEST }} | |
docker push ${{ env.REPO_IMAGE_LATEST }} |