

JavaScriptにおける
について扱います
function average(arr) {
  var result;
  var sum = 0;
  for (var i = 0, len = arr.length; i < len; i++) {
    sum += arr[i];
  }
  result = sum / arr.length;
  return result;
}console.log(average([10, 20])); //=> 15
console.log(average([10, 20, 30])); //=> 20function average(arr) {
  var sum = arr.reduce(function(a, b) { return a + b; });
  return sum / arr.length;
}console.log(average([10, 20])); //=> 15
console.log(average([10, 20, 30])); //=> 20describe('average()', function() {
  it('平均値が返ること', function() {
    expect(average([10, 20])).to.be(15);
    expect(average([10, 20, 30])).to.be(20);
  });
});function confirmAndRemove(el) {
  if (window.confirm('消すよ?')) {
    $(el).remove();
  }
}// window.confirmを全く別のフェイク関数に置き換える
var stub = sinon.stub(window, 'confirm');
// window.confirmが呼ばれたらtrueを返す
stub.returns(true);
/* ここで要素が消えているかをテストする */
// 元のwindow.confirmに戻す
stub.restore();describe('confirmAndRemove()', function() {
  beforeEach(function() {
    // 要素を作る
    this.parent = document.createElement('div');
    this.el = document.createElement('div');
    this.parent.appendChild(this.el);
    // window.confirmをstub化
    this.stub = sinon.stub(window, 'confirm');
  });
  afterEach(function() {
    // window.confirmを元に戻す
    this.stub.restore();
  });
  context('window.confirmがtrueを返す場合', function() {
    beforeEach(function() {
      // window.confirmがtrueを返すように設定
      this.stub.returns(true);
      confirmAndRemove(this.el);
    });
    it('要素が削除されること', function() {
      expect(this.parent.childNodes.length).to.be(0);
    });
  });
  context('window.confirmがfalseを返す場合', function() {
    beforeEach(function() {
      // window.confirmがfalseを返すように設定
      this.stub.returns(false);
      confirmAndRemove(this.el);
    });
    it('要素が削除されないこと', function() {
      expect(this.parent.childNodes.length).to.be(1);
    });
  });
});// jQueryのremove関数をspy化
var spy = sinon.spy(jQuery.fn, 'remove');
// テスト対象メソッド呼び出し
confirmAndRemove(el);
// jQueryのremoveメソッドが呼ばれていることをチェック
expect(spy.calledOnce).to.be(true);function confirmAndRemove(el) {
  if (window.confirm('消すよ?')) {
    // jQueryとか使わない
    el.parentNode.removeChild(el);
  }
}// jQueryのremoveメソッドが呼ばれたかを検証
expect(removeSpy.calledOnce).to.be(true);// 要素が削除されたかを検証
expect(parentElem.childNodes.length).to.be(0);$(function() {
  var $form = $('.todoForm');
  var $list = $('.todoList');
  $form.on('submit', function(e) {
    e.preventDefault();
    var $input = $('input[type="text"]');
    var val = $input.val();
    var $li = $('<li>');
    var $text = $('<span>').addClass('todoText').text(val);
    var $checkbox = $('<input type="checkbox">');
    var $remove = $('<span>').addClass('removeBtn').text('x');
    $checkbox.on('click', function() {
      $li.toggleClass('is-complete');
    });
    $remove.on('click', function() {
      if (!window.confirm('消しますよ')) return;
      $li.remove();
    });
    $li.append($checkbox, $text, $remove);
    $list.append($li);
    $input.val('');
  });
});module.exports = {
  'Todo App Testing': function (client) {
    client
      // 対象のページをブラウザで開く
      .url('http://localhost:8000/index.html')
      // テキストボックスに文字を入れて送信
      .setValue('.todoText', 'todo test')
      .submitForm('.todoForm')
      // li要素が作成されている
      .assert.elementPresent('.todoList li')
      // リストアイテムのテキストは送信したものと一致している
      .assert.containsText('.todoList li', 'todo test')
      // checkboxをクリックしたら`is-complete`が追加される
      .click('.todoList li input[type="checkbox"]')
      .assert.cssClassPresent('.todoList li', 'is-complete')
      // removeBtnをクリックしてconfirmでキャンセルしてもli要素は消えない
      .click('.todoList li .removeBtn')
      .dismissAlert()
      .assert.elementPresent('.todoList li')
      // removeBtnをクリックしてconfirmでOKしたらli要素が消える
      .click('.todoList li .removeBtn')
      .acceptAlert()
      .assert.elementNotPresent('.todoList li')
      // 検証終了
      .end();
  }
};ユニットテストと比べて