Commit 2e999a095a94f1b7e7bf563eeaeb53f8eee53020
1 parent
8238d31d
Exists in
master
and in
29 other branches
ActionItem152: revamping recent documents block
git-svn-id: https://svn.colivre.coop.br/svn/noosfero/trunk@1263 3f533792-8f58-4932-b0fe-aaf55b0a4547
Showing
4 changed files
with
55 additions
and
28 deletions
Show diff stats
app/models/block.rb
app/models/recent_documents_block.rb
1 | 1 | class RecentDocumentsBlock < Block |
2 | 2 | |
3 | + def self.description | |
4 | + _('List of recent content') | |
5 | + end | |
6 | + | |
7 | + settings_item :limit | |
8 | + | |
3 | 9 | def content |
4 | - lambda do | |
5 | - content_tag( | |
6 | - 'ul', | |
7 | - profile.recent_documents.map {|item| content_tag('li', link_to_document(item)) }.join("\n") | |
8 | - ) | |
9 | - end | |
10 | + docs = | |
11 | + if self.limit.nil? | |
12 | + owner.recent_documents | |
13 | + else | |
14 | + owner.recent_documents(self.limit) | |
15 | + end | |
16 | + | |
17 | + content_tag('ul', docs.map {|item| content_tag('li', link_to(item.title, item.url))}.join("\n")) | |
18 | + | |
10 | 19 | end |
11 | 20 | |
12 | 21 | end | ... | ... |
app/models/tags_block.rb
test/unit/recent_documents_block_test.rb
... | ... | @@ -2,26 +2,44 @@ require File.dirname(__FILE__) + '/../test_helper' |
2 | 2 | |
3 | 3 | class RecentDocumentsBlockTest < Test::Unit::TestCase |
4 | 4 | |
5 | - # Replace this with your real tests. | |
6 | - def test_should_output_list_with_links_to_recent_documents | |
7 | - profile = mock | |
8 | - profile.stubs(:identifier).returns('a_test_profile') | |
9 | - | |
10 | - doc1 = mock | |
11 | - doc2 = mock | |
12 | - doc3 = mock | |
13 | - profile.expects(:recent_documents).returns([doc1, doc2, doc3]) | |
14 | - | |
15 | - helper = mock | |
16 | - helper.expects(:profile).returns(profile) | |
17 | - helper.expects(:link_to_document).with(doc1).returns('doc1') | |
18 | - helper.expects(:content_tag).with('li', 'doc1').returns('doc1') | |
19 | - helper.expects(:link_to_document).with(doc2).returns('doc2') | |
20 | - helper.expects(:content_tag).with('li', 'doc2').returns('doc2') | |
21 | - helper.expects(:link_to_document).with(doc3).returns('doc3') | |
22 | - helper.expects(:content_tag).with('li', 'doc3').returns('doc3') | |
23 | - helper.expects(:content_tag).with('ul', "doc1\ndoc2\ndoc3").returns('the_tag') | |
24 | - | |
25 | - assert_equal('the_tag', helper.instance_eval(&RecentDocumentsBlock.new.content)) | |
5 | + def setup | |
6 | + profile = create_user('testinguser').person | |
7 | + profile.articles.build(:name => 'first').save! | |
8 | + profile.articles.build(:name => 'second').save! | |
9 | + profile.articles.build(:name => 'third').save! | |
10 | + profile.articles.build(:name => 'forth').save! | |
11 | + profile.articles.build(:name => 'fifth').save! | |
12 | + | |
13 | + box = Box.create!(:owner => profile) | |
14 | + @block = RecentDocumentsBlock.create!(:box_id => box.id) | |
15 | + | |
16 | + end | |
17 | + attr_reader :block | |
18 | + | |
19 | + should 'describe itself' do | |
20 | + assert_not_equal Block.description, RecentDocumentsBlock.description | |
21 | + end | |
22 | + | |
23 | + should 'output list with links to recent documents' do | |
24 | + output = block.content | |
25 | + | |
26 | + assert_match /href=.*\/testinguser\/first/, output | |
27 | + assert_match /href=.*\/testinguser\/second/, output | |
28 | + assert_match /href=.*\/testinguser\/third/, output | |
29 | + assert_match /href=.*\/testinguser\/forth/, output | |
30 | + assert_match /href=.*\/testinguser\/fifth/, output | |
26 | 31 | end |
32 | + | |
33 | + should 'respect the maximum number of items as configured' do | |
34 | + block.limit = 3 | |
35 | + | |
36 | + output = block.content | |
37 | + | |
38 | + assert_match /href=.*\/testinguser\/first/, output | |
39 | + assert_match /href=.*\/testinguser\/second/, output | |
40 | + assert_match /href=.*\/testinguser\/third/, output | |
41 | + assert_no_match /href=.*\/testinguser\/forth/, output | |
42 | + assert_no_match /href=.*\/testinguser\/fifth/, output | |
43 | + end | |
44 | + | |
27 | 45 | end | ... | ... |