Yii 2 Practical Project Template is a skeleton Yii 2 application based on the yii2-advanced template best for developing complex Web applications with multiple tiers. The template allows a practical method to directly access the frontend from the app root.
The template includes three tiers: front end, back end, and console, each of which is a separate Yii application.
The template is designed to work in a team development environment. It supports deploying the application in different environments.
After installing an app in the yii2-advanced application you normally would access the
frontend by:
http://domain/app/frontend/web
However, in many practical scenarios (especially on shared and single domain hosts) one would want their users to directly access frontend as:
http://domain/app
The yii2-app-practical enables you to achieve just that by carefully moving and rearranging the
bootstrap files and web components of frontend to work directly out of the app root. The
frontend/web is entirely eliminated and one can directly access the application frontend
this way:
http://domain/app
All other aspects of the app configuration remain the same as the yii2-advanced app. The common, backend and console
will remain as is. The frontend config, assets, models, controllers, views, widgets and components, will still reside within
the frontend directory. It is just the web access that is moved out to app root.
- The template has some security preconfigured for users with Apache web servers. It has a default
.htaccesssecurity configuration setup. - The template has prettyUrl enabled by default and the changes have been made to
.htaccessas well asurlManagercomponent config in the common config directory. - The template has isolated cookie settings for backend and frontend so that you can seamlessly access frontend and backend from same client.
The config files includes special
identityandcsrfcookie parameter settings for backend. Edit it according to your needs if necessary.
/
/ contains the frontend entry script, favicon, and robots.txt.
assets/ contains the frontend web runtime assets
common
config/ contains shared configurations
mail/ contains view files for e-mails
models/ contains model classes used in both backend and frontend
console
config/ contains console configurations
controllers/ contains console controllers (commands)
migrations/ contains database migrations
models/ contains console-specific model classes
runtime/ contains files generated during runtime
backend
assets/ contains backend application assets such as JavaScript and CSS
config/ contains backend configurations
controllers/ contains Web controller classes
models/ contains backend-specific model classes
runtime/ contains files generated during runtime
views/ contains view files for the Web application
web/ contains the entry script and Web resources
frontend
assets/ contains frontend application assets such as JavaScript and CSS
config/ contains frontend configurations
controllers/ contains Web controller classes
models/ contains frontend-specific model classes
runtime/ contains files generated during runtime
views/ contains view files for the Web application
widgets/ contains frontend widgets
vendor/ contains dependent 3rd-party packages
environments/ contains environment-based overrides
tests contains various tests for the "practical" application
codeception/ contains tests developed with Codeception PHP Testing Framework
The minimum requirement by this application template that your Web server supports PHP 5.4.0.
You can choose to install the application using one of the following methods.
If you do not have Composer, you may install it by following the instructions at getcomposer.org.
You can then install the application using the following command:
php composer.phar global require "fxp/composer-asset-plugin:~1.0.0"
php composer.phar create-project --prefer-dist --stability=dev kartik-v/yii2-app-practical practical
Download the archive file directly to a directory named practical that is directly under the Web root.
Note: When using a archive file method, the vendor folder is not automatically created. You must download the latest yii2-advanced archive and then extract the vendor folder from here. Then you must copy this folder directly under the app root (i.e.
practicaldirectory).
After this is complete, follow the instructions given in "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.
- Run command
initto initialize the application with a specific environment. - Create a new database and adjust the
components['db']configuration incommon/config/main-local.phpaccordingly. - 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/and using the URLhttp://frontend/ - for backend
/path/to/yii-application/backend/web/and using the URLhttp://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.
- Edit the config files as needed. Especially set the correct paths for the user identity cookie in
backend/config/main-local.php.
You can read the yii2-advanced application guide to understand details on working with the advanced application.
Follow the tests section README for setting up the tests. For details of testing in Yii 2.0, read the testing overview and setup within the Yii 2.0 Guide. Setting up the testing environment broadly involves the following steps.
Install additional composer packages:
php composer.phar require --dev "codeception/codeception: 2.0" "codeception/specify: *" "codeception/verify: *"
This application boilerplate uses database in testing, so you should create three databases that are used in tests:
yii2_practical_unit- database for unit tests;yii2_practical_functional- database for functional tests;yii2_practical_acceptance- database for acceptance tests.
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.
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/practical 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 /practical/.
If you already have a server configured or your application is not located in a folder called practical, you may need to adjust the TEST_ENTRY_URL in frontend/tests/_bootstrap.php and backend/tests/_bootstrap.php.
After that is done you should be able to run your tests, for example to run frontend tests do:
cd frontend../vendor/bin/codecept build../vendor/bin/codecept run
In similar way you can run tests for other application tiers - backend, console, common.
You can also adjust you application suite configs and _bootstrap.php settings to use other urls and files, as it is done in yii2-basic.

