published_article_test.rb
3.12 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
require File.dirname(__FILE__) + '/../test_helper'
class PublishedArticleTest < ActiveSupport::TestCase
def setup
@profile = create_user('test_user').person
@article = @profile.articles.create!(:name => 'test_article', :body => 'some trivial body')
end
should 'have a reference article and profile' do
prof = Community.create!(:name => 'test_comm', :identifier => 'test_comm')
p = PublishedArticle.create(:reference_article => @article, :profile => prof)
assert p
assert_equal prof, p.profile
assert_equal @article, p.reference_article
end
should 'have same content as reference article' do
prof = Community.create!(:name => 'test_comm', :identifier => 'test_comm')
p = PublishedArticle.create(:reference_article => @article, :profile => prof)
assert_equal @article.body, p.body
end
should 'have a different name than reference article' do
prof = Community.create!(:name => 'test_comm', :identifier => 'test_comm')
p = PublishedArticle.create(:reference_article => @article, :profile => prof, :name => 'other title')
assert_equal 'other title', p.name
assert_not_equal @article.name, p.name
end
should 'use name of reference article a default name' do
prof = Community.create!(:name => 'test_comm', :identifier => 'test_comm')
p = PublishedArticle.create!(:reference_article => @article, :profile => prof)
assert_equal @article.name, p.name
end
should 'not be created in blog if community does not have a blog' do
parent = mock
@article.expects(:parent).returns(parent)
parent.expects(:blog?).returns(true)
prof = Community.create!(:name => 'test_comm', :identifier => 'test_comm')
p = PublishedArticle.create!(:reference_article => @article, :profile => prof)
assert !prof.has_blog?
assert_nil p.parent
end
should 'be created in community blog if came from a blog' do
parent = mock
@article.expects(:parent).returns(parent)
parent.expects(:blog?).returns(true)
prof = Community.create!(:name => 'test_comm', :identifier => 'test_comm')
prof.articles << Blog.new(:profile => prof, :name => 'Blog test')
p = PublishedArticle.create!(:reference_article => @article, :profile => prof)
assert_equal p.parent, prof.blog
end
should 'not be created in community blog if did not come from a blog' do
parent = mock
@article.expects(:parent).returns(parent)
parent.expects(:blog?).returns(false)
prof = Community.create!(:name => 'test_comm', :identifier => 'test_comm')
blog = Blog.create!(:profile => prof, :name => 'Blog test')
p = PublishedArticle.create!(:reference_article => @article, :profile => prof)
assert_nil p.parent
end
should "use author of original article as its author" do
original = Article.new(:last_changed_by => @profile)
community = Community.new
published = PublishedArticle.new(:reference_article => original, :profile => community)
assert_equal @profile, published.author
end
should 'use owning profile as author when there is no referenced article yet' do
assert_equal @profile, PublishedArticle.new(:profile => @profile).author
end
end