テストを始めるまでのヤク狩り
メモ。
色々言い訳作って JavaScript のテストを書かなかったけど、さすがにマズいので書いてみる。
なお、ここでの JavaScript のテストは Web ブラウザで動く JavaScript。
テストを始めるまでに敷居が異様に高いと感じたのでまとめる。
典型的な yak shaving!
テストダブル
とりあえず Sinon.js を使っとけという雰囲気。
テストランナー
Grunt.js + Jasmine と Karma + Mocha を試す。
Gurntfile.js
module.exports = function (grunt) { grunt.initConfig({ jasmine: { myproject: { src: 'app/js/src/*.js', options: { specs: 'specs/*Spec.js', helpers: [ 'app/js/libs/jquery/dist/jquery.js', 'app/js/libs/underscore/underscore.js', 'app/js/libs/backbone/backbone.js', 'app/js/src/app.js' ] } } } }); grunt.loadNpmTasks('grunt-contrib-jasmine'); };
$ grunt jasmine Running "jasmine:myproject" (jasmine) task Testing jasmine specs via PhantomJS myproject suite ✓ expect test run 1 spec in 0.004s. >> 0 failures Done, without errors.
ブラウザのテストなので、どうやってファイルを require するのか分からなかったけど、
依存関係のあるものを helpers に並べたら動いた。
続いて Karma を試した。
こっちは Karma(テストランナー) + Mocha(テストフレームワーク) + expect(アサーション) + spec(レポーター)
Jasmine みたいにフルスタックじゃないから自分で色々選ぶ。
$ npm install karma-cli -g $ npm install karma-cli --save-dev $ npm install karma-spec-reporter --save-dev $ npm install karma-chai --save-dev
karma.conf.js
// Karma configuration // Generated on Sat Apr 26 2014 14:48:59 GMT+0900 (JST) module.exports = function(config) { config.set({ // base path that will be used to resolve all patterns (eg. files, exclude) basePath: '', // frameworks to use // available frameworks: https://npmjs.org/browse/keyword/karma-adapter frameworks: ['mocha', 'chai'], // list of files / patterns to load in the browser files: [ 'app/js/libs/jquery/dist/jquery.js', 'app/js/libs/underscore/underscore.js', 'app/js/libs/backbone/backbone.js', 'app/js/src/*.js', 'specs/*.js' ], // list of files to exclude exclude: [ '**/*.swp' ], // preprocess matching files before serving them to the browser // available preprocessors: https://npmjs.org/browse/keyword/karma-preprocessor preprocessors: { }, // test results reporter to use // possible values: 'dots', 'progress' // available reporters: https://npmjs.org/browse/keyword/karma-reporter reporters: ['spec'], // web server port port: 9876, // enable / disable colors in the output (reporters and logs) colors: true, // level of logging // possible values: config.LOG_DISABLE || config.LOG_ERROR || config.LOG_WARN || config.LOG_INFO || config.LOG_DEBUG logLevel: config.LOG_INFO, // enable / disable watching file and executing tests whenever any file changes autoWatch: true, // start these browsers // available browser launchers: https://npmjs.org/browse/keyword/karma-launcher browsers: ['PhantomJS'], // Continuous Integration mode // if true, Karma captures browsers, runs the tests and exits singleRun: false }); };
こっちも依存しているライブラリをどうやって require するのか分からなかったが、files に並べればいける。
$ karma start INFO [karma]: Karma v0.12.12 server started at http://localhost:9876/ INFO [launcher]: Starting browser PhantomJS INFO [PhantomJS 1.9.7 (Mac OS X)]: Connected on socket dDU7DYAmEEMsT1SQ-nhS with id 13921662 myproject suite ✓ expect test run PhantomJS 1.9.7 (Mac OS X): Executed 1 of 1 SUCCESS (0.004 secs / 0 secs)
試さなかったもの
- Gulp.js, Testem, Power-Assert
- RequireJS を絡ませたテスト