Yii 2 Pheme Application Template
Yii 2 Pheme Application Template is a skeleton Yii 2 application best for
developing complex Web applications with multiple tiers., (*1)
The template includes three tiers: front end, back end, api and console, each of which
is a separate Yii application., (*2)
The template is designed to work in a team development environment. It supports
deploying the application in different environments., (*3)
DIRECTORY STRUCTURE
TBD, (*4)
REQUIREMENTS
The minimum requirement by this application template that your Web server supports PHP 5.4.0., (*5)
INSTALLATION
Install from an Archive File
Extract the archive file downloaded from yiiframework.com to
a directory named advanced
that is directly under the Web root., (*6)
Then follow the instructions given in "GETTING STARTED"., (*7)
Install via Composer
If you do not have Composer, you may install it by following the instructions
at getcomposer.org., (*8)
You can then install the application using the following command:, (*9)
Linux
php composer.phar global require "fxp/composer-asset-plugin:1.0.0-beta4"
php composer.phar create-project --prefer-dist --stability=dev prawee/yii2-app-pheme your-project-name
Windows
composer global require "fxp/composer-asset-plugin:1.0.0-beta4"
composer create-project --prefer-dist --stability=dev prawee/yii2-app-pheme your-project-name
cd your-project-name
composer --prefer-dist update
GETTING STARTED
After you install the application, you have to conduct the following steps to initialize
the installed application. You only need to do these once for all., (*10)
- Run command
init
to initialize the application with a specific environment.
- Create a new database and adjust the
components['db']
configuration in common/config/main-local.php
accordingly.
- Apply migrations with console command
yii migrate
. This will create tables needed for the application to work.
- Set document roots of your Web server:
- for frontend
/path/to/yii-application/frontend/web/
and using the URL http://frontend/
- for backend
/path/to/yii-application/backend/web/
and using the URL http://backend/
To login into the application, you need to first sign up, with any of your email address, username and password.
Then, you can login into the application with same email address and password at any time., (*11)
TESTING
Install additional composer packages:
* php composer.phar require --dev "codeception/codeception: 1.8.*@dev" "codeception/specify: *" "codeception/verify: *"
, (*12)
This application boilerplate use database in testing, so you should create three databases that are used in tests:
* yii2_advanced_unit
- database for unit tests;
* yii2_advanced_functional
- database for functional tests;
* yii2_advanced_acceptance
- database for acceptance tests., (*13)
To make your database up to date, you can run in needed test folder yii migrate
, for example
if you are starting from frontend
tests then you should run yii migrate
in each suite folder acceptance
, functional
, unit
it will upgrade your database to the last state according migrations., (*14)
To be able to run acceptance tests you need a running webserver. For this you can use the php builtin server and run it in the directory where your main project folder is located. For example if your application is located in /www/advanced
all you need to is:
cd /www
and then php -S 127.0.0.1:8080
because the default configuration of acceptance tests expects the url of the application to be /advanced/
.
If you already have a server configured or your application is not located in a folder called advanced
, you may need to adjust the TEST_ENTRY_URL
in frontend/tests/_bootstrap.php
and backend/tests/_bootstrap.php
., (*15)
After that is done you should be able to run your tests, for example to run frontend
tests do:, (*16)
cd frontend
../vendor/bin/codecept build
../vendor/bin/codecept run
In similar way you can run tests for other application tiers - backend
, console
, common
., (*17)
You also can adjust you application suite configs and _bootstrap.php
settings to use other urls and files, as it is can be done in yii2-basic
., (*18)
2014-07-16 updated composer.json, (*19)