diff options
| -rw-r--r-- | app/controllers/public_body_controller.rb | 13 | ||||
| -rw-r--r-- | app/controllers/request_controller.rb | 13 | ||||
| -rw-r--r-- | app/views/public_body/_search_ahead.rhtml | 2 | ||||
| -rw-r--r-- | app/views/request/_search_ahead.rhtml | 2 | ||||
| -rw-r--r-- | spec/controllers/public_body_controller_spec.rb | 9 | ||||
| -rw-r--r-- | spec/controllers/request_controller_spec.rb | 9 | 
6 files changed, 28 insertions, 20 deletions
| diff --git a/app/controllers/public_body_controller.rb b/app/controllers/public_body_controller.rb index ff9fbadb3..62229a441 100644 --- a/app/controllers/public_body_controller.rb +++ b/app/controllers/public_body_controller.rb @@ -185,11 +185,14 @@ class PublicBodyController < ApplicationController      def search_typeahead          # Since acts_as_xapian doesn't support the Partial match flag, we work around it          # by making the last work a wildcard, which is quite the same -        query = params[:q] + '*' - -        query = query.split(' ').join(' OR ')       # XXX: HACK for OR instead of default AND! -        @xapian_requests = perform_search([PublicBody], query, 'relevant', nil, 5) - +        query = params[:q] +        query = query.split(' ') +        if query.last.nil? || query.last.strip.length < 3 +            @xapian_requests = nil +        else +            query = query.join(' OR ')       # XXX: HACK for OR instead of default AND! +            @xapian_requests = perform_search([PublicBody], query, 'relevant', nil, 5) +        end          render :partial => "public_body/search_ahead"      end  end diff --git a/app/controllers/request_controller.rb b/app/controllers/request_controller.rb index 1801648ca..d91df3780 100644 --- a/app/controllers/request_controller.rb +++ b/app/controllers/request_controller.rb @@ -754,11 +754,14 @@ class RequestController < ApplicationController      def search_typeahead          # Since acts_as_xapian doesn't support the Partial match flag, we work around it          # by making the last work a wildcard, which is quite the same -        query = params[:q] + '*' - -        query = query.split(' ').join(' OR ')       # XXX: HACK for OR instead of default AND! -        @xapian_requests = perform_search([InfoRequestEvent], query, 'relevant', 'request_collapse', 5) - +        query = params[:q] +        query = query.split(' ') +        if query.last.nil? || query.last.strip.length < 3 +            @xapian_requests = nil +        else +            query = query.join(' OR ')       # XXX: HACK for OR instead of default AND! +            @xapian_requests = perform_search([InfoRequestEvent], query, 'relevant', 'request_collapse', 5) +        end          render :partial => "request/search_ahead.rhtml"      end diff --git a/app/views/public_body/_search_ahead.rhtml b/app/views/public_body/_search_ahead.rhtml index 19c7eb4e8..436471544 100644 --- a/app/views/public_body/_search_ahead.rhtml +++ b/app/views/public_body/_search_ahead.rhtml @@ -1,4 +1,5 @@  <p> + <% if !@xapian_requests.nil? %>    <% if @xapian_requests.results.size > 0 %>      <h3><%= _('Top search results:') %></h3>      <p> @@ -12,6 +13,7 @@        <%= render :partial => 'body_listing_single', :locals => { :public_body => result[:model] } %>      <% end %>    </div> + <% end %>  </p> diff --git a/app/views/request/_search_ahead.rhtml b/app/views/request/_search_ahead.rhtml index 9c49680c3..d0b19de7d 100644 --- a/app/views/request/_search_ahead.rhtml +++ b/app/views/request/_search_ahead.rhtml @@ -1,4 +1,5 @@  <div id="request_search_ahead_results"> +  <% if !@xapian_requests.nil? %>      <% if @xapian_requests.results.size > 0 %>        <h3><%= _("Possibly related requests:") %></h3>       <% end %> @@ -9,4 +10,5 @@      <p>          <a id="body-site-search-link" target="_blank"><%= _("Or search in their website for this information.") %></a>      </p> +  <% end %>  </div> diff --git a/spec/controllers/public_body_controller_spec.rb b/spec/controllers/public_body_controller_spec.rb index d47ea7b8d..8182e1331 100644 --- a/spec/controllers/public_body_controller_spec.rb +++ b/spec/controllers/public_body_controller_spec.rb @@ -177,7 +177,7 @@ describe PublicBodyController, "when doing type ahead searches" do      it "should return nothing for the empty query string" do          get :search_typeahead, :q => ""          response.should render_template('public_body/_search_ahead') -        assigns[:xapian_requests].results.size.should == 0 +        assigns[:xapian_requests].should be_nil      end      it "should return a body matching the given keyword, but not users with a matching description" do @@ -202,10 +202,9 @@ describe PublicBodyController, "when doing type ahead searches" do          assigns[:xapian_requests].results[0][:model].name.should == public_bodies(:humpadink_public_body).name      end -    it "should return partial matches" do -        get :search_typeahead, :q => "geral"  # 'geral' for 'Geraldine' +    it "should not return  matches for short words" do +        get :search_typeahead, :q => "b"           response.should render_template('public_body/_search_ahead') -        assigns[:xapian_requests].results.size.should == 1 -        assigns[:xapian_requests].results[0][:model].name.should == public_bodies(:geraldine_public_body).name +        assigns[:xapian_requests].should be_nil      end  end diff --git a/spec/controllers/request_controller_spec.rb b/spec/controllers/request_controller_spec.rb index 3420d212e..054654611 100644 --- a/spec/controllers/request_controller_spec.rb +++ b/spec/controllers/request_controller_spec.rb @@ -1398,7 +1398,7 @@ describe RequestController, "when doing type ahead searches" do      it "should return nothing for the empty query string" do          get :search_typeahead, :q => ""          response.should render_template('request/_search_ahead.rhtml') -        assigns[:xapian_requests].results.size.should == 0 +        assigns[:xapian_requests].should be_nil      end      it "should return a request matching the given keyword, but not users with a matching description" do @@ -1416,11 +1416,10 @@ describe RequestController, "when doing type ahead searches" do          assigns[:xapian_requests].results[1][:model].title.should == info_requests(:naughty_chicken_request).title      end -    it "should return partial matches" do -        get :search_typeahead, :q => "chick"  # 'chick' for 'chicken' +    it "should not return  matches for short words" do +        get :search_typeahead, :q => "a"           response.should render_template('request/_search_ahead.rhtml') -        assigns[:xapian_requests].results.size.should == 1 -        assigns[:xapian_requests].results[0][:model].title.should == info_requests(:naughty_chicken_request).title +        assigns[:xapian_requests].should be_nil      end  end | 
