Laraland/.gitlab-ci.yml
2018-08-03 14:51:51 +07:00

120 lines
3.5 KiB
YAML

# This file is a template, and might need editing before it works on your project.
# Official framework image. Look for the different tagged releases at:
# https://hub.docker.com/r/library/php
image: registry.waf.or.id/gregorio/laraland: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: http://docs.gitlab.com/ce/ci/docker/using_docker_images.html#what-is-a-service
services:
- registry.waf.or.id/gregorio/laraland/mariadb:latest
variables:
# MYSQL_DATABASE: laraland
# MYSQL_ROOT_PASSWORD: secret
# This folder is cached between builds
# http://docs.gitlab.com/ce/ci/yaml/README.html#cache
cache:
paths:
- vendor/
# - node_modules/
stages:
- functional
- staging
# This is a basic example for a gem or script which doesn't use
# services such as redis or postgres
before_script:
# Add mariadb hostname to hosts file
- printf "172.17.0.2 mariadb\n" >> /etc/hosts
# Update packages
- apt-get update -yqq
# Upgrade to Node 7
# - curl -sL https://deb.nodesource.com/setup_7.x | bash -
# Install dependencies
# - apt-get install git 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 mysql-client nodejs -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
- composer 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
# Generate database file
- touch /var/tmp/laraland.db
# 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
- php artisan module:migrate
# Run database seed
# - php artisan db:seed
# - php artisan module:seed
# Generate passport password client
- php artisan passport:client --password --name=laraland
frameworktest:
stage: functional
script:
# run laravel tests
# - php vendor/bin/phpunit --coverage-text --colors=never
- php vendor/bin/codecept run functional
- php vendor/bin/codecept run functional -c Modules/Karyawaf
# 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
uploadstaging:
stage: staging
script:
# store ssh variables into file
- mkdir /root/.ssh
- echo "$SSH_PRIVATE_KEY" > /root/.ssh/id_rsa
- echo "$SSH_PUBLIC_KEY" > /root/.ssh/id_rsa.pub
- echo "$SSH_REMOTE_HOST" > /root/.ssh/known_hosts
# create permission for ssh files
- chmod -R 600 /root/.ssh
# run the test
- vendor/bin/robo test:server