Commit fbc6e195533b36a0cf680cc4ee0da2f54e4fed69
Exists in
master
and in
5 other branches
Merge branch 'institution_fields'
Conflicts: views/institution_editor_extras.html.erb views/mpog_software_plugin/create_institution.html.erb
Showing
5 changed files
with
139 additions
and
49 deletions
Show diff stats
test/functional/account_controller_test.rb
@@ -12,15 +12,15 @@ class AccountControllerTest < ActionController::TestCase | @@ -12,15 +12,15 @@ class AccountControllerTest < ActionController::TestCase | ||
12 | 12 | ||
13 | @govPower = GovernmentalPower.create(:name=>"Some Gov Power") | 13 | @govPower = GovernmentalPower.create(:name=>"Some Gov Power") |
14 | @govSphere = GovernmentalSphere.create(:name=>"Some Gov Sphere") | 14 | @govSphere = GovernmentalSphere.create(:name=>"Some Gov Sphere") |
15 | + @juridical_nature = JuridicalNature.create(:name => "Autarquia") | ||
15 | 16 | ||
16 | @controller = AccountController.new | 17 | @controller = AccountController.new |
17 | @request = ActionController::TestRequest.new | 18 | @request = ActionController::TestRequest.new |
18 | @response = ActionController::TestResponse.new | 19 | @response = ActionController::TestResponse.new |
19 | 20 | ||
20 | @institution_list = [] | 21 | @institution_list = [] |
21 | - @institution_list << create_institution("Ministerio Publico da Uniao", "MPU") | ||
22 | - @institution_list << create_institution("Tribunal Regional da Uniao", "TRU") | ||
23 | - | 22 | + @institution_list << create_public_institution("Ministerio Publico da Uniao", "MPU", "BR", "DF", "Gama", @juridical_nature, @govPower, @govSphere) |
23 | + @institution_list << create_public_institution("Tribunal Regional da Uniao", "TRU", "BR", "DF", "Brasilia", @juridical_nature, @govPower, @govSphere) | ||
24 | @user_info = { | 24 | @user_info = { |
25 | :login=>"novo_usuario", | 25 | :login=>"novo_usuario", |
26 | :password=>"nova_senha", | 26 | :password=>"nova_senha", |
@@ -91,15 +91,22 @@ class AccountControllerTest < ActionController::TestCase | @@ -91,15 +91,22 @@ class AccountControllerTest < ActionController::TestCase | ||
91 | 91 | ||
92 | private | 92 | private |
93 | 93 | ||
94 | - def create_institution name, acronym | ||
95 | - institution_community = Community::create :name=>name | 94 | + def create_public_institution name, acronym, country, state, city, juridical_nature, gov_p, gov_s |
95 | + institution_community = fast_create(Community) | ||
96 | + institution_community.name = name | ||
97 | + institution_community.country = country | ||
98 | + institution_community.state = state | ||
99 | + institution_community.city = city | ||
100 | + institution_community.save! | ||
101 | + | ||
96 | institution = PublicInstitution.new | 102 | institution = PublicInstitution.new |
97 | institution.community = institution_community | 103 | institution.community = institution_community |
98 | institution.name = name | 104 | institution.name = name |
99 | - institution.acronym = acronym | ||
100 | - institution.governmental_power = @govPower | ||
101 | - institution.governmental_sphere = @govSphere | ||
102 | - institution.save | 105 | + institution.juridical_nature = juridical_nature |
106 | + institution.acronym = acronym | ||
107 | + institution.governmental_power = gov_p | ||
108 | + institution.governmental_sphere = gov_s | ||
109 | + institution.save! | ||
103 | institution | 110 | institution |
104 | end | 111 | end |
105 | 112 |
@@ -0,0 +1,68 @@ | @@ -0,0 +1,68 @@ | ||
1 | +require File.dirname(__FILE__) + '/../../../../test/test_helper' | ||
2 | +require File.dirname(__FILE__) + '/../../controllers/mpog_software_plugin_controller' | ||
3 | + | ||
4 | + | ||
5 | +class InstitutionEditorTest < ActionController::TestCase | ||
6 | + | ||
7 | + def setup | ||
8 | + @controller = ProfileEditorController.new | ||
9 | + @request = ActionController::TestRequest.new | ||
10 | + @response = ActionController::TestResponse.new | ||
11 | + | ||
12 | + @environment = Environment.default | ||
13 | + @environment.enabled_plugins = ['MpogSoftwarePlugin'] | ||
14 | + @environment.save | ||
15 | + | ||
16 | + @govPower = GovernmentalPower.create(:name=>"Some Gov Power") | ||
17 | + @govSphere = GovernmentalSphere.create(:name=>"Some Gov Sphere") | ||
18 | + @juridical_nature = JuridicalNature.create(:name => "Autarquia") | ||
19 | + | ||
20 | + | ||
21 | + @institution_list = [] | ||
22 | + @institution_list << create_public_institution("Ministerio Publico da Uniao", "MPU", "BR", "DF", "Gama", @juridical_nature, @govPower, @govSphere) | ||
23 | + @institution_list << create_public_institution("Tribunal Regional da Uniao", "TRU", "BR", "DF", "Brasilia", @juridical_nature, @govPower, @govSphere) | ||
24 | + end | ||
25 | + | ||
26 | + | ||
27 | + should ' enable edition of sisp field for enviroment admin' do | ||
28 | + admin = create_user("adminuser").person | ||
29 | + admin.stubs(:has_permission?).returns("true") | ||
30 | + login_as('adminuser') | ||
31 | + @environment.add_admin(admin) | ||
32 | + get :edit, :profile => @institution_list[0].community.identifier, :id => @institution_list[0].community.id | ||
33 | + assert_tag :tag => 'span', :descendant => {:tag => "input", :attributes => { :type => 'radio', :name => "institution[sisp]"}} | ||
34 | + end | ||
35 | + | ||
36 | + should 'enable only visulization of sisp field for institution admin' do | ||
37 | + ze = create_user("ze").person | ||
38 | + login_as('ze') | ||
39 | + @institution_list[0].community.add_admin(ze) | ||
40 | + get :edit, :profile => @institution_list[0].community.identifier, :id => @institution_list[0].community.id | ||
41 | + assert_tag :tag => 'span', :descendant => {:tag => "label", :attributes => {:for => "SISP"}} | ||
42 | + end | ||
43 | + | ||
44 | + | ||
45 | + private | ||
46 | + | ||
47 | + def create_public_institution name, acronym, country, state, city, juridical_nature, gov_p, gov_s | ||
48 | + institution_community = fast_create(Community) | ||
49 | + institution_community.name = name | ||
50 | + institution_community.country = country | ||
51 | + institution_community.state = state | ||
52 | + institution_community.city = city | ||
53 | + institution_community.save! | ||
54 | + | ||
55 | + institution = PublicInstitution.new | ||
56 | + institution.community = institution_community | ||
57 | + institution.name = name | ||
58 | + institution.juridical_nature = juridical_nature | ||
59 | + institution.sisp = false | ||
60 | + institution.acronym = acronym | ||
61 | + institution.governmental_power = gov_p | ||
62 | + institution.governmental_sphere = gov_s | ||
63 | + institution.save! | ||
64 | + | ||
65 | + institution | ||
66 | + end | ||
67 | + | ||
68 | +end |
test/functional/mpog_software_plugin_controller_test.rb
@@ -16,11 +16,12 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | @@ -16,11 +16,12 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | ||
16 | 16 | ||
17 | @govPower = GovernmentalPower.create(:name=>"Some Gov Power") | 17 | @govPower = GovernmentalPower.create(:name=>"Some Gov Power") |
18 | @govSphere = GovernmentalSphere.create(:name=>"Some Gov Sphere") | 18 | @govSphere = GovernmentalSphere.create(:name=>"Some Gov Sphere") |
19 | + @juridical_nature = JuridicalNature.create(:name => "Autarquia") | ||
19 | @response = ActionController::TestResponse.new | 20 | @response = ActionController::TestResponse.new |
20 | 21 | ||
21 | @institution_list = [] | 22 | @institution_list = [] |
22 | - @institution_list << create_public_institution("Ministerio Publico da Uniao", "MPU", @govPower, @govSphere) | ||
23 | - @institution_list << create_public_institution("Tribunal Regional da Uniao", "TRU", @govPower, @govSphere) | 23 | + @institution_list << create_public_institution("Ministerio Publico da Uniao", "MPU", "BR", "DF", "Gama", @juridical_nature, @govPower, @govSphere) |
24 | + @institution_list << create_public_institution("Tribunal Regional da Uniao", "TRU", "BR", "DF", "Brasilia", @juridical_nature, @govPower, @govSphere) | ||
24 | end | 25 | end |
25 | 26 | ||
26 | should "Search for institution with acronym" do | 27 | should "Search for institution with acronym" do |
@@ -58,11 +59,14 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | @@ -58,11 +59,14 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | ||
58 | 59 | ||
59 | xhr :get, :new_institution, | 60 | xhr :get, :new_institution, |
60 | :authenticity_token=>"dsa45a6das52sd", | 61 | :authenticity_token=>"dsa45a6das52sd", |
61 | - :community=>{:name=>"foo bar"}, | ||
62 | - :institution => {:cnpj=>"12.234.567/8900-10", :acronym=>"fb", :type=>"PublicInstitution"}, | 62 | + :name => "foo bar", |
63 | + :community=>{:name=>"foo bar", :country => "BR", :state => "DF", :city => "Brasilia"}, | ||
63 | :governmental=>{:power=>@govPower.id, :sphere=>@govSphere.id}, | 64 | :governmental=>{:power=>@govPower.id, :sphere=>@govSphere.id}, |
65 | + :juridical => {:nature => @juridical_nature.id}, | ||
66 | + :institution => {:cnpj=>"12.234.567/8900-10", :acronym=>"fb", :type=>"PublicInstitution"}, | ||
64 | :recaptcha_response_field=>'' | 67 | :recaptcha_response_field=>'' |
65 | 68 | ||
69 | + | ||
66 | json_response = ActiveSupport::JSON.decode(@response.body) | 70 | json_response = ActiveSupport::JSON.decode(@response.body) |
67 | 71 | ||
68 | assert json_response["success"] | 72 | assert json_response["success"] |
@@ -73,9 +77,11 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | @@ -73,9 +77,11 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | ||
73 | 77 | ||
74 | xhr :get, :new_institution, | 78 | xhr :get, :new_institution, |
75 | :authenticity_token=>"dsa45a6das52sd", | 79 | :authenticity_token=>"dsa45a6das52sd", |
76 | - :community=>{:name=>"Ministerio Publico da Uniao"}, | ||
77 | - :institution => {:cnpj=>"12.234.567/8900-10", :acronym=>"fb", :type=>"PublicInstitution"}, | 80 | + :name => "Ministerio Publico da Uniao", |
81 | + :community=>{:name=>"Ministerio Publico da Uniao", :country => "BR", :state => "DF", :city => "Brasilia"}, | ||
78 | :governmental=>{:power=>@govPower.id, :sphere=>@govSphere.id}, | 82 | :governmental=>{:power=>@govPower.id, :sphere=>@govSphere.id}, |
83 | + :juridical => {:nature => @juridical_nature.id}, | ||
84 | + :institution => {:cnpj=>"12.234.567/8900-10", :acronym=>"fb", :type=>"PublicInstitution"}, | ||
79 | :recaptcha_response_field=>'' | 85 | :recaptcha_response_field=>'' |
80 | 86 | ||
81 | json_response = ActiveSupport::JSON.decode(@response.body) | 87 | json_response = ActiveSupport::JSON.decode(@response.body) |
@@ -83,24 +89,6 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | @@ -83,24 +89,6 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | ||
83 | assert !json_response["success"] | 89 | assert !json_response["success"] |
84 | end | 90 | end |
85 | 91 | ||
86 | - should "set the environment admin as institution community admin" do | ||
87 | - @controller.stubs(:verify_recaptcha).returns(true) | ||
88 | - | ||
89 | - xhr :get, :new_institution, | ||
90 | - :authenticity_token=>"dsa45a6das52sd", | ||
91 | - :community=>{:name=>"Another instituon community"}, | ||
92 | - :institution => {:cnpj=>"10.254.577/8910-12", :acronym=>"aic", :type=>"PublicInstitution"}, | ||
93 | - :governmental=>{:power=>@govPower.id, :sphere=>@govSphere.id}, | ||
94 | - :recaptcha_response_field=>'' | ||
95 | - | ||
96 | - json_response = ActiveSupport::JSON.decode(@response.body) | ||
97 | - | ||
98 | - assert json_response["success"] | ||
99 | - | ||
100 | - assert Community.last.admins.include?(@environment.admins.first) | ||
101 | - assert_equal Community.last.name, "Another instituon community" | ||
102 | - end | ||
103 | - | ||
104 | should "verify if institution name already exists" do | 92 | should "verify if institution name already exists" do |
105 | xhr :get, :institution_already_exists, :name=>"Ministerio Publico da Uniao" | 93 | xhr :get, :institution_already_exists, :name=>"Ministerio Publico da Uniao" |
106 | assert_equal "true", @response.body | 94 | assert_equal "true", @response.body |
@@ -135,9 +123,11 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | @@ -135,9 +123,11 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | ||
135 | 123 | ||
136 | xhr :get, :new_institution, | 124 | xhr :get, :new_institution, |
137 | :authenticity_token=>"dsa45a6das52sd", | 125 | :authenticity_token=>"dsa45a6das52sd", |
138 | - :community=>{:name=>"foo bar"}, | ||
139 | - :institution => {:cnpj=>"12.234.567/8900-10", :acronym=>"fb", :type=>"PublicInstitution"}, | 126 | + :name => "foo bar", |
127 | + :community=>{:name=>"foo bar", :country => "BR", :state => "DF", :city => "Brasilia"}, | ||
140 | :governmental=>{:power=>@govPower.id, :sphere=>@govSphere.id}, | 128 | :governmental=>{:power=>@govPower.id, :sphere=>@govSphere.id}, |
129 | + :juridical => {:nature => @juridical_nature.id}, | ||
130 | + :institution => {:cnpj=>"12.234.567/8900-10", :acronym=>"fb", :type=>"PublicInstitution"}, | ||
141 | :recaptcha_response_field=>'' | 131 | :recaptcha_response_field=>'' |
142 | 132 | ||
143 | date = Time.now.day.to_s + "/" + Time.now.month.to_s + "/" + Time.now.year.to_s | 133 | date = Time.now.day.to_s + "/" + Time.now.month.to_s + "/" + Time.now.year.to_s |
@@ -147,15 +137,23 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | @@ -147,15 +137,23 @@ class MpogSoftwarePluginControllerTest < ActionController::TestCase | ||
147 | 137 | ||
148 | private | 138 | private |
149 | 139 | ||
150 | - def create_public_institution name, acronym, gov_p, gov_s | ||
151 | - institution_community = Community::new :name=>name | 140 | + def create_public_institution name, acronym, country, state, city, juridical_nature, gov_p, gov_s |
141 | + institution_community = fast_create(Community) | ||
142 | + institution_community.name = name | ||
143 | + institution_community.country = country | ||
144 | + institution_community.state = state | ||
145 | + institution_community.city = city | ||
146 | + institution_community.save! | ||
147 | + | ||
152 | institution = PublicInstitution.new | 148 | institution = PublicInstitution.new |
153 | institution.community = institution_community | 149 | institution.community = institution_community |
154 | institution.name = name | 150 | institution.name = name |
155 | - institution.acronym = acronym | 151 | + institution.juridical_nature = juridical_nature |
152 | + institution.acronym = acronym | ||
156 | institution.governmental_power = gov_p | 153 | institution.governmental_power = gov_p |
157 | institution.governmental_sphere = gov_s | 154 | institution.governmental_sphere = gov_s |
158 | - institution.save | 155 | + institution.save! |
159 | institution | 156 | institution |
160 | end | 157 | end |
158 | + | ||
161 | end | 159 | end |
views/institution_editor_extras.html.erb
@@ -34,15 +34,18 @@ | @@ -34,15 +34,18 @@ | ||
34 | <%= label_tag('juridical_nature', _("Juridical Nature")) %> | 34 | <%= label_tag('juridical_nature', _("Juridical Nature")) %> |
35 | <%= select_tag(:juridical_nature, options_for_select(JuridicalNature.all.map {|j| [j.name, j.id]}, :selected => context.profile.institution.juridical_nature_id), :class=>"formlabel") %> | 35 | <%= select_tag(:juridical_nature, options_for_select(JuridicalNature.all.map {|j| [j.name, j.id]}, :selected => context.profile.institution.juridical_nature_id), :class=>"formlabel") %> |
36 | </div> | 36 | </div> |
37 | -</span> | ||
38 | - | 37 | + </span> |
38 | + | ||
39 | + <span class= 'public-institutions-fields'> | ||
40 | + <div class="formfieldline"> | ||
39 | <% if @show_sisp_field %> | 41 | <% if @show_sisp_field %> |
40 | - <span class= 'public-institutions-fields'> | ||
41 | - <div class="formfieldline"> | ||
42 | - <%= _("SISP?") %> | ||
43 | - <%= labelled_radio_button(_('Yes'), 'institution[sisp]', 'true', context.profile.institution.sisp)%> | ||
44 | - <%= labelled_radio_button(_('No'), 'institution[sisp]', 'false', !context.profile.institution.sisp)%> | ||
45 | - </div> | ||
46 | - </span> | 42 | + <%= _("SISP?") %> |
43 | + <%= labelled_radio_button(_('Yes'), 'institution[sisp]', 'true', context.profile.institution.sisp)%> | ||
44 | + <%= labelled_radio_button(_('No'), 'institution[sisp]', 'false', !context.profile.institution.sisp)%> | ||
45 | + <% else %> | ||
46 | + <%= _("SISP?") %> | ||
47 | + <%= label_tag('SISP', context.profile.institution.sisp ? "YES" : "NO") %> | ||
47 | <% end %> | 48 | <% end %> |
49 | + </div> | ||
50 | + </span> | ||
48 | <% end %> | 51 | <% end %> |
views/mpog_software_plugin/create_institution.html.erb
@@ -75,8 +75,22 @@ | @@ -75,8 +75,22 @@ | ||
75 | <%= inst.select(:juridical_nature, [[_("Select a Juridical Nature"), 0]]|JuridicalNature.all.map {|j| [j.name, j.id]}, {:selected=>0})%> | 75 | <%= inst.select(:juridical_nature, [[_("Select a Juridical Nature"), 0]]|JuridicalNature.all.map {|j| [j.name, j.id]}, {:selected=>0})%> |
76 | </div> | 76 | </div> |
77 | </span> | 77 | </span> |
78 | + | ||
79 | + <span class='required-field public-institutions-fields'> | ||
80 | + <div class="formfield type-text"> | ||
81 | + <%= _("SISP?") %> | ||
82 | + <% if @show_sisp_field %> | ||
83 | + <%= inst.label("sisp" ,_("Yes")) %> | ||
84 | + <%= inst.radio_button(:sisp, true) %> | ||
85 | + <%= inst.label("sisp" ,_("No")) %> | ||
86 | + <%= inst.radio_button(:sisp, false) %> | ||
87 | + <% else %> | ||
88 | + <%= inst.label("sisp", _("No")) %> | ||
89 | + <% end %> | ||
90 | + </div> | ||
91 | + </span> | ||
78 | <br /> | 92 | <br /> |
79 | - | 93 | + |
80 | <div> | 94 | <div> |
81 | <p><%= recaptcha_tags :ajax => true, :display => {:theme => 'clean'} %> </p> | 95 | <p><%= recaptcha_tags :ajax => true, :display => {:theme => 'clean'} %> </p> |
82 | <%= link_to(_('Save'), '#', :id=>'save_institution_button', :class=>'button with-text icon-add') %> | 96 | <%= link_to(_('Save'), '#', :id=>'save_institution_button', :class=>'button with-text icon-add') %> |