Commit 27e1092c92042be0ca3ecc3ae81416d068023bed
Committed by
Gabriela Navarro
1 parent
1be114f2
Exists in
master
and in
79 other branches
Add institution block and unit tests.
Signed-off-by: Luciano Prestes <lucianopcbr@gmail.com> Signed-off-by: Parley Martins <parley@outlook.com>
Showing
3 changed files
with
106 additions
and
0 deletions
Show diff stats
@@ -0,0 +1,63 @@ | @@ -0,0 +1,63 @@ | ||
1 | +class InstitutionsBlock < CommunitiesBlock | ||
2 | + | ||
3 | + def self.description | ||
4 | + _('Institutions') | ||
5 | + end | ||
6 | + | ||
7 | + def profile_count | ||
8 | + profile_list.count | ||
9 | + end | ||
10 | + | ||
11 | + def default_title | ||
12 | + n_('{#} institution', '{#} institutions', profile_count) | ||
13 | + end | ||
14 | + | ||
15 | + def help | ||
16 | + _('This block displays the institutions in which the user is a member.') | ||
17 | + end | ||
18 | + | ||
19 | + def footer | ||
20 | + owner = self.owner | ||
21 | + case owner | ||
22 | + when Profile | ||
23 | + lambda do |context| | ||
24 | + link_to s_('institutions|View all'), :profile => owner.identifier, :controller => 'profile', :action => 'communities' | ||
25 | + end | ||
26 | + when Environment | ||
27 | + lambda do |context| | ||
28 | + link_to s_('institutions|View all'), :controller => 'search', :action => 'communities' | ||
29 | + end | ||
30 | + else | ||
31 | + '' | ||
32 | + end | ||
33 | + end | ||
34 | + | ||
35 | + def profile_list | ||
36 | + result = nil | ||
37 | + visible_profiles = profiles.visible.includes([:image,:domains,:preferred_domain,:environment]) | ||
38 | + if !prioritize_profiles_with_image | ||
39 | + result = visible_profiles.all(:limit => get_limit, :order => 'profiles.updated_at DESC').sort_by{ rand } | ||
40 | + elsif profiles.visible.with_image.count >= get_limit | ||
41 | + result = visible_profiles.with_image.all(:limit => get_limit * 5, :order => 'profiles.updated_at DESC').sort_by{ rand } | ||
42 | + else | ||
43 | + result = visible_profiles.with_image.sort_by{ rand } + visible_profiles.without_image.all(:limit => get_limit * 5, :order => 'profiles.updated_at DESC').sort_by{ rand } | ||
44 | + end | ||
45 | + | ||
46 | + communities_with_institution_list = [] | ||
47 | + | ||
48 | + result.each do |r| | ||
49 | + if r.class == Community and r.institution? | ||
50 | + communities_with_institution_list << r | ||
51 | + end | ||
52 | + end | ||
53 | + | ||
54 | + result = communities_with_institution_list | ||
55 | + | ||
56 | + result.slice(0..get_limit-1) | ||
57 | + end | ||
58 | + | ||
59 | + def profiles | ||
60 | + owner.communities | ||
61 | + end | ||
62 | + | ||
63 | +end |
lib/mpog_software_plugin.rb
@@ -455,6 +455,12 @@ class MpogSoftwarePlugin < Noosfero::Plugin | @@ -455,6 +455,12 @@ class MpogSoftwarePlugin < Noosfero::Plugin | ||
455 | end | 455 | end |
456 | end | 456 | end |
457 | 457 | ||
458 | + def self.extra_blocks | ||
459 | + { | ||
460 | + InstitutionsBlock => {:type => [Environment, Person]} | ||
461 | + } | ||
462 | + end | ||
463 | + | ||
458 | private | 464 | private |
459 | 465 | ||
460 | # Add and remove the user from it's institutions communities | 466 | # Add and remove the user from it's institutions communities |
@@ -0,0 +1,37 @@ | @@ -0,0 +1,37 @@ | ||
1 | +require File.dirname(__FILE__) + '/../../../../test/test_helper' | ||
2 | +require File.dirname(__FILE__) + '/plugin_test_helper' | ||
3 | + | ||
4 | +class InstitutionsBlockTest < ActiveSupport::TestCase | ||
5 | + include PluginTestHelper | ||
6 | + should 'inherit from Block' do | ||
7 | + assert_kind_of Block, InstitutionsBlock.new | ||
8 | + end | ||
9 | + | ||
10 | + should 'declare its default title' do | ||
11 | + InstitutionsBlock.any_instance.stubs(:profile_count).returns(0) | ||
12 | + assert_not_equal Block.new.default_title, InstitutionsBlock.new.default_title | ||
13 | + end | ||
14 | + | ||
15 | + should 'describe itself' do | ||
16 | + assert_not_equal Block.description, InstitutionsBlock.description | ||
17 | + end | ||
18 | + | ||
19 | + should 'give empty footer on unsupported owner type' do | ||
20 | + block = InstitutionsBlock.new | ||
21 | + block.expects(:owner).returns(1) | ||
22 | + assert_equal '', block.footer | ||
23 | + end | ||
24 | + | ||
25 | + should 'list institutions' do | ||
26 | + user = create_person("Jose_Augusto", "jose_augusto@email.com", "aaaaaaa", "aaaaaaa", "jose_silva@email.com", "DF", "Gama") | ||
27 | + | ||
28 | + institution = create_private_institution "inst", "00000000000000", "country", "state", "city" | ||
29 | + institution.community.add_member(user) | ||
30 | + | ||
31 | + block = InstitutionsBlock.new | ||
32 | + block.expects(:owner).at_least_once.returns(user) | ||
33 | + | ||
34 | + assert_equivalent [institution.community], block.profiles | ||
35 | + end | ||
36 | + | ||
37 | +end |