Commit 1b4b5b9ef43d960835d1d4077d965095eadf473c
1 parent
4370374c
Exists in
master
and in
29 other branches
ActionItem21: listing hierarchy of filesystem-like items
git-svn-id: https://svn.colivre.coop.br/svn/noosfero/trunk@952 3f533792-8f58-4932-b0fe-aaf55b0a4547
Showing
2 changed files
with
49 additions
and
0 deletions
Show diff stats
lib/acts_as_filesystem.rb
... | ... | @@ -126,6 +126,31 @@ module ActsAsFileSystem |
126 | 126 | def explode_path |
127 | 127 | path.split(/\//) |
128 | 128 | end |
129 | + | |
130 | + # returns the full hierarchy from the top-level item to this one. For | |
131 | + # example, if item1 has a children item2 and item2 has a children item3, | |
132 | + # then item3's hierarchy would be [item1, item2, item3]. | |
133 | + # | |
134 | + # If +reload+ is passed as +true+, then the hierarchy is reload (usefull | |
135 | + # when the ActiveRecord object was modified in some way, or just after | |
136 | + # changing parent) | |
137 | + def hierarchy(reload = false) | |
138 | + if reload | |
139 | + @hierarchy = nil | |
140 | + end | |
141 | + | |
142 | + unless @hierarchy | |
143 | + @hierarchy = [] | |
144 | + item = self | |
145 | + while item | |
146 | + @hierarchy.unshift(item) | |
147 | + item = item.parent | |
148 | + end | |
149 | + end | |
150 | + | |
151 | + @hierarchy | |
152 | + end | |
153 | + | |
129 | 154 | end |
130 | 155 | end |
131 | 156 | ... | ... |
... | ... | @@ -0,0 +1,24 @@ |
1 | +require File.dirname(__FILE__) + '/../test_helper' | |
2 | + | |
3 | +class ActsAsFilesystemTest < Test::Unit::TestCase | |
4 | + | |
5 | + # FIXME shouldn't we test with a non-real model, instead of Article? | |
6 | + | |
7 | + should 'provide a hierarchy list' do | |
8 | + profile = create_user('testinguser').person | |
9 | + | |
10 | + a1 = profile.articles.build(:name => 'a1'); a1.save! | |
11 | + a2 = profile.articles.build(:name => 'a2'); a2.parent = a1; a2.save! | |
12 | + a3 = profile.articles.build(:name => 'a3'); a3.parent = a2; a3.save! | |
13 | + | |
14 | + assert_equal [a1, a2, a3], a3.hierarchy | |
15 | + end | |
16 | + | |
17 | + should 'be able to optionally reload the hierarchy' do | |
18 | + a = Article.new | |
19 | + list = a.hierarchy | |
20 | + assert_same list, a.hierarchy | |
21 | + assert_not_same list, a.hierarchy(true) | |
22 | + end | |
23 | + | |
24 | +end | ... | ... |