diff options
-rw-r--r-- | .gitignore | 1 | ||||
-rw-r--r-- | Makefile | 2 | ||||
-rw-r--r-- | web-ui/.babelrc | 7 | ||||
-rw-r--r-- | web-ui/package.json | 53 | ||||
-rw-r--r-- | web-ui/test/unit/common/input_field/input_field.spec.js | 20 | ||||
-rw-r--r-- | web-ui/test/unit/common/submit_button/submit_button.spec.js | 16 |
6 files changed, 77 insertions, 22 deletions
@@ -36,3 +36,4 @@ pixelated.cfg service/_trial_temp/ _trial_temp web-ui/coverage +.nyc_output @@ -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') + }) +}) |