Skip to content

Commit

Permalink
added karma-mocha to the project
Browse files Browse the repository at this point in the history
  • Loading branch information
leonli committed Aug 14, 2015
1 parent 332734e commit 84b14a8
Show file tree
Hide file tree
Showing 13 changed files with 129 additions and 71 deletions.
2 changes: 2 additions & 0 deletions .eslintignore
@@ -1 +1,3 @@
webpack/*
karma.conf.js
tests.webpack.js
5 changes: 3 additions & 2 deletions .eslintrc
Expand Up @@ -3,7 +3,7 @@
"env": {
"browser": true,
"node": true,
"mocha": true
"mocha": true,
},
"rules": {
"react/jsx-uses-react": 2,
Expand All @@ -13,7 +13,8 @@
"block-scoped-var": 0,
// Temporarily disabled for test/* until babel/babel-eslint#33 is resolved
"padded-blocks": 0,
"no-console": 0
"no-console": 0,
"no-unused-expressions": 0
},
"plugins": [
"react"
Expand Down
64 changes: 64 additions & 0 deletions karma.conf.js
@@ -0,0 +1,64 @@
var webpack = require('webpack');
var writeStats = require('./webpack/utils/writeStats');

module.exports = function (config) {
config.set({

browsers: [ process.env.CONTINUOUS_INTEGRATION ? 'Firefox' : 'Chrome' ],

singleRun: false,

frameworks: [ 'mocha' ],

files: [
'tests.webpack.js'
],

preprocessors: {
'tests.webpack.js': [ 'webpack', 'sourcemap' ]
},

reporters: [ 'mocha' ],

webpack: {
devtool: 'inline-source-map',
module: {
loaders: [
{ test: /\.(jpe?g|png|gif|svg)$/, loader: 'url', query: {limit: 10240} },
{ test: /\.js$/, exclude: /node_modules/, loaders: ['react-hot', 'babel?stage=0&optional=runtime&plugins=typecheck']},
{ test: /\.json$/, loader: 'json-loader' },
{ test: /\.scss$/, loader: 'style!css?modules&importLoaders=2&sourceMap&localIdentName=[local]___[hash:base64:5]!autoprefixer?browsers=last 2 version!sass?outputStyle=expanded&sourceMap' }
]
},
resolve: {
modulesDirectories: [
'src',
'node_modules'
],
extensions: ['', '.json', '.js']
},
plugins: [
// hot reload
new webpack.HotModuleReplacementPlugin(),
new webpack.IgnorePlugin(/\.json$/),
new webpack.NoErrorsPlugin(),
new webpack.DefinePlugin({
__CLIENT__: true,
__SERVER__: false,
__DEVELOPMENT__: true,
__DEVTOOLS__: false // <-------- DISABLE redux-devtools HERE
}),
function () {
this.plugin('done', function(stats) {
writeStats.call(this, stats, 'dev');
});
}
]
},

webpackServer: {
noInfo: true
}

});
};
17 changes: 10 additions & 7 deletions package.json
Expand Up @@ -31,9 +31,7 @@
"watch-client": "node ./node_modules/better-npm-run watch-client",
"dev": "concurrent --kill-others \"npm run watch-client\" \"npm run start-dev\"",

"test": "scripts/test",
"test:watch": "scripts/test-watch",
"test:cov": "scripts/test-cov"
"test": "karma start"
},
"betterScripts": {
"start": {
Expand Down Expand Up @@ -108,11 +106,16 @@
"webpack": "^1.9.11",
"webpack-dev-server": "1.9.0",

"expect": "^1.7.0",
"isparta": "^3.0.3",
"jsdom": "~5.4.3",
"chai": "^3.2.0",
"karma": "^0.13.3",
"karma-chrome-launcher": "^0.2.0",
"karma-cli": "0.0.4",
"karma-firefox-launcher": "^0.1.4",
"karma-mocha": "^0.1.10",
"karma-sourcemap-loader": "^0.3.5",
"karma-webpack": "^1.7.0",
"mocha": "^2.2.5",
"mocha-jsdom": "~0.4.0"
"karma-mocha-reporter": "^1.1.0"

},
"engines": {
Expand Down
3 changes: 0 additions & 3 deletions scripts/test

This file was deleted.

3 changes: 0 additions & 3 deletions scripts/test-cov

This file was deleted.

3 changes: 0 additions & 3 deletions scripts/test-watch

This file was deleted.

4 changes: 2 additions & 2 deletions src/components/InfoBar.js
Expand Up @@ -2,9 +2,9 @@ import React, {Component, PropTypes} from 'react';
import {bindActionCreators} from 'redux';
import {connect} from 'react-redux';
import {load} from '../actions/infoActions';
//import {requireServerCss} from '../util';
import {requireServerCss} from '../util';

//const styles = __CLIENT__ ? require('./InfoBar.scss') : requireServerCss(require.resolve('./InfoBar.scss'));
const styles = __CLIENT__ ? require('./InfoBar.scss') : requireServerCss(require.resolve('./InfoBar.scss'));

@connect(
state => ({info: state.info.data}),
Expand Down
45 changes: 45 additions & 0 deletions src/components/__tests__/InfoBar-test.js
@@ -0,0 +1,45 @@
import React from 'react/addons';
import {expect} from 'chai';
import InfoBar from '../InfoBar';
import { Provider } from 'react-redux';
import createStore from 'redux/create';
import ApiClient from 'ApiClient';
const { TestUtils } = React.addons;
const client = new ApiClient();

describe('InfoBar', () => {
const mockStore = {
info: {
load: () => {},
loaded: true,
loading: false,
data: {
message: 'This came from the api server',
time: Date.now()
}
}
};

const store = createStore(client, mockStore);
const renderer = TestUtils.renderIntoDocument(
<Provider store={store} key="provider">
{() => <InfoBar/>}
</Provider>
);
const dom = React.findDOMNode(renderer);

it('should render correctly', () => {
expect(renderer).to.be.ok;
});

it('should render with correct value', () => {
const text = dom.getElementsByTagName('strong')[0].textContent;
expect(text).to.equal(mockStore.info.data.message);
});

it('should render with a reload button', () => {
const text = dom.getElementsByTagName('button')[0].textContent;
expect(text).to.be.a('string');
});

});
43 changes: 0 additions & 43 deletions test/components/InfoBar.spec.js

This file was deleted.

7 changes: 0 additions & 7 deletions test/domUtil.js

This file was deleted.

2 changes: 2 additions & 0 deletions tests.webpack.js
@@ -0,0 +1,2 @@
var context = require.context('./src', true, /-test\.js$/);
context.keys().forEach(context);
2 changes: 1 addition & 1 deletion webpack-stats.json
@@ -1 +1 @@
{"script":["/dist/main-c3f2742f0ef0f5c4203c.js"],"css":{"files":["/dist/main-c3f2742f0ef0f5c4203c.css"],"modules":{"/components/InfoBar.scss":{"infoBar":"_3CaW76q_itao4vT6ImAtWY","time":"_3uiV15bAtFsNhGVmJOLUIm"},"/views/App.scss":{"app":"_2N2tMYhyM4guw6BcfLIHRZ","brand":"H2EnzIdjXxu077Pyos9u9","appContent":"_2TNaaqV4672lJZWDK3SmYl"},"/views/Home.scss":{"home":"_7W8gWO2O6UzmbjycMt06y","masthead":"_3YnXLhQSO45M7g8zMwTS2m","logo":"_3tAuMHJjDL3Bsi2es1fe9w","humility":"_1zm76T9uCMq1qNPr-NvB67","github":"_1qAW-pHBGZ2CubHM1ExTk0","counterContainer":"xXL-P-ZWCR_7Xn1jEVOAG"},"/views/Login.scss":{"loginPage":"_13mAukbEFo9faR8plXhVHq"},"/views/Widgets.scss":{"widgets":"_3b78fAtttDm8hG8XmGjptr","refreshBtn":"tzSnAInHGmOuUSkWYNeBH"}}},"images":[{"original":"./src/views/kitten.jpg","compiled":"/dist/c29770d03d2e95e3ea5899d57c6cfeab.jpg"},{"original":"./src/views/logo.png","compiled":""}]}
{"script":[],"css":{"files":[],"modules":{"/components/InfoBar.scss":{"infoBar":"infoBar___17D6S","time":"time___3d2TC"}}},"images":[]}

0 comments on commit 84b14a8

Please sign in to comment.