Commit b0f1226f5eada65c85d5d0b22d5b2511ebd445ac
1 parent
1e377544
Exists in
master
and in
5 other branches
Add functional tests to people custom search
(institution_fields) Signed-off-by: Gustavo Jaruga <darksshades@gmail.com> Signed-off-by: Luciano Prestes Cavalcanti <lucianopcbr@gmail.com>
Showing
3 changed files
with
119 additions
and
15 deletions
Show diff stats
lib/mpog_software_plugin.rb
| ... | ... | @@ -144,11 +144,11 @@ class MpogSoftwarePlugin < Noosfero::Plugin |
| 144 | 144 | communities << s.community |
| 145 | 145 | end |
| 146 | 146 | results = communities |
| 147 | - results = results.paginate(:per_page => 24, :page => params[:page]) | |
| 148 | - @searches[@asset] = {:results => results} | |
| 149 | - @search = results | |
| 147 | + results = results.paginate(:per_page => 24, :page => params[:page]) | |
| 148 | + @searches[@asset] = {:results => results} | |
| 149 | + @search = results | |
| 150 | 150 | |
| 151 | - render :action => :communities | |
| 151 | + render :action => :communities | |
| 152 | 152 | end |
| 153 | 153 | end |
| 154 | 154 | ... | ... |
lib/software_info.rb
| ... | ... | @@ -29,57 +29,57 @@ class SoftwareInfo < ActiveRecord::Base |
| 29 | 29 | like_sql = "" |
| 30 | 30 | values = [] |
| 31 | 31 | |
| 32 | - unless name.nil? and name.blank? | |
| 32 | + unless name.blank? | |
| 33 | 33 | like_sql << "name ILIKE ? AND " |
| 34 | 34 | values << "%#{name}%" |
| 35 | 35 | end |
| 36 | 36 | |
| 37 | - if (not database_description_id.nil?) and (not database_description_id.blank?) | |
| 37 | + unless database_description_id.blank? | |
| 38 | 38 | like_sql << "software_databases.database_description_id = ? AND " |
| 39 | 39 | values << "#{database_description_id}" |
| 40 | 40 | end |
| 41 | 41 | |
| 42 | - if (not programming_language_id.nil?) and (not programming_language_id.blank?) | |
| 42 | + unless programming_language_id.blank? | |
| 43 | 43 | like_sql << "software_languages.programming_language_id = ? AND " |
| 44 | 44 | values << "#{programming_language_id}" |
| 45 | 45 | end |
| 46 | 46 | |
| 47 | - if (not operating_system_name_id.nil?) and (not operating_system_name_id.blank?) | |
| 47 | + unless operating_system_name_id.blank? | |
| 48 | 48 | like_sql << "operating_systems.operating_system_name_id = ? AND " |
| 49 | 49 | values << "#{operating_system_name_id}" |
| 50 | 50 | end |
| 51 | 51 | |
| 52 | - if (not license_info_id.nil?) and (not license_info_id.blank?) | |
| 52 | + unless license_info_id.blank? | |
| 53 | 53 | like_sql << "license_info_id = ? AND " |
| 54 | 54 | values << "#{license_info_id}" |
| 55 | 55 | end |
| 56 | 56 | |
| 57 | - if (not internacionalizable.nil?) and (not internacionalizable.blank?) | |
| 57 | + unless internacionalizable.blank? | |
| 58 | 58 | like_sql << "internacionalizable = ? AND " |
| 59 | 59 | values << "#{internacionalizable}" |
| 60 | 60 | end |
| 61 | 61 | |
| 62 | - if (not icp_brasil.nil?) and (not icp_brasil.blank?) | |
| 62 | + unless icp_brasil.blank? | |
| 63 | 63 | like_sql << "icp_brasil = ? AND " |
| 64 | 64 | values << "#{icp_brasil}" |
| 65 | 65 | end |
| 66 | 66 | |
| 67 | - if (not e_ping.nil?) and (not e_ping.blank?) | |
| 67 | + unless e_ping.blank? | |
| 68 | 68 | like_sql << "e_ping = ? AND " |
| 69 | 69 | values << "#{e_ping}" |
| 70 | 70 | end |
| 71 | 71 | |
| 72 | - if (not e_mag.nil?) and (not e_mag.blank?) | |
| 72 | + unless e_mag.blank? | |
| 73 | 73 | like_sql << "e_mag = ? AND " |
| 74 | 74 | values << "#{e_mag}" |
| 75 | 75 | end |
| 76 | 76 | |
| 77 | - if (not e_arq.nil?) and (not e_arq.blank?) | |
| 77 | + unless e_arq.blank? | |
| 78 | 78 | like_sql << "e_arq = ? AND " |
| 79 | 79 | values << "#{e_arq}" |
| 80 | 80 | end |
| 81 | 81 | |
| 82 | - if (not controlled_vocabulary.nil?) and (not controlled_vocabulary.blank?) | |
| 82 | + unless controlled_vocabulary.blank? | |
| 83 | 83 | controlled_vocabulary = controlled_vocabulary.gsub(' ', '').underscore |
| 84 | 84 | like_sql << "controlled_vocabulary.#{controlled_vocabulary} = ? AND " |
| 85 | 85 | values << "true" | ... | ... |
| ... | ... | @@ -0,0 +1,104 @@ |
| 1 | +require File.dirname(__FILE__) + '/../../../../test/test_helper' | |
| 2 | +require File.dirname(__FILE__) + '/../../../../app/controllers/public/search_controller' | |
| 3 | + | |
| 4 | +class SearchController; def rescue_action(e) raise e end; end | |
| 5 | + | |
| 6 | +class SearchControllerTest < ActionController::TestCase | |
| 7 | + | |
| 8 | + def setup | |
| 9 | + environment = Environment.default | |
| 10 | + environment.enabled_plugins = ['MpogSoftwarePlugin'] | |
| 11 | + environment.save | |
| 12 | + | |
| 13 | + @controller = SearchController.new | |
| 14 | + @request = ActionController::TestRequest.new | |
| 15 | + @request.stubs(:ssl?).returns(:false) | |
| 16 | + @response = ActionController::TestResponse.new | |
| 17 | + | |
| 18 | + LicenseInfo.create(:version=>"GPL-2", :link =>"www.gpl2.com") | |
| 19 | + ProgrammingLanguage.create(:name=>"C++") | |
| 20 | + DatabaseDescription.create(:name => "Oracle") | |
| 21 | + OperatingSystemName.create(:name=>"Debian") | |
| 22 | + | |
| 23 | + operating_system = OperatingSystem.new(version: '1.0') | |
| 24 | + operating_system.operating_system_name = OperatingSystemName.last | |
| 25 | + operating_system.save! | |
| 26 | + | |
| 27 | + software_language = SoftwareLanguage.new(version: "1.0", operating_system: "windows") | |
| 28 | + software_language.programming_language = ProgrammingLanguage.last | |
| 29 | + software_language.save! | |
| 30 | + | |
| 31 | + software_database = SoftwareDatabase.new(version: "1.0", operating_system: "windows") | |
| 32 | + software_database.database_description = DatabaseDescription.last | |
| 33 | + software_database.save! | |
| 34 | + end | |
| 35 | + | |
| 36 | + should "search for people by name" do | |
| 37 | + p1 = create_user("user_1", "DF", "Gama", "user_1@user.com").person | |
| 38 | + | |
| 39 | + get :people, :query => "user_1" | |
| 40 | + | |
| 41 | + assert_includes assigns(:searches)[:people][:results], p1 | |
| 42 | + end | |
| 43 | + | |
| 44 | + should "search for people by state" do | |
| 45 | + p1 = create_user("user_1", "DF", "Gama", "user_1@user.com").person | |
| 46 | + | |
| 47 | + get :people, :state => "DF" | |
| 48 | + | |
| 49 | + assert_includes assigns(:searches)[:people][:results], p1 | |
| 50 | + end | |
| 51 | + | |
| 52 | + should "search for people by city" do | |
| 53 | + p1 = create_user("user_1", "DF", "Gama", "user_1@user.com").person | |
| 54 | + | |
| 55 | + get :people, :city => "Gama" | |
| 56 | + | |
| 57 | + assert_includes assigns(:searches)[:people][:results], p1 | |
| 58 | + end | |
| 59 | + | |
| 60 | + should "search for people by email" do | |
| 61 | + p1 = create_user("user_1", "DF", "Gama", "user_1@user.com").person | |
| 62 | + | |
| 63 | + get :people, :email => "user_1@user.com" | |
| 64 | + | |
| 65 | + assert_includes assigns(:searches)[:people][:results], p1 | |
| 66 | + end | |
| 67 | + | |
| 68 | + | |
| 69 | + # should "search for software by name" do | |
| 70 | + # software = create_software("software") | |
| 71 | + | |
| 72 | + # get :communities, :type => "Software", :query => "", :name => "software", :database_description => {:id => ""}, :programming_language => {:id=>""}, :operating_system => {:id => ""}, :controlled_vocabulary => "", :license_info => {:id => ""}, :e_ping => "", :e_mag => "", :icp_brasil => "", :e_arq => "", :internacionalizable => "" | |
| 73 | + | |
| 74 | + # assert_includes assigns(:searches)[:communities][:results], software.community | |
| 75 | + # end | |
| 76 | + | |
| 77 | + protected | |
| 78 | + | |
| 79 | + def create_user name, state, city, email | |
| 80 | + user = fast_create(User) | |
| 81 | + user.person = fast_create(Person) | |
| 82 | + user.person.state = state | |
| 83 | + user.person.city = city | |
| 84 | + user.person.email = email | |
| 85 | + user.save! | |
| 86 | + user.person.save! | |
| 87 | + user | |
| 88 | + end | |
| 89 | + | |
| 90 | + def create_software name | |
| 91 | + community = Community.create(:name => name) | |
| 92 | + software_info = SoftwareInfo::new(:acronym=>"SFT", :operating_platform=>"windows") | |
| 93 | + software_info.community = community | |
| 94 | + software_info.software_languages << SoftwareLanguage.last | |
| 95 | + software_info.software_databases << SoftwareDatabase.last | |
| 96 | + software_info.operating_systems << OperatingSystem.last | |
| 97 | + software_info.save! | |
| 98 | + | |
| 99 | + community.save! | |
| 100 | + | |
| 101 | + software_info | |
| 102 | + end | |
| 103 | + | |
| 104 | +end | ... | ... |