PHPackages                             rmrevin/yii2-application - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Framework](/categories/framework)
4. /
5. rmrevin/yii2-application

ActiveProject[Framework](/categories/framework)

rmrevin/yii2-application
========================

Yii 2 Advanced Application Template edited by rmrevin

222PHP

Since May 15Pushed 10y ago1 watchersCompare

[ Source](https://github.com/rmrevin/yii2-application)[ Packagist](https://packagist.org/packages/rmrevin/yii2-application)[ RSS](/packages/rmrevin-yii2-application/feed)WikiDiscussions master Synced 1mo ago

READMEChangelogDependenciesVersions (1)Used By (0)

Каркас yii2 application
=======================

[](#каркас-yii2-application)

Создание нового приложения
--------------------------

[](#создание-нового-приложения)

Если у Вас не установлен [Composer](http://getcomposer.org/), вы должны установить его следуя инструкция на официальном сайтеа [getcomposer.org](http://getcomposer.org/doc/00-intro.md#installation-nix).

Новый проект Вы можете создаь выполнив команду:

```
php composer.phar create-project --prefer-dist --stability=dev rmrevin/yii2-application my-new-application

```

Подготовка окружения
--------------------

[](#подготовка-окружения)

Для обработки bower пакетов, в системе требуется глобально установить пакет `fxp/composer-asset-plugin`. Делается это командой

```
php composer.phar global require "fxp/composer-asset-plugin:1.0.0"

```

Для полуавтоматического деплоя используется phing. Установить phing не составляет труда. Для этого необходимо выполнить команду

```
pear channel-discover pear.phing.info
pear install --alldeps phing/phing
```

Деплой
------

[](#деплой)

Document root -

- Web - `~/frontend-app/web`

1. Клонировать проект через git
2. Скопировать файл `.environment.example.php` в `.environment.php`, заполнить необходимые данные. MYSQL - основаня база, MYSQL\_TEST - копия базы для автоматических тестов.
3. Установить зависимости через композер `./composer.phar install` (если нет композера, установить через `./getcomposer`)
4. С помощью команды `./init` выбрать нужное окружение
5. Развернуть миграции `./frontend migrate`
6. Установить frontend зависимости через npm `npm install`
7. Скомпилировать less в css `phing less`
8. Создать пользователя-администратора `./frontend user/add`, программа спросит придумать имя, email и пароль

Система готова к эксплуатации.

Обновление
----------

[](#обновление)

1. Обновить кодовую базу через git
2. Обновить композер `./composer.phar selfupdate`
3. Обновить зависимости через композер `./composer.phar update`
4. Развернуть новые миграции `./frontend migrate`
5. Оновить frontend зависимости через npm `npm update`
6. Скомпилировать less в css `phing less`

Система готова к эксплуатации.

Полуавтоматический деплой и обновление
--------------------------------------

[](#полуавтоматический-деплой-и-обновление)

Сначала потребуется скачать обновление из гита командой `git pull`, затем выполнить одну из команд:

- `phing build/production` - собрать проект для продакшена.
- `phing build/demo` - собрать проект для demo площадки.
- `phing build/dev` - собрать проект для dev площадки.

Дополнительно доступны следующие команды (они выполняются в рамках `build/*` команд, и добавлены только для справки):

- `phing clear` - удалить все временные файлы и логи во всех приложениях.
- `phing clear/frontend` - удалить все временные файлы и логи в приложении frontend.
- `phing migrate` - выполнить все новые миграции для всех приложений
- `phing migrate/frontend` - выполнить все новые миграции для приложения frontend

Основные моменты
----------------

[](#основные-моменты)

За основу каркаса взят yii2-advance-application. Он позволяет создавать комплекс из разных приложений с разными подходами (обычное web приложение, cli приложение, rest приложение). На данный момент, в проекте созданны следующие приложения:

- frontend-app - основное web приложение.

Так же присутствуют несколько вспомогательных разделов:

- common - общие для всех приложений ресурсы (конфиги, расширяющие компоненты фреймворка, хелперы)
- frontend-modules - здесь хранятся модули для web приложения. Это как раз таки те модули, которые вызываются из веба. В идеале, здесь должны быть только расширяющие компонениы, контроллеры, модели форм и представления.

Для запуска тестов
------------------

[](#для-запуска-тестов)

Для того, чтобы запустить codeception тесты, необходимо скопировать конфигурации для тестов и настроить их для своей плащадки.

Автоматически, это поможет сделать `phing`. Запускаете из корня проекта команду `phing build/codecept`, и конфиги автоматически скопируются.

Для ручного копирования необходимо в директориях `erp-app/tests` и `hub-app/tests` скопировать файлы `acceptance.suite.yml.dist` в `acceptance.suite.yml`, `functional.suite.yml.dist` в `functional.suite.yml` и `unit.suite.yml.dist` в `unit.suite.yml`.

После того, как файлы были скопированы, необходимо их настроить. В `acceptance.suite.yml` необходимо изменить параметры `PhpBrowser/url` и `REST/url` под настройки Вашей площадки.

Остальные файлы могут быть оставлены без изменений.

После создания конфигов, нужно "собрать" "актёров" для тестирования. Для этого из корня проекта выполните команды

```
./codecept build -c web-app/tests/codeception.yml
```

Теперь можно приступать непосредственно к запуску тестов.

Для этого из корня провека выполните команду

```
# запустить выполнение всех тестов во всех приложениях
./codecept run

# запустить выполнение только тестов для erp приложения
./codecept run -c web-app/tests/codeception.yml

# запустить выполнение только unit тестов для hub приложения
./codecept run -c web-app/tests/codeception.yml unit

# запустить выполнение определённого unit теста для hub приложения
./codecept run -c web-app/tests/codeception.yml unit commands/UserCommandTest.php
```

Для генерации карты покрытия кода к вызову комманды добавьте параметр --coverage-html. Для отображения более подробной иформации по ходу выполнения теста к вызову комманды добавьте параметр --debug.

```
./codecept run --coverage-html
./codecept run -c web-app/tests/codeception.yml --coverage-html --debug
```

###  Health Score

21

—

LowBetter than 19% of packages

Maintenance20

Infrequent updates — may be unmaintained

Popularity9

Limited adoption so far

Community7

Small or concentrated contributor base

Maturity41

Maturing project, gaining track record

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

### Community

Maintainers

![](https://www.gravatar.com/avatar/1ed2a8c869410bcc2f79245fe77cf156db86c83fed1c60c3dea8df1e04966788?d=identicon)[rmrevin](/maintainers/rmrevin)

---

Top Contributors

[![rmrevin](https://avatars.githubusercontent.com/u/803507?v=4)](https://github.com/rmrevin "rmrevin (63 commits)")

### Embed Badge

![Health badge](/badges/rmrevin-yii2-application/health.svg)

```
[![Health](https://phpackages.com/badges/rmrevin-yii2-application/health.svg)](https://phpackages.com/packages/rmrevin-yii2-application)
```

###  Alternatives

[laravel/telescope

An elegant debug assistant for the Laravel framework.

5.2k67.8M190](/packages/laravel-telescope)[laravel/passport

Laravel Passport provides OAuth2 server support to Laravel.

3.4k85.0M529](/packages/laravel-passport)[spiral/roadrunner

RoadRunner: High-performance PHP application server and process manager written in Go and powered with plugins

8.4k12.2M84](/packages/spiral-roadrunner)[nolimits4web/swiper

Most modern mobile touch slider and framework with hardware accelerated transitions

41.8k177.2k1](/packages/nolimits4web-swiper)[laravel/dusk

Laravel Dusk provides simple end-to-end testing and browser automation.

1.9k36.7M256](/packages/laravel-dusk)[laravel/prompts

Add beautiful and user-friendly forms to your command-line applications.

708181.8M591](/packages/laravel-prompts)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
