moves search by author name to full text searches

This commit is contained in:
rgarcia
2016-01-16 22:10:17 +01:00
parent 44769d96f4
commit 82f9a656ad
7 changed files with 24 additions and 69 deletions

View File

@@ -2,7 +2,6 @@ module Filterable
extend ActiveSupport::Concern extend ActiveSupport::Concern
included do included do
scope :by_author, -> (username) { where(users: { username: username }).joins(:author) }
scope :by_official_level, -> (official_level) { where(users: { official_level: official_level }).joins(:author) } scope :by_official_level, -> (official_level) { where(users: { official_level: official_level }).joins(:author) }
scope :by_date_range, -> (date_range) { where(created_at: date_range) } scope :by_date_range, -> (date_range) { where(created_at: date_range) }
end end
@@ -21,7 +20,7 @@ module Filterable
def allowed_filter?(filter, value) def allowed_filter?(filter, value)
return if value.blank? return if value.blank?
['author', 'official_level', 'date_range'].include?(filter) ['official_level', 'date_range'].include?(filter)
end end
end end

View File

@@ -68,6 +68,7 @@ class Proposal < ActiveRecord::Base
description => 'D' description => 'D'
} }
tag_list.each{ |tag| values[tag] = 'D' } tag_list.each{ |tag| values[tag] = 'D' }
values[author.username] = 'D'
values values
end end

View File

@@ -13,12 +13,6 @@
placeholder: t("shared.advanced_search.general_placeholder") %> placeholder: t("shared.advanced_search.general_placeholder") %>
</div> </div>
<div class="small-12 medium-6 advanced-search columns">
<h5 class='search-option inline-block'><%= t("shared.advanced_search.author") %></h5>
<%= text_field_tag "advanced_search[author]", params[:advanced_search].try(:[], :author),
placeholder: t("shared.advanced_search.author_placeholder") %>
</div>
<div class="small-12 medium-6 advanced-search columns"> <div class="small-12 medium-6 advanced-search columns">
<h5 class='search-option'><%= t("shared.advanced_search.author_type") %></h5> <h5 class='search-option'><%= t("shared.advanced_search.author_type") %></h5>
<%= select_tag('advanced_search[official_level]', official_level_search_options, <%= select_tag('advanced_search[official_level]', official_level_search_options,

View File

@@ -512,29 +512,6 @@ feature 'Debates' do
end end
end end
scenario "Search by author", :js do
ana = create :user, username: "Ana06"
john = create :user, username: "John Smith"
debate1 = create(:debate, author: ana)
debate2 = create(:debate, author: ana)
debate3 = create(:debate, author: john)
visit debates_path
click_link "Advanced search"
fill_in "Write the author name", with: "Ana06"
click_button "Filter"
within("#debates") do
expect(page).to have_css('.debate', count: 2)
expect(page).to have_content(debate1.title)
expect(page).to have_content(debate2.title)
expect(page).to_not have_content(debate3.title)
end
end
context "Search by author type" do context "Search by author type" do
scenario "Public employee", :js do scenario "Public employee", :js do
@@ -763,18 +740,17 @@ feature 'Debates' do
end end
scenario "Search by multiple filters", :js do scenario "Search by multiple filters", :js do
ana = create :user, username: "Ana06", official_level: 1 ana = create :user, official_level: 1
john = create :user, username: "John", official_level: 1 john = create :user, official_level: 1
debate1 = create(:debate, title: "Get Schwifty", author: ana, created_at: 1.minute.ago) debate1 = create(:debate, title: "Get Schwifty", author: ana, created_at: 1.minute.ago)
debate2 = create(:debate, title: "Hello Schwifty", author: john, created_at: 1.minute.ago) debate2 = create(:debate, title: "Hello Schwifty", author: john, created_at: 2.days.ago)
debate3 = create(:debate, title: "Save the forest") debate3 = create(:debate, title: "Save the forest")
visit debates_path visit debates_path
click_link "Advanced search" click_link "Advanced search"
fill_in "Write the text", with: "Schwifty" fill_in "Write the text", with: "Schwifty"
fill_in "Write the author name", with: "Ana06"
select "Public employee", from: "advanced_search_official_level" select "Public employee", from: "advanced_search_official_level"
select "Last 24 hours", from: "js-advanced-search-date-min" select "Last 24 hours", from: "js-advanced-search-date-min"
@@ -791,7 +767,6 @@ feature 'Debates' do
click_link "Advanced search" click_link "Advanced search"
fill_in "Write the text", with: "Schwifty" fill_in "Write the text", with: "Schwifty"
fill_in "Write the author name", with: "Ana06"
select "Public employee", from: "advanced_search_official_level" select "Public employee", from: "advanced_search_official_level"
select "Last 24 hours", from: "js-advanced-search-date-min" select "Last 24 hours", from: "js-advanced-search-date-min"
@@ -799,7 +774,6 @@ feature 'Debates' do
within "#js-advanced-search" do within "#js-advanced-search" do
expect(page).to have_selector("input[name='search'][value='Schwifty']") expect(page).to have_selector("input[name='search'][value='Schwifty']")
expect(page).to have_selector("input[name='advanced_search[author]'][value='Ana06']")
expect(page).to have_select('advanced_search[official_level]', selected: 'Public employee') expect(page).to have_select('advanced_search[official_level]', selected: 'Public employee')
expect(page).to have_select('advanced_search[date_min]', selected: 'Last 24 hours') expect(page).to have_select('advanced_search[date_min]', selected: 'Last 24 hours')
end end

View File

@@ -575,29 +575,6 @@ feature 'Proposals' do
end end
end end
scenario "Search by author", :js do
ana = create :user, username: "Ana06"
john = create :user, username: "John Smith"
proposal1 = create(:proposal, author: ana)
proposal2 = create(:proposal, author: ana)
proposal3 = create(:proposal, author: john)
visit proposals_path
click_link "Advanced search"
fill_in "Write the author name", with: "Ana06"
click_button "Filter"
within("#proposals") do
expect(page).to have_css('.proposal', count: 2)
expect(page).to have_content(proposal1.title)
expect(page).to have_content(proposal2.title)
expect(page).to_not have_content(proposal3.title)
end
end
context "Search by author type" do context "Search by author type" do
scenario "Public employee", :js do scenario "Public employee", :js do
@@ -826,18 +803,17 @@ feature 'Proposals' do
end end
scenario "Search by multiple filters", :js do scenario "Search by multiple filters", :js do
ana = create :user, username: "Ana06", official_level: 1 ana = create :user, official_level: 1
john = create :user, username: "John", official_level: 1 john = create :user, official_level: 1
proposal1 = create(:proposal, title: "Get Schwifty", author: ana, created_at: 1.minute.ago) proposal1 = create(:proposal, title: "Get Schwifty", author: ana, created_at: 1.minute.ago)
proposal2 = create(:proposal, title: "Hello Schwifty", author: john, created_at: 1.minute.ago) proposal2 = create(:proposal, title: "Hello Schwifty", author: john, created_at: 2.days.ago)
proposal3 = create(:proposal, title: "Save the forest") proposal3 = create(:proposal, title: "Save the forest")
visit proposals_path visit proposals_path
click_link "Advanced search" click_link "Advanced search"
fill_in "Write the text", with: "Schwifty" fill_in "Write the text", with: "Schwifty"
fill_in "Write the author name", with: "Ana06"
select "Public employee", from: "advanced_search_official_level" select "Public employee", from: "advanced_search_official_level"
select "Last 24 hours", from: "js-advanced-search-date-min" select "Last 24 hours", from: "js-advanced-search-date-min"
@@ -845,7 +821,6 @@ feature 'Proposals' do
within("#proposals") do within("#proposals") do
expect(page).to have_css('.proposal', count: 1) expect(page).to have_css('.proposal', count: 1)
expect(page).to have_content(proposal1.title) expect(page).to have_content(proposal1.title)
end end
end end
@@ -855,7 +830,6 @@ feature 'Proposals' do
click_link "Advanced search" click_link "Advanced search"
fill_in "Write the text", with: "Schwifty" fill_in "Write the text", with: "Schwifty"
fill_in "Write the author name", with: "Ana06"
select "Public employee", from: "advanced_search_official_level" select "Public employee", from: "advanced_search_official_level"
select "Last 24 hours", from: "js-advanced-search-date-min" select "Last 24 hours", from: "js-advanced-search-date-min"
@@ -863,7 +837,6 @@ feature 'Proposals' do
within "#js-advanced-search" do within "#js-advanced-search" do
expect(page).to have_selector("input[name='search'][value='Schwifty']") expect(page).to have_selector("input[name='search'][value='Schwifty']")
expect(page).to have_selector("input[name='advanced_search[author]'][value='Ana06']")
expect(page).to have_select('advanced_search[official_level]', selected: 'Public employee') expect(page).to have_select('advanced_search[official_level]', selected: 'Public employee')
expect(page).to have_select('advanced_search[date_min]', selected: 'Last 24 hours') expect(page).to have_select('advanced_search[date_min]', selected: 'Last 24 hours')
end end

View File

@@ -444,6 +444,13 @@ describe Debate do
expect(results).to eq([debate]) expect(results).to eq([debate])
end end
xit "searches by author name" do
author = create(:user, username: 'Danny Trejo')
debate = create(:debate, author: author)
results = Debate.search('Danny')
expect(results).to eq([debate])
end
end end
context "stemming" do context "stemming" do

View File

@@ -394,6 +394,13 @@ describe Proposal do
expect(results).to eq([proposal]) expect(results).to eq([proposal])
end end
it "searches by author name" do
author = create(:user, username: 'Danny Trejo')
proposal = create(:proposal, author: author)
results = Proposal.search('Danny')
expect(results).to eq([proposal])
end
end end
context "stemming" do context "stemming" do