generator-react-webpack/test/test-creation.js
2015-01-17 14:56:19 -07:00

189 lines
5.1 KiB
JavaScript

/*global describe, beforeEach, it*/
'use strict';
var path = require('path');
var helpers = require('yeoman-generator').test;
var assert = require('yeoman-generator').assert;
var _ = require('underscore.string');
describe('react-webpack generator', function() {
var react;
var expected = [
'src/favicon.ico',
'src/styles/normalize.css',
'src/styles/main.css',
'src/index.html',
'Gruntfile.js',
'webpack.config.js',
'karma.conf.js',
'package.json'
];
var mockPrompts = {};
var genOptions = {
'appPath': 'src',
'skip-install': true,
'skip-welcome-message': true,
'skip-message': true
};
var deps = [
'../../app',
'../../common',
'../../component',
'../../main'
];
beforeEach(function(done) {
helpers.testDirectory(path.join(__dirname, 'temp-test'), function(err) {
if (err) {
return done(err);
}
react = helpers.createGenerator('react-webpack:app', deps, false, genOptions);
helpers.mockPrompt(react, mockPrompts);
done();
});
});
describe('App files', function() {
it('should generate dotfiles', function(done) {
react.run({}, function() {
helpers.assertFile([].concat(expected, [
'.yo-rc.json',
'.editorconfig',
'.gitignore',
'.jshintrc'
]));
done();
});
});
it('should generate app files', function(done) {
react.run({}, function() {
// TODO: Hack, no time to work out why generated
// files not present at point of test...
setTimeout(function() {
helpers.assertFile(expected);
done();
});
});
});
it('should generate expected JS files', function(done) {
react.run({}, function() {
setTimeout(function() {
helpers.assertFile([].concat(expected, [
'src/scripts/components/TempTestApp.js',
'src/scripts/components/main.js'
]));
done();
});
});
});
it('should generate expected test JS files', function(done) {
react.run({}, function() {
// TODO: Hack, no time to work out why generated
// files not present at point of test...
setTimeout(function() {
helpers.assertFile([].concat(expected, [
'test/helpers/phantomjs-shims.js',
'test/helpers/react/addons.js',
'test/spec/components/TempTestApp.js'
]));
done();
});
});
});
it('should use HMR webpack API inside of configs', function (done) {
react.run({}, function() {
assert.fileContent([
['package.json', /react-hot-loader/],
['Gruntfile.js', /hot:\s*true/],
['webpack.config.js', /react-hot/],
['webpack.config.js', /webpack\.HotModuleReplacementPlugin/],
['webpack.config.js', /webpack\.NoErrorsPlugin/],
['webpack.config.js', /webpack\/hot\/only-dev-server/]
]);
done();
});
});
});
describe('Generator', function () {
it('should contain info about used style lang', function (done) {
react.run({}, function() {
assert.ok(react.config.get('styles-language'));
done();
});
});
it('by default should use css style lang', function (done) {
react.run({}, function() {
assert.equal(react.config.get('styles-language'), 'css');
done();
});
});
var assertStyle = function (lang, done) {
helpers.mockPrompt(react, {
stylesLanguage: lang
});
react.run({}, function() {
assert.equal(react.config.get('styles-language'), lang);
done();
});
};
it('should use sass style lang', function (done) {
assertStyle('sass', done);
});
it('should use scss style lang', function (done) {
assertStyle('scss', done);
});
it('should use less style lang', function (done) {
assertStyle('less', done);
});
it('should use stylus style lang', function (done) {
assertStyle('stylus', done);
});
});
describe('Subgenerators', function() {
var generatorTest = function(generatorType, specType, targetDirectory, scriptNameFn, specNameFn, suffix, done) {
var name = 'Foo';
var deps = [path.join('../..', generatorType)];
genOptions.appPath += '/scripts'
var reactGenerator = helpers.createGenerator('react-webpack:' + generatorType, deps, [name], genOptions);
react.run([], function() {
reactGenerator.run([], function() {
helpers.assertFileContent([
[path.join('src/scripts', targetDirectory, name + '.js'), new RegExp('var ' + scriptNameFn(name) + suffix, 'g')],
[path.join('test/spec', targetDirectory, name + '.js'), new RegExp('describe\\(\'' + specNameFn(name) + suffix + '\'', 'g')]
]);
done();
});
});
}
it('should generate a new component', function(done) {
react.run({}, function() {
generatorTest('component', 'component', 'components', _.capitalize, _.capitalize, '', done);
});
});
});
});