Gulp BEM tmpl-specs updater
Плагин, для проверки и обновления шаблонов в magic-bundles и исходных блоках. Нужен для автоматической правки тестов. При запуске gulp плагина, проверяет magic-bundles и исходные тесты, если они различаются, то плагин показывает ошибки не совпадения в шаблонах и спрашивает, нужно ли заменить шаблоны.
Для чего
С помощью этого плагина, вы можете быстро править тесты, если вы уверены в том, что замена будет корректной. Помогает не ходить по файловой системе и не править все эти файлы вручную, то есть автоматизирует этот процесс.
Как пользоваться
- Создать gulp таск
- В параметрах передать пути к
magic-bundles
и кblocks
Пример:
const bemReplacer = require('gulp-bem-tmpl-specs-updater');
const gulp = require('gulp');
gulp.task('updater-tmpl-specs', () =>
gulp.src(['./magic-bundles/**/*.html', './blocks/**/*.tmpl-specs/*.html'], {
base: './'
})
.pipe(bemReplacer())
);
После каждого не совпадающего теста, будет выходит prompt о сообщении, нужно ли заменить эталонный тест.
Как работает
Плагин, на данный этап, НЕ принимает параметры. Она достаточно сильно завязана на файловую структуру
(будет изменено в ближайшем релизе). Все файлы она ищет в папке blocks
. Точка входа для файлов проверки:
magic-bundles
, для эталонных любая папка, любой вложенности. Главное, чтобы в ней были папки, формата *.blocks
.
Именно по этому паттерну и ищет плагин. Ниже будет приведен пример файловой структуры.
├── blocks/
| ├── magic-bundles/
| ├── ├── desktop.blocks/
| ├── ├── ├── user/
| ├── ├── ├── ├── user.tmpl-specs/
| ├── ├── ├── ├── ├── 10-empty.html
| ├── ├── ├── ├── ├── 20-simple.html
| └── └── └── └── └── 30-extended.html
| └── └── touch-pad
| └── └── touch-phone
| ├── yamoney-project
| ├── ├── common.blocks
| ├── ├── ├── user/
| ├── ├── ├── ├── user.tmpl-specs/
| ├── ├── ├── ├── ├── 10-empty.html
| ├── ├── ├── ├── ├── 20-simple.html
| └── └── └── └── └── 0-extended.html
| └── └── desktop.blocks
В данном примере произойдет следующее:
- Плагин пойдет по структуре magic-bundles и найдет первый файл формата
*.tmpl-specs
этим файлом окажется 10-empty.html, лежащий вuser
. - Затем, он найдет точно такой же файл, но в yamoney-projects. Но сделает это по уровням,
Например, для уровня
desktop
, плагин сначала попробует найти его вdesktop
, а потом вcommon
. Для планшетаtouch-pad
, произойдет проверка вtouch-pad
->touch
->common
. - После того, как плагин нашел файлы, он начнет их сравниват, если они НЕ идентичные, то покажет пользователю различия и спросит, хочет ли тот сделать замену html.
- После выбора пользователя, пойдет искать след. файл.
Таблица принипов поиска по блокам
Название уровня блока в magic-bundles | Название блоков, в которых будет происводиться сравнение |
---|---|
desktop |
desktop / common |
touch-pad |
touch-pad / touch / common |
touch-phone |
touch-phone / touch / common |