Commit 7f3ef5c768d20a229dd98f46ab524cda71d10a39
1 parent
a51a5baa
Exists in
master
and in
29 other branches
ActionItem508: display only regions with validators on enterprise
registration git-svn-id: https://svn.colivre.coop.br/svn/noosfero/trunk@2191 3f533792-8f58-4932-b0fe-aaf55b0a4547
Showing
7 changed files
with
49 additions
and
3 deletions
Show diff stats
app/controllers/public/enterprise_registration_controller.rb
| ... | ... | @@ -33,7 +33,7 @@ class EnterpriseRegistrationController < ApplicationController |
| 33 | 33 | # |
| 34 | 34 | # Posts back. |
| 35 | 35 | def basic_information |
| 36 | - @regions = environment.regions.map {|item| [item.name, item.id]} | |
| 36 | + @regions = environment.regions.select{|i| i.has_validator?}.map {|item| [item.name, item.id]} | |
| 37 | 37 | end |
| 38 | 38 | |
| 39 | 39 | # present information about validator organizations, and the user one to | ... | ... |
app/models/region.rb
app/views/enterprise_registration/basic_information.rhtml
| ... | ... | @@ -26,7 +26,7 @@ |
| 26 | 26 | |
| 27 | 27 | <%= labelled_form_field(_('Management information'), text_editor('create_enterprise', 'management_information')) %> |
| 28 | 28 | |
| 29 | - <%= f.select('region_id', @regions) %> | |
| 29 | + <%= labelled_form_field(_('Region'), f.select('region_id', @regions)) %> | |
| 30 | 30 | |
| 31 | 31 | <% button_bar do %> |
| 32 | 32 | <%= submit_button('next', _('Next'), :cancel => {:action => 'index'}) %> | ... | ... |
app/views/profile_editor/index.rhtml
| ... | ... | @@ -48,7 +48,7 @@ |
| 48 | 48 | |
| 49 | 49 | <% button_bar do %> |
| 50 | 50 | <%= button(:add, _('Create a new community'), :controller => 'memberships', :action => 'new_community') %> |
| 51 | - <%= button(:add, _('Register a new Enterprise'), :controller => 'enterprise_registration') %> | |
| 51 | + <%= button(:add, _('Register a new Enterprise'), :controller => 'enterprise_registration') if environment.regions.any?{|i| i.has_validator?} %> | |
| 52 | 52 | <% end %> |
| 53 | 53 | |
| 54 | 54 | <% file_manager do %> | ... | ... |
test/functional/enterprise_registration_controller_test.rb
| ... | ... | @@ -134,4 +134,18 @@ all_fixtures |
| 134 | 134 | assert_sanitized assigns(:create_enterprise).management_information |
| 135 | 135 | end |
| 136 | 136 | |
| 137 | + should 'load only regions with validator organizations' do | |
| 138 | + env = Environment.default | |
| 139 | + | |
| 140 | + reg1 = env.regions.create!(:name => 'Region with validator') | |
| 141 | + reg1.validators.create!(:name => 'Validator one', :identifier => 'validator-one') | |
| 142 | + reg2 = env.regions.create!(:name => 'Region without validator') | |
| 143 | + | |
| 144 | + get :index | |
| 145 | + | |
| 146 | + assert_includes assigns(:regions), [reg1.name, reg1.id] | |
| 147 | + assert_tag :tag => 'option', :content => "Region with validator" | |
| 148 | + assert_no_tag :tag => 'option', :content => "Region without validator" | |
| 149 | + end | |
| 150 | + | |
| 137 | 151 | end | ... | ... |
test/functional/profile_editor_controller_test.rb
| ... | ... | @@ -418,5 +418,19 @@ class ProfileEditorControllerTest < Test::Unit::TestCase |
| 418 | 418 | get :index, :profile => profile.identifier |
| 419 | 419 | assert_tag :tag => 'a', :attributes => { :href => "/myprofile/#{profile.identifier}/memberships/new_community" } |
| 420 | 420 | end |
| 421 | + | |
| 422 | + should 'not display link to register new enterprise if there is no validators' do | |
| 423 | + person = create_user('testuser').person | |
| 424 | + get :index, :profile => 'testuser' | |
| 425 | + assert_no_tag :tag => 'a', :content => 'Register a new Enterprise' | |
| 426 | + end | |
| 427 | + | |
| 428 | + should 'display link to register new enterprise' do | |
| 429 | + reg = Environment.default.regions.create!(:name => 'Region test') | |
| 430 | + reg.validators.create!(:name => 'Validator test', :identifier => 'validator-test') | |
| 431 | + person = create_user('testuser').person | |
| 432 | + get :index, :profile => 'testuser' | |
| 433 | + assert_tag :tag => 'a', :content => 'Register a new Enterprise' | |
| 434 | + end | |
| 421 | 435 | |
| 422 | 436 | end | ... | ... |
test/unit/region_test.rb
| ... | ... | @@ -40,4 +40,17 @@ class RegionTest < Test::Unit::TestCase |
| 40 | 40 | assert_not_includes possible, org1 |
| 41 | 41 | end |
| 42 | 42 | |
| 43 | + should 'has validator' do | |
| 44 | + env = Environment.create!(:name => "my test environment") | |
| 45 | + region = Region.create!(:environment_id => env.id, :name => 'My Region') | |
| 46 | + region.validators.create!(:name => 'Validator entity', :identifier => 'validator-entity') | |
| 47 | + assert region.has_validator? | |
| 48 | + end | |
| 49 | + | |
| 50 | + should 'has no validator' do | |
| 51 | + env = Environment.create!(:name => "my test environment") | |
| 52 | + region = Region.create!(:environment_id => env.id, :name => 'My Region') | |
| 53 | + assert !region.has_validator? | |
| 54 | + end | |
| 55 | + | |
| 43 | 56 | end | ... | ... |