tidies up a bit and adds wild: true for tag-based debate searching
This commit is contained in:
@@ -116,8 +116,10 @@ class Debate < ActiveRecord::Base
|
||||
def self.search(terms)
|
||||
return none unless terms.present?
|
||||
|
||||
ids = where("debates.title ILIKE ? OR debates.description ILIKE ?", "%#{terms}%", "%#{terms}%").pluck(:id) | tagged_with(terms).pluck(:id)
|
||||
where(id: ids)
|
||||
debate_ids = where("debates.title ILIKE ? OR debates.description ILIKE ?",
|
||||
"%#{terms}%", "%#{terms}%").pluck(:id)
|
||||
tag_ids = tagged_with(terms, wild: true, any: true).pluck(:id)
|
||||
where(id: [debate_ids, tag_ids].flatten.compact)
|
||||
end
|
||||
|
||||
def conflictive?
|
||||
|
||||
@@ -483,16 +483,18 @@ feature 'Debates' do
|
||||
debate3 = create(:debate)
|
||||
debate4 = create(:debate, description: "Schwifty in here")
|
||||
debate5 = create(:debate, tag_list: 'schwifty')
|
||||
debate6 = create(:debate, tag_list: ['awesome foreign schwifty', 'major'])
|
||||
|
||||
visit debates_path
|
||||
fill_in "search", with: "Schwifty"
|
||||
click_button "Search"
|
||||
|
||||
within("#debates") do
|
||||
expect(page).to have_css('.debate', count: 3)
|
||||
expect(page).to have_css('.debate', count: 4)
|
||||
expect(page).to have_content(debate2.title)
|
||||
expect(page).to have_content(debate4.title)
|
||||
expect(page).to have_content(debate5.title)
|
||||
expect(page).to have_content(debate6.title)
|
||||
expect(page).to_not have_content(debate1.title)
|
||||
expect(page).to_not have_content(debate3.title)
|
||||
end
|
||||
|
||||
Reference in New Issue
Block a user