This repository has been archived on 2024-09-05. You can view files and clone it, but cannot push or open issues or pull requests.
shimmie2/.github/workflows/test_and_publish.yml

89 lines
2.9 KiB
YAML
Raw Normal View History

2020-03-19 13:44:56 +00:00
name: Test & Publish
2019-11-21 16:59:07 +00:00
on: [push, pull_request]
jobs:
2020-03-19 13:44:56 +00:00
test:
2019-11-21 16:59:07 +00:00
name: PHP ${{ matrix.php }} / DB ${{ matrix.database }}
strategy:
2019-11-21 17:30:19 +00:00
max-parallel: 3
2019-11-22 23:03:34 +00:00
fail-fast: false
2019-11-21 16:59:07 +00:00
matrix:
2019-11-21 17:30:19 +00:00
php: ['7.3']
2019-11-21 17:28:02 +00:00
database: ['pgsql', 'mysql', 'sqlite']
2019-11-21 16:59:07 +00:00
runs-on: ubuntu-latest
2019-11-21 16:59:07 +00:00
steps:
- name: Checkout
2020-03-16 15:05:29 +00:00
uses: actions/checkout@v2
2019-11-21 16:59:07 +00:00
- name: Set up PHP
uses: shivammathur/setup-php@master
with:
php-version: ${{ matrix.php }}
coverage: pcov
2020-01-26 16:40:52 +00:00
extensions: mbstring
2019-11-21 16:59:07 +00:00
2019-11-21 17:42:31 +00:00
- name: Set up database
2019-11-21 16:59:07 +00:00
run: |
mkdir -p data/config
if [[ "${{ matrix.database }}" == "pgsql" ]]; then
2020-03-13 09:54:14 +00:00
sudo apt update && sudo apt-get install -y postgresql postgresql-client ;
2019-11-21 17:34:07 +00:00
psql --version ;
2019-11-23 12:09:18 +00:00
sudo -u postgres psql -c "SELECT set_config('log_statement', 'all', false);" -U postgres ;
sudo -u postgres psql -c "CREATE USER shimmie WITH PASSWORD 'shimmie';" -U postgres ;
sudo -u postgres psql -c "CREATE DATABASE shimmie WITH OWNER shimmie;" -U postgres ;
2019-11-21 16:59:07 +00:00
fi
if [[ "${{ matrix.database }}" == "mysql" ]]; then
2020-03-16 15:22:22 +00:00
sudo systemctl start mysql ;
2019-11-21 17:34:07 +00:00
mysql --version ;
2019-11-22 23:03:34 +00:00
mysql -e "SET GLOBAL general_log = 'ON';" -uroot -proot ;
mysql -e "CREATE DATABASE shimmie;" -uroot -proot ;
2019-11-21 16:59:07 +00:00
fi
if [[ "${{ matrix.database }}" == "sqlite" ]]; then
2020-03-13 09:54:14 +00:00
sudo apt update && sudo apt-get install -y sqlite3 ;
2019-11-21 17:34:07 +00:00
sqlite3 --version ;
2019-11-21 16:59:07 +00:00
fi
2019-11-21 17:34:07 +00:00
2019-11-21 17:42:31 +00:00
- name: Check versions
run: php -v && composer -V
- name: Validate composer.json and composer.lock
run: composer validate
- name: Install PHP dependencies
run: composer install --prefer-dist --no-progress --no-suggest
2019-11-21 17:34:07 +00:00
- name: Install shimmie
run: php index.php
2019-11-21 16:59:07 +00:00
- name: Run test suite
2020-01-27 19:40:14 +00:00
run: |
if [[ "${{ matrix.database }}" == "pgsql" ]]; then
export DSN="pgsql:user=shimmie;password=shimmie;host=127.0.0.1;dbname=shimmie"
fi
if [[ "${{ matrix.database }}" == "mysql" ]]; then
export DSN="mysql:user=root;password=root;host=127.0.0.1;dbname=shimmie"
fi
if [[ "${{ matrix.database }}" == "sqlite" ]]; then
export DSN="sqlite:data/shimmie.sqlite"
fi
vendor/bin/phpunit --configuration tests/phpunit.xml --coverage-clover=data/coverage.clover
2019-11-21 16:59:07 +00:00
- name: Upload coverage
run: |
wget https://scrutinizer-ci.com/ocular.phar
php ocular.phar code-coverage:upload --format=php-clover data/coverage.clover
2020-03-19 13:44:56 +00:00
publish:
runs-on: ubuntu-latest
needs: build
if: github.ref == 'refs/heads/master'
steps:
- uses: actions/checkout@master
- name: Publish to Registry
uses: elgohr/Publish-Docker-Github-Action@master
with:
name: shish2k/shimmie2
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}