私は検索ボックスをテストする方法を理解しようとしています。 in rspec \ capybara私は2つのジョブを作成して、検索ボックスがあるページにアクセスし、検索語を入力してから、検索ボタンをクリックします。私は1つの仕事だけを見ることを期待していますが、両方の仕事は返されています。私は、テスト入力が無視されていると推測しています。rails rspecとcapybaraは検索ボックスの入力をテストします
特徴スペック
it "narrows results for a job using the search box" do
job1 = Job.create!(job_attributes(title: "Windows admin"))
job2 = Job.create!(job_attributes(title: "Linux administrator"))
visit jobs_path
fill_in :search, with: "Windows"
click_button 'Search'
expect(page).to have_text(job1.title)
expect(page).not_to have_text(job2.title)
end
検索フォームビューで。
<%= form_tag(filtered_jobs_path, :method => "get", id: "search", layout: :inline) do %>
<%= text_field_tag :search, params[:search], placeholder: "Search jobs", class: "form-control" %>
<div class="col-sm-12 col-xs-8">
<%= submit_tag "Search", :name => nil, :class => "btn btn-primary btn-outline btn-block" %>
<% end %>
</div>
私のコントローラのindexアクション:生成
def index
@jobs = Job.all
# Search query for job title and description
if params[:search].present?
@jobs = @jobs.by_job_title_and_description(params[:search])
end
end
HTML:
<div class="jobs_index">
<!-- search header -->
<div class="row bg-color">
<div class="col-md-10 col-md-offset-1 col-xs-10 col-xs-offset-1">
<fieldset class="row">
<div class="col-xs-12">
<div class="form-group">
</div>
</div>
<div class="col-md-6 col-md-offset-2 col-sm-5">
<div class="form-group">
<div class="input-group">
<div class="input-group-addon"><label for="search-field-keyword" class="">
<i class="fa fa-search fa-lg" aria-hidden="true"></i></label>
</div>
<form id="search" layout="inline" action="/jobs" accept-charset="UTF-8" method="get"><input name="utf8" type="hidden" value="✓" />
<input type="text" name="search" id="search" value="ruby" placeholder="Search jobs" class="form-control" />
<!-- if a filter is already set submit it again with search query to keep it persisted -->
</div>
</div>
</div>
<div class="col-md-2 col-sm-3">
<div class="row">
<div class="col-sm-12 col-xs-8">
<input type="submit" value="Search" class="btn btn-primary btn-outline btn-block" data-disable-with="Search" />
</form>
</div>
</div>
</div>
</fieldset>
</div><!-- /.col-md-10 -->
</div><!-- /.row -->
あなたがtest.logをチェックして、検索パラメータが実際にサブミットされているかどうかを確認してください。 –
Thomasさんに感謝してtest.logを確認しましたが、検索パラメータが渡されていないと思われます。 jobs/index.html.erbがレンダリングされます。しかし、実際にその検索入力を提出する方法がわからない – Scott
- あなたはフォームを十分に表示していません(ボタンなどを表示しないでください)。テンプレートではなくHTMLが生成されます。また、 'fill_in 'searchを試してみるとよいでしょう:" Windows "' - ロケータは文字列ではなくシンボルであると仮定します –