Skip to content

Merge pull request #37138 from Progi1984/test4256 #380

Merge pull request #37138 from Progi1984/test4256

Merge pull request #37138 from Progi1984/test4256 #380

Workflow file for this run

name: Behaviour tests
on:
push:
pull_request:
permissions:
contents: read # to clone the repos and get release assets (shivammathur/setup-php)
concurrency:
group: ${{ github.event_name }}-${{ github.workflow }}-${{ github.event.pull_request.number || github.ref }}
cancel-in-progress: true
jobs:
behaviour:
permissions:
contents: read # to clone the repos and get release assets (shivammathur/setup-php)
name: Behaviour tests
runs-on: ubuntu-latest
strategy:
matrix:
php: [ '8.1', '8.2', '8.3' ]
fail-fast: false
steps:
- name: Setup PHP
uses: shivammathur/setup-php@v2
with:
php-version: ${{ matrix.php }}
extensions: mbstring, intl, gd, xml, dom, json, fileinfo, curl, zip, iconv
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Setup MySQL
uses: mirromutth/[email protected]
with:
mysql version: '8.0'
mysql database: 'prestashop'
mysql root password: 'password'
- name: Setup Node
uses: actions/setup-node@v4
with:
node-version: '20'
- uses: actions/checkout@v4
- name: PrestaShop Configuration
run: |
cp .github/workflows/phpunit/parameters.yml app/config/parameters.yml
cp .github/workflows/phpunit/parameters.php app/config/parameters.php
- name: Get Composer Cache Directory
id: composer-cache
run: echo "dir=$(composer config cache-files-dir)" >> $GITHUB_OUTPUT
- name: Cache Node Directory
uses: actions/cache@v4
with:
path: ~/.npm
key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }}
restore-keys: ${{ runner.os }}-node-
- name: Cache Composer Directory
uses: actions/cache@v4
with:
path: ${{ steps.composer-cache.outputs.dir }}
key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }}
restore-keys: ${{ runner.os }}-composer-
- name: Composer Install
run: COMPOSER_PROCESS_TIMEOUT=600 composer install --ansi --prefer-dist --no-interaction --no-progress
- name: Build theme assets
run: make front-classic
- name: Change MySQL authentication method
run: mysql -h127.0.0.1 -uroot -ppassword -e "ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'password'; FLUSH PRIVILEGES;"
- name: Install maildev
run: |
docker run -d -p 1080:1080 -p 1025:1025 maildev/maildev
bash -c 'while [[ "$(curl -L -s -o /dev/null -w %{http_code} http://localhost:1080)" != "200" ]]; do echo "Wait for maildev"; sleep 5; done'
- name: Run integration-behaviour-tests
run: composer run-script integration-behaviour-tests --timeout=0
env:
SYMFONY_DEPRECATIONS_HELPER: disabled
- name: Upload logs
uses: actions/upload-artifact@v4
if: failure()
with:
name: behaviour-${{ matrix.php }}
path: |
./var/logs
- name: Test git versionned files unchanged
run: git diff --exit-code