まず、プロジェクト名とそのプロジェクトに属するエントリを表示する作業中の Rails 'show' ページを用意しました。angular $scope を使用してプロジェクト名が表示され、ERB のブロックを使用してエントリが表示された場合、私のテストは成功しました。エントリの ERB コードを angular ディレクティブ「ng-repeat」に置き換えたところ、シナリオをテストするエントリのみが失敗し始めました。興味深いことに、アプリケーションはまだブラウザーで動作していました。そして、私の見解の他の $scope 変数は、ほぼ同じテストを使用して合格し続けています。
show.html.erb の作業 (ERB で表示されるエントリ):
<div ng-controller="ProjectCtrl">
<h1>This is {{ project.details.name }}</h1>
<h2>Entries</h2>
<% @entries.each do |e| %>
<ul>
<li>
<%= e.title %>
</li>
<li>
<%= e.summary %>
</li>
</ul>
<% end %>
</div>
show.html.erb の破壊 (Angular で表示されるエントリ):
<div ng-controller="ProjectCtrl">
<h1>This is {{ project.details.name }}</h1>
<h2>Entries</h2>
<ul ng-repeat=" e in project.entries ">
<li>
{{ e.title }}
</li>
<li>
{{ e.summary }}
</li>
</ul>
</div>
Angular Controller、データは返された JSON に置き換えられました。
@ProjectCtrl = ["$scope", "$http", ($scope, $http) ->
$http.get().success (data) ->
$scope.project = {"details":{"name":"Project1","author":"brian"},"updated_at":"2013-04-13T16:48:46.406Z","entries":[{"title":"Test Title","summary":"Summary Test"},{"title":"The Third Entry","summary":"Summary of Third Entry"}]}
]
これは、以前は機能していたが、ERB を ng-repeat に置き換えた後に失敗したテストの例です。
scenario "Displays Entries Summary" do
project = Project.create!(details: {name: "aproject"})
Entry.create!(data: {summary: "Should Be Displayed"}, project_id: project.id)
Entry.create!(data: {summary: "Should Not Be Displayed"})
visit project_path(project.id)
page.must_have_content "Should Be Displayed"
page.wont_have_content "Should Not Be Displayed"
end
何か不足していますか、それとも機能テストの方法を変更する必要がありますか?