git clone [email protected]:DeSmart/laravel-vanilla.git .
Set proper paths to folders and shared volumes in the following files:
docker-compose.local.yml
(mounted volumes for both 'www' and 'api' services)
Proceed with the following commands:
. dev.sh
dc up -d
chmod -R 0777 bootstrap/ storage/ (on host machine)
cp .env.example .env
dc run php composer install --prefer-dist
dc run php php artisan key:generate
dc run php php vendor/bin/codecept bootstrap
rm -rf .git
-
Goto variables setting page (https://git.desmart.com/PROJECT/PATH/variables)
-
Add entry for
APP_KEY
(it will be used for staging environments, and during test builds)- this entry should contain full output of
artisan key:generate --show
command
alternatively run this command - it will generate full key:
docker run --rm desmart/laravel-appkey
- this entry should contain full output of
-
Edit
.gitlab-ci.yml
file and updatevariables.PROJECT_NAME
value to match yours project name
CI, by default, will:
- run unit tests on every push
- test command is defined in
Makefile
, it will be ran onphp
container
- test command is defined in
- generate and push to registry docker images for
php
andwww
service.- images will be built for branches:
develop
,master
,release/*
and stable (tagged) versions
- images will be built for branches:
- depending on branch a new staging version will be deployed:
develop
-> test version (url: test.PROJECT_NAME.staging.desmart.com)release/*
-> beta version (url: beta.PROJECT_NAME.staging.desmart.com)
In order to speed up development, check out these packages as you might find them useful:
- desmart/adr - ADR pattern implementation
- desmart/jwt-auth - Simple JWT implementation fo rapid user authentication
Below you will find a project readme.md
template.
Some introduction text here.
This project requires Docker to run. If you don't have Docker installed, please visit https://www.docker.com/ and follow the instructions regarding installation. Once you have Docker installed, proceed with the instructions below.
- Clone the project from GitLab:
git clone [email protected]:foo/bar.git .
- Run
composer install
. - Do all sorts of crazy stuff to get the project up and running.
ssh project-name
cd /var/www/project
phing build
- eat popcorn
ssh project-name
cd /var/www/project
phing build
- eat popcorn
ssh project-name
cd /var/www/project
phing build
- eat popcorn
- PHP: 7.0
- MySql: 5.6
- Back-end / API - John Doe, [email protected], mobile +48 555 666 777
- iOS / Android - John Doe, [email protected], mobile +48 555 666 777
- QA - John Doe, [email protected], mobile +48 555 666 777
- Product Owner - John Doe, [email protected], mobile +48 555 666 777
- Graphic Designer - John Doe, [email protected], mobile +48 555 666 777
- Issue tracker - https://pivotaltracker.com/n/projects/123
- Prototype - https://uxpin.com/foobar
- Docs - https://drive.google.com/foobar
In order to run tests use the following commands:
- run
vendor/bin/phpunit --verbose
- run
vendor/bin/phpspec run --verbose
- API: http://foo.desmart.com
- Front-end: http://bar.desmart.com
- API: http://foo.desmart.com
- Front-end: http://bar.desmart.com
- API: http://foo.desmart.com
- Front-end: http://bar.desmart.com
List of actions needed to be taken when introducing a new developer to the project (e.g. one developer is leaving for holidays and wants to pass his know-how to a new person).
- install and configure the project
- give SSH access
- show pictures of cats