-
Notifications
You must be signed in to change notification settings - Fork 1
69 lines (57 loc) · 2.18 KB
/
php.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
name: Test App
on:
push:
branches: [ master, devel ]
pull_request:
branches: [ master, devel ]
jobs:
build:
runs-on: ubuntu-18.04
services:
# https://docs.docker.com/samples/library/mysql/
mysql:
image: mysql:8.0
env:
MYSQL_ALLOW_EMPTY_PASSWORD: false
MYSQL_ROOT_PASSWORD: qHTavO1ajSOnQzUdi3ef
ports:
- 3306:3306
options: --health-cmd="mysqladmin ping" --health-interval=10s --health-timeout=5s --health-retries=3
steps:
- uses: actions/checkout@v2
- name: Setup PHP, with composer and extensions
uses: shivammathur/setup-php@v2
with:
php-version: 7.2.5
extensions: mbstring, xml, ctype, iconv, intl, pdo_sqlite, mysql
coverage: xdebug #optional
- name: Validate composer.json and composer.lock
run: composer validate
- name: Cache Composer packages
id: composer-cache
uses: actions/cache@v2
with:
path: vendor
key: ${{ runner.os }}-php-${{ hashFiles('**/composer.lock') }}
restore-keys: |
${{ runner.os }}-php-
- name: Install dependencies
if: steps.composer-cache.outputs.cache-hit != 'true'
run: composer install --dev --no-suggest --no-interaction --optimize-autoloader
# Add a test script to composer.json, for instance: "test": "vendor/bin/phpunit"
# Docs: https://getcomposer.org/doc/articles/scripts.md
- name: Prepare Database
env:
DATABASE_URL: mysql2://root:[email protected]:3306/msb?serverVersion=8.0
run: |
mysql -h 127.0.0.1 --port 3306 -u root -pqHTavO1ajSOnQzUdi3ef -e "ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'qHTavO1ajSOnQzUdi3ef';"
php bin/console doctrine:database:create -n
php bin/console doctrine:mig:mig -n
php bin/console doctrine:fixtures:load --group=dev -n
- name: Run Tests
run: vendor/symfony/phpunit-bridge/bin/simple-phpunit
# - name: SonarCloud Scan
# uses: SonarSource/[email protected]
# env:
# GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
# SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }}