Skip to content
This repository has been archived by the owner on Nov 15, 2023. It is now read-only.

build(deps): update guzzlehttp/guzzle requirement from ^7.7 to ^7.8 (… #836

build(deps): update guzzlehttp/guzzle requirement from ^7.7 to ^7.8 (…

build(deps): update guzzlehttp/guzzle requirement from ^7.7 to ^7.8 (… #836

Workflow file for this run

name: tests
on:
push:
branches: [master, main]
tags-ignore: ['**']
paths-ignore: ['**.md']
pull_request:
paths-ignore: ['**.md']
concurrency:
group: ${{ github.ref }}
cancel-in-progress: true
jobs: # Docs: <https://help.github.com/en/articles/workflow-syntax-for-github-actions>
gitleaks:
name: GitLeaks
runs-on: ubuntu-latest
timeout-minutes: 3
steps:
- uses: actions/checkout@v3
with: {fetch-depth: 0}
- name: Check for GitLeaks
uses: gacts/gitleaks@v1 # Action page: <https://github.com/gacts/gitleaks>
phpunit:
name: Run PHPUnit tests
runs-on: ubuntu-latest
timeout-minutes: 5
steps:
- name: Check out code
uses: actions/checkout@v3
- name: Setup PHP, with composer and extensions
uses: shivammathur/setup-php@v2 # Action page: <https://github.com/shivammathur/setup-php>
with:
php-version: '8.2'
- name: Get Composer Cache Directory # Docs: <https://git.io/JfAKn#php---composer>
id: composer-cache
run: echo "::set-output name=dir::$(composer config cache-files-dir)"
- name: Cache dependencies # Docs: <https://git.io/JfAKn#php---composer>
uses: actions/cache@v3
with:
path: ${{ steps.composer-cache.outputs.dir }}
key: ${{ runner.os }}-composer-${{ matrix.setup }}-${{ hashFiles('**/composer.json') }}
restore-keys: ${{ runner.os }}-composer-
- name: Install Composer dependencies
run: composer update -n --prefer-dist --no-progress --ansi && composer info
- name: Run PHPUnit
run: composer phpunit
phpstan:
name: Run PHPStan (Static Analysis Tool)
runs-on: ubuntu-latest
timeout-minutes: 5
steps:
- name: Check out code
uses: actions/checkout@v3
- name: Setup PHP, with composer and extensions
uses: shivammathur/setup-php@v2
with:
php-version: '8.2'
- name: Get Composer Cache Directory
id: composer-cache
run: echo "::set-output name=dir::$(composer config cache-files-dir)"
- name: Cache dependencies
uses: actions/cache@v3
with:
path: ${{ steps.composer-cache.outputs.dir }}
key: ${{ runner.os }}-composer-${{ matrix.setup }}-${{ hashFiles('**/composer.json') }}
restore-keys: ${{ runner.os }}-composer-
- name: Install Composer dependencies
run: composer update -n --prefer-dist --no-progress --ansi && composer info
- name: Run PHPStan
run: composer phpstan
docker-image:
name: Build docker image
runs-on: ubuntu-latest
needs: [phpunit, phpstan]
timeout-minutes: 10
steps:
- name: Check out code
uses: actions/checkout@v3
- name: Build image
run: docker build -t app:local -f ./Dockerfile .
- name: Show PHP and Laravel versions, installed in docker image
run: docker run --rm app:local sh -c "php -v && php artisan -V"
- name: Save docker image
run: docker save app:local > ./docker-image.tar
- name: Upload artifact
uses: actions/upload-artifact@v3
with:
name: docker-image
path: ./docker-image.tar
retention-days: 1
#docker-image-scan:
# name: Scan docker image for vulnerabilities
# runs-on: ubuntu-latest
# needs: [docker-image]
# continue-on-error: true
# steps:
# - name: Download built docker image
# uses: actions/download-artifact@v3
# with:
# name: docker-image
# path: .artifact
#
# - name: Prepare image to run
# working-directory: .artifact
# run: docker load < docker-image.tar
#
# - name: Scan image
# uses: anchore/scan-action@v3 # action page: <https://github.com/anchore/scan-action>
# with:
# image: app:local
# #severity-cutoff: medium # negligible, low, medium, high or critical
docker-image-e2e:
name: Docker image End-to-End tests (SSL ${{ matrix.ssl }})
runs-on: ubuntu-latest
needs: [docker-image]
strategy:
fail-fast: false
matrix:
ssl: [on, off]
steps:
- name: Check out code
uses: actions/checkout@v3
- name: Create docker network
run: docker network create "app-network"
- name: Start postgres server
run: |
docker run --rm -d \
--network "app-network" \
--name=postgres \
-p "5432/tcp" \
-e "POSTGRES_DB=forge" \
-e "POSTGRES_USER=forge" \
-e "POSTGRES_PASSWORD=forge" \
postgres:15-alpine
- name: Start redis server
run: |
docker run --rm -d \
--network "app-network" \
--name=redis \
-p "6379/tcp" \
redis:7-alpine \
redis-server --requirepass redis_password
- name: Download built docker image
uses: actions/download-artifact@v3
with:
name: docker-image
path: .artifact
- name: Prepare image to run
working-directory: .artifact
run: docker load < docker-image.tar
- name: Migrate the database
run: |
docker run --rm \
--network "app-network" \
-e "DB_HOST=postgres" \
-e "DB_DATABASE=forge" \
-e "DB_USERNAME=forge" \
-e "DB_PASSWORD=forge" \
app:local \
php artisan migrate --force
- name: Start application queue worker
run: |
docker run --rm -d \
--network "app-network" \
-e "REDIS_HOST=redis" \
-e "REDIS_PASSWORD=redis_password" \
-e "DB_HOST=postgres" \
-e "DB_DATABASE=forge" \
-e "DB_USERNAME=forge" \
-e "DB_PASSWORD=forge" \
app:local \
php artisan queue:work --memory=256 --sleep=1
- name: Start application HTTP server
run: |
docker run --rm -d \
--network "app-network" \
-p "8080:8080/tcp" \
-p "8443:8443/tcp" \
-e "REDIS_HOST=redis" \
-e "REDIS_PASSWORD=redis_password" \
-e "DB_HOST=postgres" \
-e "DB_DATABASE=forge" \
-e "DB_USERNAME=forge" \
-e "DB_PASSWORD=forge" \
app:local \
rr serve -c .rr.yaml
- name: Generate values for tests running
id: values
run: echo "::set-output name=base_url::`[ "${{ matrix.ssl }}" = "on" ] && echo "https://localhost:8443" || echo "http://localhost:8080"`"
# Image page: <https://hub.docker.com/r/postman/newman>,
# CLI options: <https://www.npmjs.com/package/newman#command-line-options>
- name: Run Newman
run: |
docker run --rm --tty \
--net host \
--volume "$(pwd):/rootfs:ro" \
--workdir "/rootfs/tests/postman" \
postman/newman:5.2-alpine run ./default.postman_collection.json \
--env-var "base_url=${{ steps.values.outputs.base_url }}" \
--insecure \
--color on