# 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