Commit c489251bf4383c07e9e2f8db313108406435048c

Authored by Luciano Prestes
Committed by Thiago Ribeiro
1 parent 5ffa5a41

Search software_infos find only softwares with visible community

lib/ext/search_controller.rb
@@ -61,6 +61,7 @@ class SearchController @@ -61,6 +61,7 @@ class SearchController
61 61
62 def get_filtered_software_list 62 def get_filtered_software_list
63 params[:query] ||= "" 63 params[:query] ||= ""
  64 + visible_communities = visible_profiles(Community)
64 65
65 filtered_software_list = SoftwareInfo.search_by_query(params[:query]) 66 filtered_software_list = SoftwareInfo.search_by_query(params[:query])
66 67
@@ -70,6 +71,7 @@ class SearchController @@ -70,6 +71,7 @@ class SearchController
70 @public_software_selected = false 71 @public_software_selected = false
71 end 72 end
72 73
  74 + filtered_software_list.select!{ |software| visible_communities.include?(software.community) }
73 category_ids = get_filter_category_ids 75 category_ids = get_filter_category_ids
74 76
75 unless category_ids.empty? 77 unless category_ids.empty?
test/functional/search_controller_test.rb
@@ -214,6 +214,7 @@ class SearchControllerTest < ActionController::TestCase @@ -214,6 +214,7 @@ class SearchControllerTest < ActionController::TestCase
214 assert_not_includes assigns(:searches)[:software_infos][:results], software_one.community 214 assert_not_includes assigns(:searches)[:software_infos][:results], software_one.community
215 end 215 end
216 216
  217 +<<<<<<< 5ffa5a412be43c8ca9d1a07ed84a55503bb1a3fd
217 should "software_infos search return only enabled softwares" do 218 should "software_infos search return only enabled softwares" do
218 s1 = SoftwareInfo.first 219 s1 = SoftwareInfo.first
219 s2 = SoftwareInfo.last 220 s2 = SoftwareInfo.last
@@ -239,6 +240,23 @@ class SearchControllerTest &lt; ActionController::TestCase @@ -239,6 +240,23 @@ class SearchControllerTest &lt; ActionController::TestCase
239 assert_not_includes assigns(:searches)[:software_infos][:results], s2.community 240 assert_not_includes assigns(:searches)[:software_infos][:results], s2.community
240 end 241 end
241 242
  243 + should "software_infos search not return software with secret community" do
  244 + software_one = create_software_info("Software ABC", :acronym => "SFO", :finality => "Help")
  245 + software_two = create_software_info("Python", :acronym => "SFT", :finality => "Task")
  246 + software_three = create_software_info("Software DEF", :acronym => "SFW", :finality => "Java")
  247 +
  248 + software_one.community.secret = true
  249 + software_one.community.save!
  250 +
  251 + get(
  252 + :software_infos,
  253 + )
  254 +
  255 + assert_includes assigns(:searches)[:software_infos][:results], software_two.community
  256 + assert_includes assigns(:searches)[:software_infos][:results], software_three.community
  257 + assert_not_includes assigns(:searches)[:software_infos][:results], software_one.community
  258 + end
  259 +
242 private 260 private
243 261
244 def create_software_categories 262 def create_software_categories