Capybara-Webkit+Cucumber+Sinon.JSでJavaScriptのテストはここまで変わるフレームワークで実践! JavaScriptテスト入門(5)(2/3 ページ)

» 2013年02月20日 18時00分 公開
[清家巧,TIS コーポレート本部 戦略技術センター]

Capybara+Cucumberでテスト内容を記述する

 ここまででCucumberで特定のURLを開きスクリーンショットを保存するテストを記述し、実行できました。

 ただし、これだけではWebブラウザのスクリーンショットが取得できただけであり、JavaScriptのテストの内容になっていないので、まずはテスト対象となるプロダクションコードを用意してテストのコードを書いていきます。

プロダクションコードを用意する

 ここからは以下のHTML/JavaScriptに対するテストを書いていきます。

 このHTML/JavaScriptは「ユーザーが入力したユーザー名の利用可否をボタンを押したタイミングで取得し画面に利用可否を確認する」イメージで作ったHTML/JavaScriptで、jQueryに依存しています。

 「~/webapp/」ディレクトリを作成し、配下に以下の2ファイルを用意します。

<!DOCTYPE html>
<html lang="ja">
<head>
  <title>test_target</title>
  <meta charset="utf-8">
  <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.8.3/jquery.min.js"></script>
  <script>
    $(function (){
      $('#check').on('click', function(e){
        var inputtext = $('#user').attr('value');
        $('#msg').text("確認中...")
        $.getJSON("./status", {"name": inputtext}, function(res){
          if(res.status == "ok")
            $('#msg').text("利用可能です");
          else{
            $('#msg').text("利用できません");
          }
        });
      });
    });
  </script>
</head>
<body>
    <input id="user"   type="text" >
    <input id="check" type="button" value="確認">
    <div id="msg" ></div>
</body>
</html>
index.html

 これに加えて、本来はサーバサイドでユーザーアカウントをチェックするロジックを実装するところですが、今回は実験用に必ずNGを返すWeb APIを簡易的に実装します。

{"status": "ng"}
status

 このファイルを配置することにより、/statusのAPIからは毎回{"status": "ng"}が返され、Webブラウザ上で確認ボタンを押すと「利用できません」が表示されます。

 これら2ファイルを配置したディレクトリを用意して以下のスクリプトでWebサーバを作成して公開します。

cd ~/webapp
python -m SimpleHTTPServer 8000 &> /dev/null &

 この状態で「http://{IPアドレス}:8000/」でページが公開されます。このサイトに対してテストを記述していきます。AWS上で作業している場合セキュリティグループでポート8000番にInboundの許可を与えると、Webブラウザからテスト対象が見られます。

テストを記述

 上記の単純なHTML/JavaScriptに対してCapybaraとCucumberを使ってボタンを押したら「利用できません。」が表示されることを確認するテストを記述していきます。といっても難しいことはありません。

 直前の「~/test」と同様の構成をした「~/test2」ディレクトリを作成し、以下のファイルを作成してください。Rakefileは同じものを使い回します。

# language:ja
機能: ユーザー名を入力してAPIから利用の可否を取得し表示する
 シナリオ: ユーザー名を入力して確認を押下しNGであることを確認
  前提 "http://localhost:8000/"を表示
  もし "ユーザー名"を入力
  かつ 確認ボタンを押下
  ならば メッセージ"利用できません"が表示される
features/sample.feature

 テストシナリオはこのような記述にしました。「前提」に続けて前提となる条件、「もし」に続けてユーザーの操作、「ならば」に続けて期待する動作を記述していきます。

# -*- coding: utf-8 -*-
gem 'capybara', '~>2.0'
gem 'capybara-webkit', '~>0.14.1'
require 'capybara'
require 'capybara/dsl'
require 'capybara-webkit'
Capybara.default_driver = :webkit
include Capybara::DSL
前提 /\"(.+)\"を表示/ do |url|
  visit(url)
end
もし /\"(.+)\"を入力/ do |name|
  fill_in('user', :with => name)
end
もし '確認ボタンを押下' do
  click_button('確認')
end
ならば /メッセージ\"(.+)\"が表示される/ do |text|
  find('#msg').should have_content text
end
ならば /スクリーンショットを取得し\"(.+)\"に保存/ do |filename|
  page.save_screenshot  "./#{filename}"
end
features/step_definitions/steps.rb

 sample.feature内の操作の定義を行います。CapybaraのDSLドキュメントを参考に、入力やボタンの押下をRubyで記述します。

 ここまで準備したところで、テストを実行してみます。

 テストが通ったようですね。

テスト失敗させてみる

 次にテストを失敗させてみます。アプリケーションのAPIが「{"status":"ok"}」を返すようにファイルを変更します。

{"status": "ok"}
~/webapp/status

 これにより、画面に表示されるメッセージが変化するため、以下のようにテストが失敗します。

 HTML出力させると、このように出力されます。

 次にテストを修正します。

-ならば メッセージ"利用できません"が表示される
+ならば メッセージ"利用可能です"が表示される
features/sample.feature

 表示するメッセージの変更程度であれば簡単ですね。

 テストを修正後実行すると以下のようにテストが成功します。

Copyright © ITmedia, Inc. All Rights Reserved.

RSSについて

アイティメディアIDについて

メールマガジン登録

@ITのメールマガジンは、 もちろん、すべて無料です。ぜひメールマガジンをご購読ください。