85 lines
3 KiB
YAML
85 lines
3 KiB
YAML
# You can copy and paste this template into a new `.gitlab-ci.yml` file.
|
|
# You should not add this template to an existing `.gitlab-ci.yml` file by using the `include:` keyword.
|
|
#
|
|
# To contribute improvements to CI/CD templates, please follow the Development guide at:
|
|
# https://docs.gitlab.com/ee/development/cicd/templates.html
|
|
# This specific template is located at:
|
|
# https://gitlab.com/gitlab-org/gitlab/-/blob/master/lib/gitlab/ci/templates/Laravel.gitlab-ci.yml
|
|
|
|
# Official framework image. Look for the different tagged releases at:
|
|
# https://hub.docker.com/r/library/php
|
|
image: php:latest
|
|
|
|
# Pick zero or more services to be used on all builds.
|
|
# Only needed when using a docker container to run your tests in.
|
|
# Check out: https://docs.gitlab.com/ee/ci/services/index.html
|
|
services:
|
|
- mysql:latest
|
|
|
|
variables:
|
|
MYSQL_DATABASE: project_name
|
|
MYSQL_ROOT_PASSWORD: secret
|
|
|
|
# This folder is cached between builds
|
|
# https://docs.gitlab.com/ee/ci/yaml/index.html#cache
|
|
cache:
|
|
paths:
|
|
- vendor/
|
|
- node_modules/
|
|
|
|
# This is a basic example for a gem or script which doesn't use
|
|
# services such as redis or postgres
|
|
before_script:
|
|
# Update packages
|
|
- apt-get update -yqq
|
|
# Prep for Node
|
|
- apt-get install gnupg -yqq
|
|
# Upgrade to Node 8
|
|
- curl -sL https://deb.nodesource.com/setup_8.x | bash -
|
|
# Install dependencies
|
|
- apt-get install git nodejs libcurl4-gnutls-dev libicu-dev libmcrypt-dev libvpx-dev libjpeg-dev libpng-dev libxpm-dev zlib1g-dev libfreetype6-dev libxml2-dev libexpat1-dev libbz2-dev libgmp3-dev libldap2-dev unixodbc-dev libpq-dev libsqlite3-dev libaspell-dev libsnmp-dev libpcre3-dev libtidy-dev -yqq
|
|
# Install php extensions
|
|
- docker-php-ext-install mbstring pdo_mysql curl json intl gd xml zip bz2 opcache
|
|
# Install & enable Xdebug for code coverage reports
|
|
- pecl install xdebug
|
|
- docker-php-ext-enable xdebug
|
|
# Install Composer and project dependencies.
|
|
- curl -sS https://getcomposer.org/installer | php
|
|
- php composer.phar install
|
|
# Install Node dependencies.
|
|
# comment this out if you don't have a node dependency
|
|
- npm install
|
|
# Copy over testing configuration.
|
|
# Don't forget to set the database config in .env.testing correctly
|
|
# DB_HOST=mysql
|
|
# DB_DATABASE=project_name
|
|
# DB_USERNAME=root
|
|
# DB_PASSWORD=secret
|
|
- cp .env.testing .env
|
|
# Run npm build
|
|
# comment this out if you don't have a frontend build
|
|
# you can change this to to your frontend building script like
|
|
# npm run build
|
|
- npm run dev
|
|
# Generate an application key. Re-cache.
|
|
- php artisan key:generate
|
|
- php artisan config:cache
|
|
# Run database migrations.
|
|
- php artisan migrate
|
|
# Run database seed
|
|
- php artisan db:seed
|
|
|
|
test:
|
|
script:
|
|
# run laravel tests
|
|
- php vendor/bin/phpunit --coverage-text --colors=never
|
|
# run frontend tests
|
|
# if you have any task for testing frontend
|
|
# set it in your package.json script
|
|
# comment this out if you don't have a frontend test
|
|
- npm test
|
|
|
|
deploy:
|
|
stage: deploy
|
|
script: echo "Define your deployment script!"
|
|
environment: production
|