Mercurial > hg > soundsoftware-site
diff test/functional/search_controller_test.rb @ 524:1248a47e81b3 feature_36
Merge from branch "luisf"
author | luisf <luis.figueira@eecs.qmul.ac.uk> |
---|---|
date | Mon, 25 Jul 2011 14:39:38 +0100 |
parents | 0c939c159af4 |
children | cbb26bc654de |
line wrap: on
line diff
--- a/test/functional/search_controller_test.rb Fri Jul 15 17:21:05 2011 +0100 +++ b/test/functional/search_controller_test.rb Mon Jul 25 14:39:38 2011 +0100 @@ -1,4 +1,4 @@ -require File.dirname(__FILE__) + '/../test_helper' +require File.expand_path('../../test_helper', __FILE__) require 'search_controller' # Re-raise errors caught by the controller. @@ -9,14 +9,14 @@ :issues, :trackers, :issue_statuses, :custom_fields, :custom_values, :repositories, :changesets - + def setup @controller = SearchController.new @request = ActionController::TestRequest.new @response = ActionController::TestResponse.new User.current = nil end - + def test_search_for_projects get :index assert_response :success @@ -27,37 +27,39 @@ assert_template 'index' assert assigns(:results).include?(Project.find(1)) end - + def test_search_all_projects - get :index, :q => 'recipe subproject commit', :submit => 'Search' + get :index, :q => 'recipe subproject commit', :all_words => '' assert_response :success assert_template 'index' - + assert assigns(:results).include?(Issue.find(2)) assert assigns(:results).include?(Issue.find(5)) assert assigns(:results).include?(Changeset.find(101)) assert_tag :dt, :attributes => { :class => /issue/ }, :child => { :tag => 'a', :content => /Add ingredients categories/ }, :sibling => { :tag => 'dd', :content => /should be classified by categories/ } - + assert assigns(:results_by_type).is_a?(Hash) assert_equal 5, assigns(:results_by_type)['changesets'] assert_tag :a, :content => 'Changesets (5)' end - + def test_search_issues get :index, :q => 'issue', :issues => 1 assert_response :success assert_template 'index' - + + assert_equal true, assigns(:all_words) + assert_equal false, assigns(:titles_only) assert assigns(:results).include?(Issue.find(8)) assert assigns(:results).include?(Issue.find(5)) assert_tag :dt, :attributes => { :class => /issue closed/ }, :child => { :tag => 'a', :content => /Closed/ } end - + def test_search_project_and_subprojects - get :index, :id => 1, :q => 'recipe subproject', :scope => 'subprojects', :submit => 'Search' + get :index, :id => 1, :q => 'recipe subproject', :scope => 'subprojects', :all_words => '' assert_response :success assert_template 'index' assert assigns(:results).include?(Issue.find(1)) @@ -66,37 +68,39 @@ def test_search_without_searchable_custom_fields CustomField.update_all "searchable = #{ActiveRecord::Base.connection.quoted_false}" - + get :index, :id => 1 assert_response :success assert_template 'index' assert_not_nil assigns(:project) - + get :index, :id => 1, :q => "can" assert_response :success assert_template 'index' end - + def test_search_with_searchable_custom_fields get :index, :id => 1, :q => "stringforcustomfield" assert_response :success results = assigns(:results) assert_not_nil results assert_equal 1, results.size - assert results.include?(Issue.find(3)) + assert results.include?(Issue.find(7)) end - + def test_search_all_words # 'all words' is on by default - get :index, :id => 1, :q => 'recipe updating saving' + get :index, :id => 1, :q => 'recipe updating saving', :all_words => '1' + assert_equal true, assigns(:all_words) results = assigns(:results) assert_not_nil results assert_equal 1, results.size assert results.include?(Issue.find(3)) end - + def test_search_one_of_the_words - get :index, :id => 1, :q => 'recipe updating saving', :submit => 'Search' + get :index, :id => 1, :q => 'recipe updating saving', :all_words => '' + assert_equal false, assigns(:all_words) results = assigns(:results) assert_not_nil results assert_equal 3, results.size @@ -104,19 +108,30 @@ end def test_search_titles_only_without_result - get :index, :id => 1, :q => 'recipe updating saving', :all_words => '1', :titles_only => '1', :submit => 'Search' + get :index, :id => 1, :q => 'recipe updating saving', :titles_only => '1' results = assigns(:results) assert_not_nil results assert_equal 0, results.size end def test_search_titles_only - get :index, :id => 1, :q => 'recipe', :titles_only => '1', :submit => 'Search' + get :index, :id => 1, :q => 'recipe', :titles_only => '1' + assert_equal true, assigns(:titles_only) results = assigns(:results) assert_not_nil results assert_equal 2, results.size end - + + def test_search_content + Issue.update_all("description = 'This is a searchkeywordinthecontent'", "id=1") + + get :index, :id => 1, :q => 'searchkeywordinthecontent', :titles_only => '' + assert_equal false, assigns(:titles_only) + results = assigns(:results) + assert_not_nil results + assert_equal 1, results.size + end + def test_search_with_invalid_project_id get :index, :id => 195, :q => 'recipe' assert_response 404 @@ -127,7 +142,7 @@ # issue of a public project get :index, :q => "3" assert_redirected_to '/issues/3' - + # issue of a private project get :index, :q => "4" assert_response :success @@ -139,7 +154,7 @@ assert_response :success assert_template 'index' end - + def test_tokens_with_quotes get :index, :id => 1, :q => '"good bye" hello "bye bye"' assert_equal ["good bye", "hello", "bye bye"], assigns(:tokens)