Commit 35138b91c33727e7fcbe1da4cc44db6cf90be72d
Committed by
Gabriela Navarro
1 parent
10afab41
Exists in
master
and in
5 other branches
fix_institution: Test for institution edition
Signed-off-by: Fabio Teixeira <fabio1079@gmail.com> Signed-off-by: Gabriela Navarro <navarro1703@gmail.com>
Showing
3 changed files
with
91 additions
and
56 deletions
Show diff stats
| @@ -0,0 +1,44 @@ | @@ -0,0 +1,44 @@ | ||
| 1 | +module InstitutionTestHelper | ||
| 2 | + | ||
| 3 | + def self.generate_form_fields name, country, state, city, cnpj, type | ||
| 4 | + fields = { | ||
| 5 | + :community => { | ||
| 6 | + :name => name, | ||
| 7 | + :country => country, | ||
| 8 | + :state => state, | ||
| 9 | + :city => city | ||
| 10 | + }, | ||
| 11 | + :institutions => { | ||
| 12 | + :cnpj=> cnpj, | ||
| 13 | + :type => type, | ||
| 14 | + :acronym => "", | ||
| 15 | + :governmental_power => "", | ||
| 16 | + :governmental_sphere => "", | ||
| 17 | + :juridical_nature => "", | ||
| 18 | + :corporate_name => "coporate default" | ||
| 19 | + } | ||
| 20 | + } | ||
| 21 | + fields | ||
| 22 | + end | ||
| 23 | + | ||
| 24 | + def self.create_public_institution name, acronym, country, state, city, juridical_nature, gov_p, gov_s, cnpj | ||
| 25 | + institution_community = Community::new | ||
| 26 | + institution_community.name = name | ||
| 27 | + institution_community.country = country | ||
| 28 | + institution_community.state = state | ||
| 29 | + institution_community.city = city | ||
| 30 | + institution_community.save! | ||
| 31 | + | ||
| 32 | + institution = PublicInstitution.new | ||
| 33 | + institution.community = institution_community | ||
| 34 | + institution.name = name | ||
| 35 | + institution.juridical_nature = juridical_nature | ||
| 36 | + institution.acronym = acronym | ||
| 37 | + institution.governmental_power = gov_p | ||
| 38 | + institution.governmental_sphere = gov_s | ||
| 39 | + institution.cnpj = cnpj | ||
| 40 | + institution.corporate_name = "corporate default" | ||
| 41 | + institution.save! | ||
| 42 | + institution | ||
| 43 | + end | ||
| 44 | +end | ||
| 0 | \ No newline at end of file | 45 | \ No newline at end of file |
test/functional/mpog_software_plugin_controller_test.rb
| 1 | require File.dirname(__FILE__) + '/../../../../test/test_helper' | 1 | require File.dirname(__FILE__) + '/../../../../test/test_helper' |
| 2 | +require File.dirname(__FILE__) + '/institution_test_helper' | ||
| 2 | require File.dirname(__FILE__) + '/../../controllers/mpog_software_plugin_controller' | 3 | require File.dirname(__FILE__) + '/../../controllers/mpog_software_plugin_controller' |
| 3 | 4 | ||
| 4 | class MpogSoftwarePluginController; def rescue_action(e) raise e end; end | 5 | class MpogSoftwarePluginController; def rescue_action(e) raise e end; end |
| @@ -6,12 +7,12 @@ class MpogSoftwarePluginController; def rescue_action(e) raise e end; end | @@ -6,12 +7,12 @@ class MpogSoftwarePluginController; def rescue_action(e) raise e end; end | ||
| 6 | class MpogSoftwarePluginControllerTest < ActionController::TestCase | 7 | class MpogSoftwarePluginControllerTest < ActionController::TestCase |
| 7 | 8 | ||
| 8 | def setup | 9 | def setup |
| 9 | - admin = create_user("adminuser").person | ||
| 10 | - admin.stubs(:has_permission?).returns("true") | 10 | + @admin = create_user("adminuser").person |
| 11 | + @admin.stubs(:has_permission?).returns("true") | ||
| 11 | 12 | ||
| 12 | @environment = Environment.default | 13 | @environment = Environment.default |
| 13 | @environment.enabled_plugins = ['MpogSoftwarePlugin'] | 14 | @environment.enabled_plugins = ['MpogSoftwarePlugin'] |
| 14 | - @environment.add_admin(admin) | 15 | + @environment.add_admin(@admin) |
| 15 | @environment.save | 16 | @environment.save |
| 16 | 17 | ||
| 17 | @govPower = GovernmentalPower.create(:name=>"Some Gov Power") | 18 | @govPower = GovernmentalPower.create(:name=>"Some Gov Power") |
| @@ -20,8 +21,8 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | @@ -20,8 +21,8 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | ||
| 20 | @response = ActionController::TestResponse.new | 21 | @response = ActionController::TestResponse.new |
| 21 | 22 | ||
| 22 | @institution_list = [] | 23 | @institution_list = [] |
| 23 | - @institution_list << create_public_institution("Ministerio Publico da Uniao", "MPU", "BR", "DF", "Gama", @juridical_nature, @govPower, @govSphere, "12.345.678/9012-45") | ||
| 24 | - @institution_list << create_public_institution("Tribunal Regional da Uniao", "TRU", "BR", "DF", "Brasilia", @juridical_nature, @govPower, @govSphere, "12.345.678/9012-90") | 24 | + @institution_list << InstitutionTestHelper.create_public_institution("Ministerio Publico da Uniao", "MPU", "BR", "DF", "Gama", @juridical_nature, @govPower, @govSphere, "12.345.678/9012-45") |
| 25 | + @institution_list << InstitutionTestHelper.create_public_institution("Tribunal Regional da Uniao", "TRU", "BR", "DF", "Brasilia", @juridical_nature, @govPower, @govSphere, "12.345.678/9012-90") | ||
| 25 | end | 26 | end |
| 26 | 27 | ||
| 27 | should "Search for institution with acronym" do | 28 | should "Search for institution with acronym" do |
| @@ -50,6 +51,7 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | @@ -50,6 +51,7 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | ||
| 50 | end | 51 | end |
| 51 | 52 | ||
| 52 | should "method create_institution return the html for modal" do | 53 | should "method create_institution return the html for modal" do |
| 54 | + @controller.stubs(:current_user).returns(@admin.user) | ||
| 53 | xhr :get, :create_institution | 55 | xhr :get, :create_institution |
| 54 | assert_template 'create_institution' | 56 | assert_template 'create_institution' |
| 55 | end | 57 | end |
| @@ -57,7 +59,7 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | @@ -57,7 +59,7 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | ||
| 57 | should "create new institution with ajax without acronym" do | 59 | should "create new institution with ajax without acronym" do |
| 58 | @controller.stubs(:verify_recaptcha).returns(true) | 60 | @controller.stubs(:verify_recaptcha).returns(true) |
| 59 | 61 | ||
| 60 | - fields = generate_form_fields "foo bar", "BR", "DF", "Brasilia", "12.234.567/8900-10", "PublicInstitution" | 62 | + fields = InstitutionTestHelper.generate_form_fields "foo bar", "BR", "DF", "Brasilia", "12.234.567/8900-10", "PublicInstitution" |
| 61 | fields[:institutions][:governmental_power] = @govPower.id | 63 | fields[:institutions][:governmental_power] = @govPower.id |
| 62 | fields[:institutions][:governmental_sphere] = @govSphere.id | 64 | fields[:institutions][:governmental_sphere] = @govSphere.id |
| 63 | fields[:institutions][:juridical_nature] = @juridical_nature.id | 65 | fields[:institutions][:juridical_nature] = @juridical_nature.id |
| @@ -72,7 +74,7 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | @@ -72,7 +74,7 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | ||
| 72 | should "not create a institution that already exists" do | 74 | should "not create a institution that already exists" do |
| 73 | @controller.stubs(:verify_recaptcha).returns(true) | 75 | @controller.stubs(:verify_recaptcha).returns(true) |
| 74 | 76 | ||
| 75 | - fields = generate_form_fields "Ministerio Publico da Uniao", "BR", "DF", "Brasilia", "12.234.567/8900-10", "PublicInstitution" | 77 | + fields = InstitutionTestHelper.generate_form_fields "Ministerio Publico da Uniao", "BR", "DF", "Brasilia", "12.234.567/8900-10", "PublicInstitution" |
| 76 | fields[:institutions][:governmental_power] = @govPower.id | 78 | fields[:institutions][:governmental_power] = @govPower.id |
| 77 | fields[:institutions][:governmental_sphere] = @govSphere.id | 79 | fields[:institutions][:governmental_sphere] = @govSphere.id |
| 78 | fields[:institutions][:juridical_nature] = @juridical_nature.id | 80 | fields[:institutions][:juridical_nature] = @juridical_nature.id |
| @@ -87,7 +89,7 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | @@ -87,7 +89,7 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | ||
| 87 | should "not create a institution without cnpj" do | 89 | should "not create a institution without cnpj" do |
| 88 | @controller.stubs(:verify_recaptcha).returns(true) | 90 | @controller.stubs(:verify_recaptcha).returns(true) |
| 89 | 91 | ||
| 90 | - fields = generate_form_fields "Some Private Institution", "BR", "DF", "Brasilia", "", "PrivateInstitution" | 92 | + fields = InstitutionTestHelper.generate_form_fields "Some Private Institution", "BR", "DF", "Brasilia", "", "PrivateInstitution" |
| 91 | fields[:institutions][:acronym] = "SPI" | 93 | fields[:institutions][:acronym] = "SPI" |
| 92 | 94 | ||
| 93 | xhr :get, :new_institution, fields | 95 | xhr :get, :new_institution, fields |
| @@ -129,7 +131,7 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | @@ -129,7 +131,7 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | ||
| 129 | should "Create new institution with method post" do | 131 | should "Create new institution with method post" do |
| 130 | @controller.stubs(:verify_recaptcha).returns(true) | 132 | @controller.stubs(:verify_recaptcha).returns(true) |
| 131 | 133 | ||
| 132 | - fields = generate_form_fields "Some Private Institution", "BR", "DF", "Brasilia", "12.345.567/8900-10", "PrivateInstitution" | 134 | + fields = InstitutionTestHelper.generate_form_fields "Some Private Institution", "BR", "DF", "Brasilia", "12.345.567/8900-10", "PrivateInstitution" |
| 133 | fields[:institutions][:acronym] = "SPI" | 135 | fields[:institutions][:acronym] = "SPI" |
| 134 | 136 | ||
| 135 | post :new_institution, fields | 137 | post :new_institution, fields |
| @@ -140,7 +142,7 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | @@ -140,7 +142,7 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | ||
| 140 | should "not create new institution with method post without cnpj" do | 142 | should "not create new institution with method post without cnpj" do |
| 141 | @controller.stubs(:verify_recaptcha).returns(true) | 143 | @controller.stubs(:verify_recaptcha).returns(true) |
| 142 | 144 | ||
| 143 | - fields = generate_form_fields "Some Private Institution", "BR", "DF", "Brasilia", "", "PrivateInstitution" | 145 | + fields = InstitutionTestHelper.generate_form_fields "Some Private Institution", "BR", "DF", "Brasilia", "", "PrivateInstitution" |
| 144 | fields[:institutions][:acronym] = "SPI" | 146 | fields[:institutions][:acronym] = "SPI" |
| 145 | 147 | ||
| 146 | post :new_institution, fields | 148 | post :new_institution, fields |
| @@ -151,7 +153,7 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | @@ -151,7 +153,7 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | ||
| 151 | should "Create foreign institution without city, state and cnpj by post" do | 153 | should "Create foreign institution without city, state and cnpj by post" do |
| 152 | @controller.stubs(:verify_recaptcha).returns(true) | 154 | @controller.stubs(:verify_recaptcha).returns(true) |
| 153 | 155 | ||
| 154 | - fields = generate_form_fields "Foreign institution", "AZ", "", "", "", "PrivateInstitution" | 156 | + fields = InstitutionTestHelper.generate_form_fields "Foreign institution", "AZ", "", "", "", "PrivateInstitution" |
| 155 | fields[:institutions][:acronym] = "FI" | 157 | fields[:institutions][:acronym] = "FI" |
| 156 | 158 | ||
| 157 | post :new_institution, fields | 159 | post :new_institution, fields |
| @@ -162,7 +164,7 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | @@ -162,7 +164,7 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | ||
| 162 | should "Create foreign institution without city, state and cnpj by ajax" do | 164 | should "Create foreign institution without city, state and cnpj by ajax" do |
| 163 | @controller.stubs(:verify_recaptcha).returns(true) | 165 | @controller.stubs(:verify_recaptcha).returns(true) |
| 164 | 166 | ||
| 165 | - fields = generate_form_fields "Foreign institution", "AZ", "", "", "", "PrivateInstitution" | 167 | + fields = InstitutionTestHelper.generate_form_fields "Foreign institution", "AZ", "", "", "", "PrivateInstitution" |
| 166 | fields[:institutions][:acronym] = "FI" | 168 | fields[:institutions][:acronym] = "FI" |
| 167 | 169 | ||
| 168 | xhr :post, :new_institution, fields | 170 | xhr :post, :new_institution, fields |
| @@ -171,48 +173,4 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | @@ -171,48 +173,4 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | ||
| 171 | assert json_response["success"] | 173 | assert json_response["success"] |
| 172 | end | 174 | end |
| 173 | 175 | ||
| 174 | - private | ||
| 175 | - | ||
| 176 | - def generate_form_fields name, country, state, city, cnpj, type | ||
| 177 | - fields = { | ||
| 178 | - :community => { | ||
| 179 | - :name => name, | ||
| 180 | - :country => country, | ||
| 181 | - :state => state, | ||
| 182 | - :city => city | ||
| 183 | - }, | ||
| 184 | - :institutions => { | ||
| 185 | - :cnpj=> cnpj, | ||
| 186 | - :type => type, | ||
| 187 | - :acronym => "", | ||
| 188 | - :governmental_power => "", | ||
| 189 | - :governmental_sphere => "", | ||
| 190 | - :juridical_nature => "", | ||
| 191 | - :corporate_name => "coporate default" | ||
| 192 | - } | ||
| 193 | - } | ||
| 194 | - fields | ||
| 195 | - end | ||
| 196 | - | ||
| 197 | - def create_public_institution name, acronym, country, state, city, juridical_nature, gov_p, gov_s, cnpj | ||
| 198 | - institution_community = fast_create(Community) | ||
| 199 | - institution_community.name = name | ||
| 200 | - institution_community.country = country | ||
| 201 | - institution_community.state = state | ||
| 202 | - institution_community.city = city | ||
| 203 | - institution_community.save! | ||
| 204 | - | ||
| 205 | - institution = PublicInstitution.new | ||
| 206 | - institution.community = institution_community | ||
| 207 | - institution.name = name | ||
| 208 | - institution.juridical_nature = juridical_nature | ||
| 209 | - institution.acronym = acronym | ||
| 210 | - institution.governmental_power = gov_p | ||
| 211 | - institution.governmental_sphere = gov_s | ||
| 212 | - institution.cnpj = cnpj | ||
| 213 | - institution.corporate_name = "corporate default" | ||
| 214 | - institution.save! | ||
| 215 | - institution | ||
| 216 | - end | ||
| 217 | - | ||
| 218 | end | 176 | end |
test/functional/mpog_software_plugin_myprofile_controller_test.rb
| 1 | require File.dirname(__FILE__) + '/../../../../test/test_helper' | 1 | require File.dirname(__FILE__) + '/../../../../test/test_helper' |
| 2 | require File.dirname(__FILE__) + '/../../controllers/mpog_software_plugin_myprofile_controller' | 2 | require File.dirname(__FILE__) + '/../../controllers/mpog_software_plugin_myprofile_controller' |
| 3 | require File.dirname(__FILE__) + '/software_test_helper' | 3 | require File.dirname(__FILE__) + '/software_test_helper' |
| 4 | +require File.dirname(__FILE__) + '/institution_test_helper' | ||
| 4 | 5 | ||
| 5 | class MpogSoftwarePluginMyprofileController; def rescue_action(e) raise e end; | 6 | class MpogSoftwarePluginMyprofileController; def rescue_action(e) raise e end; |
| 6 | end | 7 | end |
| @@ -100,4 +101,36 @@ class MpogSoftwarePluginMyprofileControllerTest < ActionController::TestCase | @@ -100,4 +101,36 @@ class MpogSoftwarePluginMyprofileControllerTest < ActionController::TestCase | ||
| 100 | assert_equal true, SoftwareInfo.last.public_software? | 101 | assert_equal true, SoftwareInfo.last.public_software? |
| 101 | end | 102 | end |
| 102 | 103 | ||
| 104 | + should "user edit its community institution" do | ||
| 105 | + govPower = GovernmentalPower.create(:name=>"Some Gov Power") | ||
| 106 | + govSphere = GovernmentalSphere.create(:name=>"Some Gov Sphere") | ||
| 107 | + juridical_nature = JuridicalNature.create(:name => "Autarquia") | ||
| 108 | + | ||
| 109 | + institution = InstitutionTestHelper.create_public_institution("Ministerio Publico da Uniao", "MPU", "BR", "DF", "Gama", juridical_nature, govPower, govSphere, "12.345.678/9012-45") | ||
| 110 | + identifier = institution.community.identifier | ||
| 111 | + | ||
| 112 | + fields = InstitutionTestHelper.generate_form_fields "institution new name", "BR", "DF", "Gama", "12.345.678/9012-45", "PrivateInstitution" | ||
| 113 | + | ||
| 114 | + post :edit_institution, :profile=>institution.community.identifier, :community=>fields[:community], :institutions=>fields[:institutions] | ||
| 115 | + | ||
| 116 | + institution = Community[identifier].institution | ||
| 117 | + assert_not_equal "Ministerio Publico da Uniao", institution.community.name | ||
| 118 | + end | ||
| 119 | + | ||
| 120 | + should "not user edit its community institution with wrong values" do | ||
| 121 | + govPower = GovernmentalPower.create(:name=>"Some Gov Power") | ||
| 122 | + govSphere = GovernmentalSphere.create(:name=>"Some Gov Sphere") | ||
| 123 | + juridical_nature = JuridicalNature.create(:name => "Autarquia") | ||
| 124 | + | ||
| 125 | + institution = InstitutionTestHelper.create_public_institution("Ministerio Publico da Uniao", "MPU", "BR", "DF", "Gama", juridical_nature, govPower, govSphere, "12.345.678/9012-45") | ||
| 126 | + identifier = institution.community.identifier | ||
| 127 | + | ||
| 128 | + fields = InstitutionTestHelper.generate_form_fields "", "BR", "DF", "Gama", "6465465465", "PrivateInstitution" | ||
| 129 | + | ||
| 130 | + post :edit_institution, :profile=>institution.community.identifier, :community=>fields[:community], :institutions=>fields[:institutions] | ||
| 131 | + | ||
| 132 | + institution = Community[identifier].institution | ||
| 133 | + assert_equal "Ministerio Publico da Uniao", institution.community.name | ||
| 134 | + assert_equal "12.345.678/9012-45", institution.cnpj | ||
| 135 | + end | ||
| 103 | end | 136 | end |