Build and test PHP applications with Gitlab CI (or any other CI plataform!
Docker images with everything you'll need to build and test PHP applications.
Official PHP images
Based on7
,7.3
,latest
(7.3/Dockerfile) -7.3-alpine
,alpine
(7.3/alpine/Dockerfile) -7.3-alpine-lts
,alpine-lts
(7.3/alpine/Dockerfile-lts) -7.3-fpm
,fpm
(7.3/fpm/Dockerfile) -7.2
(7.2/Dockerfile) -7.2-alpine
(7.2/alpine/Dockerfile) -7.2-alpine-lts
(7.2/alpine/Dockerfile-lts) -7.2-fpm
(7.2/fpm/Dockerfile) -7.1
(7.1/Dockerfile) -7.1-alpine
(7.1/alpine/Dockerfile) -7.1-alpine-lts
(7.1/alpine/Dockerfile-lts) -7.1-fpm
(7.1/fpm/Dockerfile) -
All versions (except lts
) come with Node 12, Composer and Yarn
lts
version come with node v10
PHP 7.0.x is now deprecated and removed from this documentation. Your scripts will not stop working since the images are still available but they will not be receiving new builds from now on.
Laravel users
All images come with PHP (with all laravel required extensions), Composer (with hirak/prestissimo to speed up installs), Node and Yarn.
Everything you need to test Laravel projects :D
Laravel Dusk
To run Dusk tests we need chromium installed on the image, because of that we have a special tag for this case.
7.3-chromium
(7.3/chromium/Dockerfile)7.2-chromium
(7.2/chromium/Dockerfile)7.1-chromium
(7.1/chromium/Dockerfile)
Gitlab pipeline examples
Laravel test examples
.gitlab-ci.yml
using mysql service
Simple # Variables
variables:
MYSQL_ROOT_PASSWORD: root
MYSQL_USER: homestead
MYSQL_PASSWORD: secret
MYSQL_DATABASE: homestead
DB_HOST: mysql
test:
stage: test
services:
- mysql:5.7
image: edbizarro/gitlab-ci-pipeline-php:7.3-alpine
script:
- yarn
- composer install --prefer-dist --no-ansi --no-interaction --no-progress
- cp .env.example .env
- php artisan key:generate
- php artisan migrate:refresh --seed
- ./vendor/phpunit/phpunit/phpunit -v --coverage-text --colors=never --stderr
.gitlab-ci.yml
using mysql service, stages and cache
Advanced stages:
- test
- deploy
# Variables
variables:
MYSQL_ROOT_PASSWORD: root
MYSQL_USER: homestead
MYSQL_PASSWORD: secret
MYSQL_DATABASE: homestead
DB_HOST: mysql
# Speed up builds
cache:
key: $CI_BUILD_REF_NAME # changed to $CI_COMMIT_REF_NAME in Gitlab 9.x
paths:
- vendor
- node_modules
- public
- .yarn
test:
stage: test
services:
- mysql:5.7
image: edbizarro/gitlab-ci-pipeline-php:7.3-alpine
script:
- sudo yarn config set cache-folder .yarn
- yarn install --pure-lockfile
- composer install --prefer-dist --no-ansi --no-interaction --no-progress
- cp .env.example .env
- php artisan key:generate
- php artisan migrate:refresh --seed
- ./vendor/phpunit/phpunit/phpunit -v --coverage-text --colors=never --stderr
artifacts:
paths:
- ./storage/logs # for debugging
expire_in: 7 days
when: always
deploy:
stage: deploy
image: edbizarro/gitlab-ci-pipeline-php:7.3-alpine
script:
- echo "Deploy all the things!"
only:
- master
when: on_success
.gitlab-ci.yml
using mysql service and cache
Laravel Dusk tests stages:
- test
# Variables
variables:
MYSQL_ROOT_PASSWORD: root
MYSQL_USER: homestead
MYSQL_PASSWORD: secret
MYSQL_DATABASE: homestead
DB_HOST: mysql
# Speed up builds
cache:
key: $CI_BUILD_REF_NAME # changed to $CI_COMMIT_REF_NAME in Gitlab 9.x
paths:
- vendor
- node_modules
- public
- .yarn
test:
stage: test
services:
- mysql:5.7
image: edbizarro/gitlab-ci-pipeline-php:7.3-chromium
script:
- yarn install --pure-lockfile
- composer install --prefer-dist --no-ansi --no-interaction --no-progress
- cp .env.example .env
- php artisan key:generate
- php artisan migrate:refresh --seed
- php artisan serve &
- ./vendor/laravel/dusk/bin/chromedriver-linux --port=9515 &
- sleep 5
- php artisan dusk
artifacts:
paths:
- ./storage/logs # for debugging
- ./tests/Browser/screenshots # for Dusk screenshots
- ./tests/Browser/console
expire_in: 7 days
when: always
Deploying Laravel applications with Gitlab
Recommended
Special thanks to Ambientum, an incredible Brazilian project, for the inspiration.
Also https://github.com/Chialab/docker-php for php 7.2 build scripts