summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--.gitignore1
-rw-r--r--Makefile2
-rw-r--r--web-ui/.babelrc7
-rw-r--r--web-ui/package.json53
-rw-r--r--web-ui/test/unit/common/input_field/input_field.spec.js20
-rw-r--r--web-ui/test/unit/common/submit_button/submit_button.spec.js16
6 files changed, 77 insertions, 22 deletions
diff --git a/.gitignore b/.gitignore
index 820e352c..8a974601 100644
--- a/.gitignore
+++ b/.gitignore
@@ -36,3 +36,4 @@ pixelated.cfg
service/_trial_temp/
_trial_temp
web-ui/coverage
+.nyc_output
diff --git a/Makefile b/Makefile
index a263ec42..1d7a2343 100644
--- a/Makefile
+++ b/Makefile
@@ -49,7 +49,7 @@ linters_py:
linters_js:
@cd web-ui;\
- npm run jshint
+ npm run lint
coverage:
@. $(VIRTUALENV)/bin/activate;\
diff --git a/web-ui/.babelrc b/web-ui/.babelrc
index 86c445f5..e74e4d82 100644
--- a/web-ui/.babelrc
+++ b/web-ui/.babelrc
@@ -1,3 +1,8 @@
{
- "presets": ["es2015", "react"]
+ "presets": ["es2015", "react"],
+ "env": {
+ "test": {
+ "plugins": ["istanbul"]
+ }
+ }
}
diff --git a/web-ui/package.json b/web-ui/package.json
index ab5d1b24..c9229270 100644
--- a/web-ui/package.json
+++ b/web-ui/package.json
@@ -9,6 +9,7 @@
"babel-cli": "^6.22.2",
"babel-core": "^6.21.0",
"babel-loader": "^6.2.10",
+ "babel-plugin-istanbul": "^3.1.2",
"babel-preset-es2015": "^6.18.0",
"babel-preset-react": "^6.22.0",
"bower": "1.7.9",
@@ -53,6 +54,7 @@
"mocha-webpack": "^0.7.0",
"modernizr": "^3.3.1",
"node-sass": "^4.5.0",
+ "nyc": "^10.1.2",
"quoted-printable": "^1.0.1",
"react": "^15.4.2",
"react-a11y": "^0.3.3",
@@ -69,28 +71,39 @@
"webpack": "^1.14.0"
},
"scripts": {
- "test": "npm run lint --silent && npm run build-statics --silent && npm run mocha-test && npm run karma-test",
- "mocha-test": "mocha-webpack --webpack-config webpack.test.config.js \"test/unit/**/*.spec.js\"",
- "mocha-watch": "mocha-webpack --watch --webpack-config webpack.test.config.js \"test/unit/**/*.spec.js\"",
- "karma-test": "karma start --single-run $GRUNT_OPTS",
- "debug": "npm run build && karma start --browsers Chrome $GRUNT_OPTS",
- "watch": "npm run compass-watch & npm run handlebars-watch & npm run build-js-watch",
- "watch-test": "karma start",
- "handlebars": "mkdir -p app/js/generated/hbs/ && handlebars app/templates/**/*.hbs > app/js/generated/hbs/templates.js --namespace=window.Pixelated --root .",
- "handlebars-watch": "watch 'npm run handlebars' app/templates",
- "compass": "compass compile",
- "compass-watch": "compass watch",
- "build": "npm run build-statics && npm run build-js",
- "build-statics": "npm run clean && npm run handlebars && npm run add_git_version && npm run compass",
- "build-prod": "npm run build-statics && webpack -p --config ./webpack.production.config.js",
- "build-js": "webpack --colors --progress",
- "build-js-watch": "webpack --colors --progress --watch",
- "lint": "npm run jshint && npm run eslint",
- "jshint": "jshint --config=.jshintrc app test",
- "eslint": "eslint src test/unit",
+ "test": "npm run lint --silent && npm run build:statics --silent && npm run test:unit",
+ "test:unit": "npm run test:coverage && npm run test:karma",
+ "test:coverage": "NODE_ENV=test nyc --check-coverage npm run test:mocha",
+ "test:mocha": "mocha-webpack --webpack-config webpack.test.config.js \"test/unit/**/*.spec.js\"",
+ "test:karma": "karma start --single-run $GRUNT_OPTS",
+ "test:watch:mocha": "npm run test:mocha -- --watch",
+ "test:watch:karma": "karma start",
+
+ "lint": "npm run lint:jshint && npm run lint:eslint",
+ "lint:jshint": "jshint --config=.jshintrc app test",
+ "lint:eslint": "eslint src test/unit",
+
+ "build": "npm run build:statics && npm run build:js",
+ "build:debug": "npm run build && karma start --browsers Chrome $GRUNT_OPTS",
+ "build:statics": "npm run clean && npm run build:handlebars && npm run add_git_version && npm run build:compass",
+ "build:prod": "npm run build:statics && webpack -p --config ./webpack.production.config.js",
+ "build:js": "webpack --colors --progress",
+ "build:compass": "compass compile",
+ "build:handlebars": "mkdir -p app/js/generated/hbs/ && handlebars app/templates/**/*.hbs > app/js/generated/hbs/templates.js --namespace=window.Pixelated --root .",
+
+ "watch": "npm run watch:compass & npm run watch:handlebars & npm run watch:js",
+ "watch:handlebars": "watch 'npm run build:handlebars' app/templates",
+ "watch:compass": "compass watch",
+ "watch:js": "webpack --colors --progress --watch",
+
"clean": "rm -rf dist/ app/js/generated/hbs/* app/css/*",
- "package": "PIXELATED_BUILD='package' npm run build-prod && npm run imagemin",
"imagemin": "node config/imagemin.js",
+ "package": "PIXELATED_BUILD='package' npm run build:prod && npm run imagemin",
"add_git_version": "/bin/bash config/add_git_version.sh"
+ },
+ "nyc": {
+ "include": [
+ "src/**/*.js"
+ ]
}
}
diff --git a/web-ui/test/unit/common/input_field/input_field.spec.js b/web-ui/test/unit/common/input_field/input_field.spec.js
new file mode 100644
index 00000000..88983f4f
--- /dev/null
+++ b/web-ui/test/unit/common/input_field/input_field.spec.js
@@ -0,0 +1,20 @@
+import { shallow } from 'enzyme'
+import expect from 'expect'
+import React from 'react'
+import InputField from 'src/common/input_field/input_field'
+
+describe('InputField', () => {
+ let inputField
+
+ beforeEach(() => {
+ inputField = shallow(<InputField label="Email" name="email" />)
+ })
+
+ it('renders an input of type text for email', () => {
+ expect(inputField.find('input[type="text"]').props().name).toEqual('email')
+ })
+
+ it('renders a label for the email', () => {
+ expect(inputField.find('label').text()).toEqual('Email')
+ })
+})
diff --git a/web-ui/test/unit/common/submit_button/submit_button.spec.js b/web-ui/test/unit/common/submit_button/submit_button.spec.js
new file mode 100644
index 00000000..629b3545
--- /dev/null
+++ b/web-ui/test/unit/common/submit_button/submit_button.spec.js
@@ -0,0 +1,16 @@
+import { shallow } from 'enzyme'
+import expect from 'expect'
+import React from 'react'
+import SubmitButton from 'src/common/submit_button/submit_button'
+
+describe('SubmitButton', () => {
+ let submitButton
+
+ beforeEach(() => {
+ submitButton = shallow(<SubmitButton buttonText="Add Email" />)
+ })
+
+ it('renders an input of type submit for add email', () => {
+ expect(submitButton.find('input[type="submit"]').props().value).toEqual('Add Email')
+ })
+})