DEV: Prefabricate more things in topic_spec.rb (#7490)
* Moved let to more appropriate scopes * Refactored tests It's confusing when let blocks in a parent context depend on other let blocks from a child context. * Moved fabrication to top level * Removed unnecessary user fabrications * Added a trust level 2 user at the top level * Factored out category * Made test use generic user * Prefabricate topic * Cut down redundant users * Prefabricated more things
This commit is contained in:
parent
e20f13ebb7
commit
c7a0baebc5
|
@ -7,7 +7,8 @@ require_dependency 'post_destroyer'
|
||||||
describe Topic do
|
describe Topic do
|
||||||
let(:now) { Time.zone.local(2013, 11, 20, 8, 0) }
|
let(:now) { Time.zone.local(2013, 11, 20, 8, 0) }
|
||||||
fab!(:user) { Fabricate(:user) }
|
fab!(:user) { Fabricate(:user) }
|
||||||
let(:topic) { Fabricate(:topic) }
|
fab!(:another_user) { Fabricate(:user) }
|
||||||
|
fab!(:trust_level_2) { Fabricate(:user, trust_level: TrustLevel[2]) }
|
||||||
|
|
||||||
context 'validations' do
|
context 'validations' do
|
||||||
let(:topic) { Fabricate.build(:topic) }
|
let(:topic) { Fabricate.build(:topic) }
|
||||||
|
@ -122,33 +123,35 @@ describe Topic do
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'slug' do
|
context 'slug' do
|
||||||
let(:title) { "hello world topic" }
|
|
||||||
let(:slug) { "hello-world-topic" }
|
|
||||||
let!(:expected_title) { title.dup }
|
|
||||||
let!(:expected_slug) { slug.dup }
|
|
||||||
let(:topic) { Fabricate.build(:topic, title: title) }
|
|
||||||
|
|
||||||
context 'encoded generator' do
|
context 'encoded generator' do
|
||||||
before { SiteSetting.slug_generation_method = 'encoded' }
|
before { SiteSetting.slug_generation_method = 'encoded' }
|
||||||
|
|
||||||
|
context 'with ascii letters' do
|
||||||
|
let!(:title) { "hello world topic" }
|
||||||
|
let!(:slug) { "hello-world-topic" }
|
||||||
|
let!(:topic) { Fabricate.build(:topic, title: title) }
|
||||||
|
|
||||||
it "returns a Slug for a title" do
|
it "returns a Slug for a title" do
|
||||||
expect(topic.title).to eq(expected_title)
|
expect(topic.title).to eq(title)
|
||||||
expect(topic.slug).to eq(expected_slug)
|
expect(topic.slug).to eq(slug)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'for cjk characters' do
|
context 'for cjk characters' do
|
||||||
let(:title) { "熱帶風暴畫眉" }
|
let!(:title) { "熱帶風暴畫眉" }
|
||||||
let!(:expected_title) { title.dup }
|
let!(:topic) { Fabricate.build(:topic, title: title) }
|
||||||
|
|
||||||
it "returns encoded Slug for a title" do
|
it "returns encoded Slug for a title" do
|
||||||
expect(topic.title).to eq(expected_title)
|
expect(topic.title).to eq(title)
|
||||||
expect(topic.slug).to eq(expected_title)
|
expect(topic.slug).to eq(title)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'for numbers' do
|
context 'for numbers' do
|
||||||
let(:title) { "123456789" }
|
let!(:title) { "123456789" }
|
||||||
let(:slug) { "topic" }
|
let!(:slug) { "topic" }
|
||||||
|
let!(:topic) { Fabricate.build(:topic, title: title) }
|
||||||
|
|
||||||
it 'generates default slug' do
|
it 'generates default slug' do
|
||||||
Slug.expects(:for).with(title).returns("topic")
|
Slug.expects(:for).with(title).returns("topic")
|
||||||
expect(Fabricate.build(:topic, title: title).slug).to eq("topic")
|
expect(Fabricate.build(:topic, title: title).slug).to eq("topic")
|
||||||
|
@ -157,10 +160,11 @@ describe Topic do
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'none generator' do
|
context 'none generator' do
|
||||||
before { SiteSetting.slug_generation_method = 'none' }
|
let!(:title) { "熱帶風暴畫眉" }
|
||||||
|
let!(:slug) { "topic" }
|
||||||
|
let!(:topic) { Fabricate.build(:topic, title: title) }
|
||||||
|
|
||||||
let(:title) { "熱帶風暴畫眉" }
|
before { SiteSetting.slug_generation_method = 'none' }
|
||||||
let(:slug) { "topic" }
|
|
||||||
|
|
||||||
it "returns a Slug for a title" do
|
it "returns a Slug for a title" do
|
||||||
Slug.expects(:for).with(title).returns('topic')
|
Slug.expects(:for).with(title).returns('topic')
|
||||||
|
@ -171,14 +175,21 @@ describe Topic do
|
||||||
context '#ascii_generator' do
|
context '#ascii_generator' do
|
||||||
before { SiteSetting.slug_generation_method = 'ascii' }
|
before { SiteSetting.slug_generation_method = 'ascii' }
|
||||||
|
|
||||||
|
context 'with ascii letters' do
|
||||||
|
let!(:title) { "hello world topic" }
|
||||||
|
let!(:slug) { "hello-world-topic" }
|
||||||
|
let!(:topic) { Fabricate.build(:topic, title: title) }
|
||||||
|
|
||||||
it "returns a Slug for a title" do
|
it "returns a Slug for a title" do
|
||||||
Slug.expects(:for).with(title).returns(slug)
|
Slug.expects(:for).with(title).returns(slug)
|
||||||
expect(Fabricate.build(:topic, title: title).slug).to eq(slug)
|
expect(Fabricate.build(:topic, title: title).slug).to eq(slug)
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
||||||
context 'for cjk characters' do
|
context 'for cjk characters' do
|
||||||
let(:title) { "熱帶風暴畫眉" }
|
let!(:title) { "熱帶風暴畫眉" }
|
||||||
let(:slug) { 'topic' }
|
let!(:slug) { 'topic' }
|
||||||
|
let!(:topic) { Fabricate.build(:topic, title: title) }
|
||||||
|
|
||||||
it "returns 'topic' when the slug is empty (say, non-latin characters)" do
|
it "returns 'topic' when the slug is empty (say, non-latin characters)" do
|
||||||
Slug.expects(:for).with(title).returns("topic")
|
Slug.expects(:for).with(title).returns("topic")
|
||||||
|
@ -379,6 +390,8 @@ describe Topic do
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'category validation' do
|
context 'category validation' do
|
||||||
|
fab!(:category) { Fabricate(:category) }
|
||||||
|
|
||||||
context 'allow_uncategorized_topics is false' do
|
context 'allow_uncategorized_topics is false' do
|
||||||
before do
|
before do
|
||||||
SiteSetting.allow_uncategorized_topics = false
|
SiteSetting.allow_uncategorized_topics = false
|
||||||
|
@ -396,7 +409,7 @@ describe Topic do
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'passes for topics with a category' do
|
it 'passes for topics with a category' do
|
||||||
expect(Fabricate.build(:topic, category: Fabricate(:category))).to be_valid
|
expect(Fabricate.build(:topic, category: category)).to be_valid
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -410,7 +423,7 @@ describe Topic do
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'passes for topics with a category' do
|
it 'passes for topics with a category' do
|
||||||
expect(Fabricate.build(:topic, category: Fabricate(:category))).to be_valid
|
expect(Fabricate.build(:topic, category: category)).to be_valid
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -441,7 +454,7 @@ describe Topic do
|
||||||
end
|
end
|
||||||
|
|
||||||
context "secure categories" do
|
context "secure categories" do
|
||||||
let(:category) { Fabricate(:category, read_restricted: true) }
|
fab!(:category) { Fabricate(:category, read_restricted: true) }
|
||||||
|
|
||||||
before do
|
before do
|
||||||
topic.category = category
|
topic.category = category
|
||||||
|
@ -478,8 +491,7 @@ describe Topic do
|
||||||
end
|
end
|
||||||
|
|
||||||
describe '#invite' do
|
describe '#invite' do
|
||||||
let(:topic) { Fabricate(:topic, user: user) }
|
fab!(:topic) { Fabricate(:topic, user: user) }
|
||||||
let(:another_user) { Fabricate(:user) }
|
|
||||||
|
|
||||||
context 'rate limits' do
|
context 'rate limits' do
|
||||||
before do
|
before do
|
||||||
|
@ -496,7 +508,6 @@ describe Topic do
|
||||||
start = Time.now.tomorrow.beginning_of_day
|
start = Time.now.tomorrow.beginning_of_day
|
||||||
freeze_time(start)
|
freeze_time(start)
|
||||||
|
|
||||||
trust_level_2 = Fabricate(:user, trust_level: 2)
|
|
||||||
topic = Fabricate(:topic, user: trust_level_2)
|
topic = Fabricate(:topic, user: trust_level_2)
|
||||||
|
|
||||||
topic.invite(topic.user, user.username)
|
topic.invite(topic.user, user.username)
|
||||||
|
@ -510,7 +521,6 @@ describe Topic do
|
||||||
start = Time.now.tomorrow.beginning_of_day
|
start = Time.now.tomorrow.beginning_of_day
|
||||||
freeze_time(start)
|
freeze_time(start)
|
||||||
|
|
||||||
trust_level_2 = Fabricate(:user, trust_level: 2)
|
|
||||||
topic = Fabricate(:private_message_topic, user: trust_level_2)
|
topic = Fabricate(:private_message_topic, user: trust_level_2)
|
||||||
|
|
||||||
topic.invite(topic.user, user.username)
|
topic.invite(topic.user, user.username)
|
||||||
|
@ -539,8 +549,8 @@ describe Topic do
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'private message' do
|
describe 'private message' do
|
||||||
let(:user) { Fabricate(:user, trust_level: TrustLevel[2]) }
|
fab!(:user) { trust_level_2 }
|
||||||
let(:topic) { Fabricate(:private_message_topic, user: user) }
|
fab!(:topic) { Fabricate(:private_message_topic, user: trust_level_2) }
|
||||||
|
|
||||||
describe 'by username' do
|
describe 'by username' do
|
||||||
it 'should be able to invite a user' do
|
it 'should be able to invite a user' do
|
||||||
|
@ -643,18 +653,18 @@ describe Topic do
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'when topic belongs to a private category' do
|
describe 'when topic belongs to a private category' do
|
||||||
let(:group) { Fabricate(:group) }
|
fab!(:group) { Fabricate(:group) }
|
||||||
|
|
||||||
let(:category) do
|
fab!(:category) do
|
||||||
Fabricate(:category, groups: [group]).tap do |category|
|
Fabricate(:category, groups: [group]).tap do |category|
|
||||||
category.set_permissions(group => :full)
|
category.set_permissions(group => :full)
|
||||||
category.save!
|
category.save!
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
let(:topic) { Fabricate(:topic, category: category) }
|
fab!(:topic) { Fabricate(:topic, category: category) }
|
||||||
let(:inviter) { Fabricate(:user).tap { |user| group.add_owner(user) } }
|
let(:inviter) { Fabricate(:user).tap { |user| group.add_owner(user) } }
|
||||||
let(:invitee) { Fabricate(:user) }
|
fab!(:invitee) { Fabricate(:user) }
|
||||||
|
|
||||||
describe 'as a group owner' do
|
describe 'as a group owner' do
|
||||||
it 'should be able to invite a user' do
|
it 'should be able to invite a user' do
|
||||||
|
@ -724,7 +734,7 @@ describe Topic do
|
||||||
|
|
||||||
context 'private message' do
|
context 'private message' do
|
||||||
let(:coding_horror) { User.find_by(username: "CodingHorror") }
|
let(:coding_horror) { User.find_by(username: "CodingHorror") }
|
||||||
let(:evil_trout) { Fabricate(:evil_trout) }
|
fab!(:evil_trout) { Fabricate(:evil_trout) }
|
||||||
let(:topic) { Fabricate(:private_message_topic) }
|
let(:topic) { Fabricate(:private_message_topic) }
|
||||||
|
|
||||||
it "should integrate correctly" do
|
it "should integrate correctly" do
|
||||||
|
@ -740,7 +750,7 @@ describe Topic do
|
||||||
context 'existing user' do
|
context 'existing user' do
|
||||||
|
|
||||||
context 'by group name' do
|
context 'by group name' do
|
||||||
let(:group) { Fabricate(:group) }
|
fab!(:group) { Fabricate(:group) }
|
||||||
|
|
||||||
it 'can add admin to allowed groups' do
|
it 'can add admin to allowed groups' do
|
||||||
admins = Group[:admins]
|
admins = Group[:admins]
|
||||||
|
@ -784,12 +794,12 @@ describe Topic do
|
||||||
it "should set up actions correctly" do
|
it "should set up actions correctly" do
|
||||||
UserActionManager.enable
|
UserActionManager.enable
|
||||||
|
|
||||||
post = create_post(archetype: 'private_message', target_usernames: [Fabricate(:coding_horror).username])
|
post = create_post(archetype: 'private_message', target_usernames: [user.username])
|
||||||
actions = post.user.user_actions
|
actions = post.user.user_actions
|
||||||
|
|
||||||
expect(actions.map { |a| a.action_type }).not_to include(UserAction::NEW_TOPIC)
|
expect(actions.map { |a| a.action_type }).not_to include(UserAction::NEW_TOPIC)
|
||||||
expect(actions.map { |a| a.action_type }).to include(UserAction::NEW_PRIVATE_MESSAGE)
|
expect(actions.map { |a| a.action_type }).to include(UserAction::NEW_PRIVATE_MESSAGE)
|
||||||
expect(coding_horror.user_actions.map { |a| a.action_type }).to include(UserAction::GOT_PRIVATE_MESSAGE)
|
expect(user.user_actions.map { |a| a.action_type }).to include(UserAction::GOT_PRIVATE_MESSAGE)
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
@ -797,60 +807,57 @@ describe Topic do
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'bumping topics' do
|
context 'bumping topics' do
|
||||||
|
let!(:topic) { Fabricate(:topic, bumped_at: 1.year.ago) }
|
||||||
before do
|
|
||||||
@topic = Fabricate(:topic, bumped_at: 1.year.ago)
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'updates the bumped_at field when a new post is made' do
|
it 'updates the bumped_at field when a new post is made' do
|
||||||
expect(@topic.bumped_at).to be_present
|
expect(topic.bumped_at).to be_present
|
||||||
expect {
|
expect {
|
||||||
create_post(topic: @topic, user: @topic.user)
|
create_post(topic: topic, user: topic.user)
|
||||||
@topic.reload
|
topic.reload
|
||||||
}.to change(@topic, :bumped_at)
|
}.to change(topic, :bumped_at)
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'editing posts' do
|
context 'editing posts' do
|
||||||
before do
|
before do
|
||||||
@earlier_post = Fabricate(:post, topic: @topic, user: @topic.user)
|
@earlier_post = Fabricate(:post, topic: topic, user: topic.user)
|
||||||
@last_post = Fabricate(:post, topic: @topic, user: @topic.user)
|
@last_post = Fabricate(:post, topic: topic, user: topic.user)
|
||||||
@topic.reload
|
topic.reload
|
||||||
end
|
end
|
||||||
|
|
||||||
it "doesn't bump the topic on an edit to the last post that doesn't result in a new version" do
|
it "doesn't bump the topic on an edit to the last post that doesn't result in a new version" do
|
||||||
expect {
|
expect {
|
||||||
SiteSetting.editing_grace_period = 5.minutes
|
SiteSetting.editing_grace_period = 5.minutes
|
||||||
@last_post.revise(@last_post.user, { raw: @last_post.raw + "a" }, revised_at: @last_post.created_at + 10.seconds)
|
@last_post.revise(@last_post.user, { raw: @last_post.raw + "a" }, revised_at: @last_post.created_at + 10.seconds)
|
||||||
@topic.reload
|
topic.reload
|
||||||
}.not_to change(@topic, :bumped_at)
|
}.not_to change(topic, :bumped_at)
|
||||||
end
|
end
|
||||||
|
|
||||||
it "bumps the topic when a new version is made of the last post" do
|
it "bumps the topic when a new version is made of the last post" do
|
||||||
expect {
|
expect {
|
||||||
@last_post.revise(Fabricate(:moderator), raw: 'updated contents')
|
@last_post.revise(Fabricate(:moderator), raw: 'updated contents')
|
||||||
@topic.reload
|
topic.reload
|
||||||
}.to change(@topic, :bumped_at)
|
}.to change(topic, :bumped_at)
|
||||||
end
|
end
|
||||||
|
|
||||||
it "doesn't bump the topic when a post that isn't the last post receives a new version" do
|
it "doesn't bump the topic when a post that isn't the last post receives a new version" do
|
||||||
expect {
|
expect {
|
||||||
@earlier_post.revise(Fabricate(:moderator), raw: 'updated contents')
|
@earlier_post.revise(Fabricate(:moderator), raw: 'updated contents')
|
||||||
@topic.reload
|
topic.reload
|
||||||
}.not_to change(@topic, :bumped_at)
|
}.not_to change(topic, :bumped_at)
|
||||||
end
|
end
|
||||||
|
|
||||||
it "doesn't bump the topic when a post have invalid topic title while edit" do
|
it "doesn't bump the topic when a post have invalid topic title while edit" do
|
||||||
expect {
|
expect {
|
||||||
@last_post.revise(Fabricate(:moderator), title: 'invalid title')
|
@last_post.revise(Fabricate(:moderator), title: 'invalid title')
|
||||||
@topic.reload
|
topic.reload
|
||||||
}.not_to change(@topic, :bumped_at)
|
}.not_to change(topic, :bumped_at)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'moderator posts' do
|
context 'moderator posts' do
|
||||||
let(:moderator) { Fabricate(:moderator) }
|
fab!(:moderator) { Fabricate(:moderator) }
|
||||||
let(:topic) { Fabricate(:topic) }
|
fab!(:topic) { Fabricate(:topic) }
|
||||||
|
|
||||||
it 'creates a moderator post' do
|
it 'creates a moderator post' do
|
||||||
mod_post = topic.add_moderator_post(
|
mod_post = topic.add_moderator_post(
|
||||||
|
@ -883,39 +890,39 @@ describe Topic do
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'update_status' do
|
context 'update_status' do
|
||||||
|
fab!(:topic) { Fabricate(:topic, bumped_at: 1.hour.ago) }
|
||||||
|
|
||||||
before do
|
before do
|
||||||
@topic = Fabricate(:topic, bumped_at: 1.hour.ago)
|
@original_bumped_at = topic.bumped_at.to_f
|
||||||
@topic.reload
|
@user = topic.user
|
||||||
@original_bumped_at = @topic.bumped_at.to_f
|
|
||||||
@user = @topic.user
|
|
||||||
@user.admin = true
|
@user.admin = true
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'visibility' do
|
context 'visibility' do
|
||||||
context 'disable' do
|
context 'disable' do
|
||||||
before do
|
before do
|
||||||
@topic.update_status('visible', false, @user)
|
topic.update_status('visible', false, @user)
|
||||||
@topic.reload
|
topic.reload
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should not be visible and have correct counts' do
|
it 'should not be visible and have correct counts' do
|
||||||
expect(@topic).not_to be_visible
|
expect(topic).not_to be_visible
|
||||||
expect(@topic.moderator_posts_count).to eq(1)
|
expect(topic.moderator_posts_count).to eq(1)
|
||||||
expect(@topic.bumped_at.to_f).to eq(@original_bumped_at)
|
expect(topic.bumped_at.to_f).to eq(@original_bumped_at)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'enable' do
|
context 'enable' do
|
||||||
before do
|
before do
|
||||||
@topic.update_attribute :visible, false
|
topic.update_attribute :visible, false
|
||||||
@topic.update_status('visible', true, @user)
|
topic.update_status('visible', true, @user)
|
||||||
@topic.reload
|
topic.reload
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should be visible with correct counts' do
|
it 'should be visible with correct counts' do
|
||||||
expect(@topic).to be_visible
|
expect(topic).to be_visible
|
||||||
expect(@topic.moderator_posts_count).to eq(1)
|
expect(topic.moderator_posts_count).to eq(1)
|
||||||
expect(@topic.bumped_at.to_f).to eq(@original_bumped_at)
|
expect(topic.bumped_at.to_f).to eq(@original_bumped_at)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -923,28 +930,28 @@ describe Topic do
|
||||||
context 'pinned' do
|
context 'pinned' do
|
||||||
context 'disable' do
|
context 'disable' do
|
||||||
before do
|
before do
|
||||||
@topic.update_status('pinned', false, @user)
|
topic.update_status('pinned', false, @user)
|
||||||
@topic.reload
|
topic.reload
|
||||||
end
|
end
|
||||||
|
|
||||||
it "doesn't have a pinned_at but has correct dates" do
|
it "doesn't have a pinned_at but has correct dates" do
|
||||||
expect(@topic.pinned_at).to be_blank
|
expect(topic.pinned_at).to be_blank
|
||||||
expect(@topic.moderator_posts_count).to eq(1)
|
expect(topic.moderator_posts_count).to eq(1)
|
||||||
expect(@topic.bumped_at.to_f).to eq(@original_bumped_at)
|
expect(topic.bumped_at.to_f).to eq(@original_bumped_at)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'enable' do
|
context 'enable' do
|
||||||
before do
|
before do
|
||||||
@topic.update_attribute :pinned_at, nil
|
topic.update_attribute :pinned_at, nil
|
||||||
@topic.update_status('pinned', true, @user)
|
topic.update_status('pinned', true, @user)
|
||||||
@topic.reload
|
topic.reload
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should enable correctly' do
|
it 'should enable correctly' do
|
||||||
expect(@topic.pinned_at).to be_present
|
expect(topic.pinned_at).to be_present
|
||||||
expect(@topic.bumped_at.to_f).to eq(@original_bumped_at)
|
expect(topic.bumped_at.to_f).to eq(@original_bumped_at)
|
||||||
expect(@topic.moderator_posts_count).to eq(1)
|
expect(topic.moderator_posts_count).to eq(1)
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
@ -968,15 +975,15 @@ describe Topic do
|
||||||
|
|
||||||
context 'enable' do
|
context 'enable' do
|
||||||
before do
|
before do
|
||||||
@topic.update_attribute :archived, false
|
topic.update_attribute :archived, false
|
||||||
@topic.update_status('archived', true, @user)
|
topic.update_status('archived', true, @user)
|
||||||
@topic.reload
|
topic.reload
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should be archived' do
|
it 'should be archived' do
|
||||||
expect(@topic).to be_archived
|
expect(topic).to be_archived
|
||||||
expect(@topic.moderator_posts_count).to eq(1)
|
expect(topic.moderator_posts_count).to eq(1)
|
||||||
expect(@topic.bumped_at.to_f).to eq(@original_bumped_at)
|
expect(topic.bumped_at.to_f).to eq(@original_bumped_at)
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
@ -1001,16 +1008,16 @@ describe Topic do
|
||||||
|
|
||||||
context 'enable' do
|
context 'enable' do
|
||||||
before do
|
before do
|
||||||
@topic.update_attribute :closed, false
|
topic.update_attribute :closed, false
|
||||||
@topic.update_status(status, true, @user)
|
topic.update_status(status, true, @user)
|
||||||
@topic.reload
|
topic.reload
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should be closed' do
|
it 'should be closed' do
|
||||||
expect(@topic).to be_closed
|
expect(topic).to be_closed
|
||||||
expect(@topic.bumped_at.to_f).to eq(@original_bumped_at)
|
expect(topic.bumped_at.to_f).to eq(@original_bumped_at)
|
||||||
expect(@topic.moderator_posts_count).to eq(1)
|
expect(topic.moderator_posts_count).to eq(1)
|
||||||
expect(@topic.topic_timers.first).to eq(nil)
|
expect(topic.topic_timers.first).to eq(nil)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -1027,9 +1034,9 @@ describe Topic do
|
||||||
context 'topic was set to close when it was created' do
|
context 'topic was set to close when it was created' do
|
||||||
it 'includes the autoclose duration in the moderator post' do
|
it 'includes the autoclose duration in the moderator post' do
|
||||||
freeze_time(Time.new(2000, 1, 1))
|
freeze_time(Time.new(2000, 1, 1))
|
||||||
@topic.created_at = 3.days.ago
|
topic.created_at = 3.days.ago
|
||||||
@topic.update_status(status, true, @user)
|
topic.update_status(status, true, @user)
|
||||||
expect(@topic.posts.last.raw).to include "closed after 3 days"
|
expect(topic.posts.last.raw).to include "closed after 3 days"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -1037,17 +1044,17 @@ describe Topic do
|
||||||
it 'includes the autoclose duration in the moderator post' do
|
it 'includes the autoclose duration in the moderator post' do
|
||||||
freeze_time(Time.new(2000, 1, 1))
|
freeze_time(Time.new(2000, 1, 1))
|
||||||
|
|
||||||
@topic.created_at = 7.days.ago
|
topic.created_at = 7.days.ago
|
||||||
|
|
||||||
freeze_time(2.days.ago)
|
freeze_time(2.days.ago)
|
||||||
|
|
||||||
@topic.set_or_create_timer(TopicTimer.types[:close], 48)
|
topic.set_or_create_timer(TopicTimer.types[:close], 48)
|
||||||
@topic.save!
|
topic.save!
|
||||||
|
|
||||||
freeze_time(2.days.from_now)
|
freeze_time(2.days.from_now)
|
||||||
|
|
||||||
@topic.update_status(status, true, @user)
|
topic.update_status(status, true, @user)
|
||||||
expect(@topic.posts.last.raw).to include "closed after 2 days"
|
expect(topic.posts.last.raw).to include "closed after 2 days"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -1055,8 +1062,8 @@ describe Topic do
|
||||||
|
|
||||||
describe "banner" do
|
describe "banner" do
|
||||||
|
|
||||||
let(:topic) { Fabricate(:topic) }
|
fab!(:topic) { Fabricate(:topic) }
|
||||||
let(:user) { topic.user }
|
fab!(:user) { topic.user }
|
||||||
let(:banner) { { html: "<p>BANNER</p>", url: topic.url, key: topic.id } }
|
let(:banner) { { html: "<p>BANNER</p>", url: topic.url, key: topic.id } }
|
||||||
|
|
||||||
before { topic.stubs(:banner).returns(banner) }
|
before { topic.stubs(:banner).returns(banner) }
|
||||||
|
@ -1155,7 +1162,7 @@ describe Topic do
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'meta data' do
|
describe 'meta data' do
|
||||||
let(:topic) { Fabricate(:topic, meta_data: { 'hello' => 'world' }) }
|
fab!(:topic) { Fabricate(:topic, meta_data: { 'hello' => 'world' }) }
|
||||||
|
|
||||||
it 'allows us to create a topic with meta data' do
|
it 'allows us to create a topic with meta data' do
|
||||||
expect(topic.meta_data['hello']).to eq('world')
|
expect(topic.meta_data['hello']).to eq('world')
|
||||||
|
@ -1206,7 +1213,7 @@ describe Topic do
|
||||||
|
|
||||||
describe 'after create' do
|
describe 'after create' do
|
||||||
|
|
||||||
let(:topic) { Fabricate(:topic) }
|
fab!(:topic) { Fabricate(:topic) }
|
||||||
|
|
||||||
it 'is a regular topic by default' do
|
it 'is a regular topic by default' do
|
||||||
expect(topic.archetype).to eq(Archetype.default)
|
expect(topic.archetype).to eq(Archetype.default)
|
||||||
|
@ -1228,9 +1235,9 @@ describe Topic do
|
||||||
end
|
end
|
||||||
|
|
||||||
describe '#change_category_to_id' do
|
describe '#change_category_to_id' do
|
||||||
let(:topic) { Fabricate(:topic) }
|
fab!(:topic) { Fabricate(:topic) }
|
||||||
let(:user) { topic.user }
|
fab!(:user) { topic.user }
|
||||||
let(:category) { Fabricate(:category, user: user) }
|
fab!(:category) { Fabricate(:category, user: user) }
|
||||||
|
|
||||||
describe 'without a previous category' do
|
describe 'without a previous category' do
|
||||||
it 'changes the category' do
|
it 'changes the category' do
|
||||||
|
@ -1274,8 +1281,7 @@ describe Topic do
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'to a different category' do
|
describe 'to a different category' do
|
||||||
let(:new_category) { Fabricate(:category, user: user, name: '2nd category') }
|
fab!(:new_category) { Fabricate(:category, user: user, name: '2nd category') }
|
||||||
let(:another_user) { Fabricate(:user) }
|
|
||||||
|
|
||||||
it 'should work' do
|
it 'should work' do
|
||||||
topic.change_category_to_id(new_category.id)
|
topic.change_category_to_id(new_category.id)
|
||||||
|
@ -1415,10 +1421,10 @@ describe Topic do
|
||||||
describe '#by_most_recently_created' do
|
describe '#by_most_recently_created' do
|
||||||
it 'returns topics ordered by created_at desc, id desc' do
|
it 'returns topics ordered by created_at desc, id desc' do
|
||||||
now = Time.now
|
now = Time.now
|
||||||
a = Fabricate(:topic, created_at: now - 2.minutes)
|
a = Fabricate(:topic, user: user, created_at: now - 2.minutes)
|
||||||
b = Fabricate(:topic, created_at: now)
|
b = Fabricate(:topic, user: user, created_at: now)
|
||||||
c = Fabricate(:topic, created_at: now)
|
c = Fabricate(:topic, user: user, created_at: now)
|
||||||
d = Fabricate(:topic, created_at: now - 2.minutes)
|
d = Fabricate(:topic, user: user, created_at: now - 2.minutes)
|
||||||
expect(Topic.by_newest).to eq([c, b, d, a])
|
expect(Topic.by_newest).to eq([c, b, d, a])
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -1426,11 +1432,11 @@ describe Topic do
|
||||||
describe '#created_since' do
|
describe '#created_since' do
|
||||||
it 'returns topics created after some date' do
|
it 'returns topics created after some date' do
|
||||||
now = Time.now
|
now = Time.now
|
||||||
a = Fabricate(:topic, created_at: now - 2.minutes)
|
a = Fabricate(:topic, user: user, created_at: now - 2.minutes)
|
||||||
b = Fabricate(:topic, created_at: now - 1.minute)
|
b = Fabricate(:topic, user: user, created_at: now - 1.minute)
|
||||||
c = Fabricate(:topic, created_at: now)
|
c = Fabricate(:topic, user: user, created_at: now)
|
||||||
d = Fabricate(:topic, created_at: now + 1.minute)
|
d = Fabricate(:topic, user: user, created_at: now + 1.minute)
|
||||||
e = Fabricate(:topic, created_at: now + 2.minutes)
|
e = Fabricate(:topic, user: user, created_at: now + 2.minutes)
|
||||||
expect(Topic.created_since(now)).not_to include a
|
expect(Topic.created_since(now)).not_to include a
|
||||||
expect(Topic.created_since(now)).not_to include b
|
expect(Topic.created_since(now)).not_to include b
|
||||||
expect(Topic.created_since(now)).not_to include c
|
expect(Topic.created_since(now)).not_to include c
|
||||||
|
@ -1441,9 +1447,9 @@ describe Topic do
|
||||||
|
|
||||||
describe '#visible' do
|
describe '#visible' do
|
||||||
it 'returns topics set as visible' do
|
it 'returns topics set as visible' do
|
||||||
a = Fabricate(:topic, visible: false)
|
a = Fabricate(:topic, user: user, visible: false)
|
||||||
b = Fabricate(:topic, visible: true)
|
b = Fabricate(:topic, user: user, visible: true)
|
||||||
c = Fabricate(:topic, visible: true)
|
c = Fabricate(:topic, user: user, visible: true)
|
||||||
expect(Topic.visible).not_to include a
|
expect(Topic.visible).not_to include a
|
||||||
expect(Topic.visible).to include b
|
expect(Topic.visible).to include b
|
||||||
expect(Topic.visible).to include c
|
expect(Topic.visible).to include c
|
||||||
|
@ -1456,9 +1462,9 @@ describe Topic do
|
||||||
c2 = Fabricate(:category, parent_category_id: c1.id)
|
c2 = Fabricate(:category, parent_category_id: c1.id)
|
||||||
c3 = Fabricate(:category)
|
c3 = Fabricate(:category)
|
||||||
|
|
||||||
t1 = Fabricate(:topic, category_id: c1.id)
|
t1 = Fabricate(:topic, user: user, category_id: c1.id)
|
||||||
t2 = Fabricate(:topic, category_id: c2.id)
|
t2 = Fabricate(:topic, user: user, category_id: c2.id)
|
||||||
t3 = Fabricate(:topic, category_id: c3.id)
|
t3 = Fabricate(:topic, user: user, category_id: c3.id)
|
||||||
|
|
||||||
expect(Topic.in_category_and_subcategories(c1.id)).not_to include(t3)
|
expect(Topic.in_category_and_subcategories(c1.id)).not_to include(t3)
|
||||||
expect(Topic.in_category_and_subcategories(c1.id)).to include(t2)
|
expect(Topic.in_category_and_subcategories(c1.id)).to include(t2)
|
||||||
|
@ -1468,8 +1474,6 @@ describe Topic do
|
||||||
end
|
end
|
||||||
|
|
||||||
describe '#private_topic_timer' do
|
describe '#private_topic_timer' do
|
||||||
let(:user) { Fabricate(:user) }
|
|
||||||
|
|
||||||
let(:topic_timer) do
|
let(:topic_timer) do
|
||||||
Fabricate(:topic_timer,
|
Fabricate(:topic_timer,
|
||||||
public_type: false,
|
public_type: false,
|
||||||
|
@ -1490,8 +1494,8 @@ describe Topic do
|
||||||
Fabricate(:topic_timer, execute_at: 5.hours.from_now).topic
|
Fabricate(:topic_timer, execute_at: 5.hours.from_now).topic
|
||||||
end
|
end
|
||||||
|
|
||||||
let(:admin) { Fabricate(:admin) }
|
fab!(:admin) { Fabricate(:admin) }
|
||||||
let(:trust_level_4) { Fabricate(:trust_level_4) }
|
fab!(:trust_level_4) { Fabricate(:trust_level_4) }
|
||||||
|
|
||||||
it 'can take a number of hours as an integer' do
|
it 'can take a number of hours as an integer' do
|
||||||
freeze_time now
|
freeze_time now
|
||||||
|
@ -1634,9 +1638,9 @@ describe Topic do
|
||||||
end
|
end
|
||||||
|
|
||||||
describe "private status type" do
|
describe "private status type" do
|
||||||
let(:topic) { Fabricate(:topic) }
|
fab!(:topic) { Fabricate(:topic) }
|
||||||
let(:reminder) { Fabricate(:topic_timer, user: admin, topic: topic, status_type: TopicTimer.types[:reminder]) }
|
let(:reminder) { Fabricate(:topic_timer, user: admin, topic: topic, status_type: TopicTimer.types[:reminder]) }
|
||||||
let(:other_admin) { Fabricate(:admin) }
|
fab!(:other_admin) { Fabricate(:admin) }
|
||||||
|
|
||||||
it "lets two users have their own record" do
|
it "lets two users have their own record" do
|
||||||
reminder
|
reminder
|
||||||
|
@ -1699,6 +1703,7 @@ describe Topic do
|
||||||
end
|
end
|
||||||
|
|
||||||
it "doesn't return topics that a user has muted" do
|
it "doesn't return topics that a user has muted" do
|
||||||
|
topic = Fabricate(:topic)
|
||||||
user = Fabricate(:user)
|
user = Fabricate(:user)
|
||||||
|
|
||||||
Fabricate(:topic_user,
|
Fabricate(:topic_user,
|
||||||
|
@ -1828,12 +1833,12 @@ describe Topic do
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'all_allowed_users' do
|
describe 'all_allowed_users' do
|
||||||
let(:group) { Fabricate(:group) }
|
fab!(:group) { Fabricate(:group) }
|
||||||
let(:topic) { Fabricate(:topic, allowed_groups: [group]) }
|
fab!(:topic) { Fabricate(:topic, allowed_groups: [group]) }
|
||||||
let!(:allowed_user) { Fabricate(:user) }
|
fab!(:allowed_user) { Fabricate(:user) }
|
||||||
let!(:allowed_group_user) { Fabricate(:user) }
|
fab!(:allowed_group_user) { Fabricate(:user) }
|
||||||
let!(:moderator) { Fabricate(:user, moderator: true) }
|
fab!(:moderator) { Fabricate(:user, moderator: true) }
|
||||||
let!(:rando) { Fabricate(:user) }
|
fab!(:rando) { Fabricate(:user) }
|
||||||
|
|
||||||
before do
|
before do
|
||||||
topic.allowed_users << allowed_user
|
topic.allowed_users << allowed_user
|
||||||
|
@ -1913,8 +1918,8 @@ describe Topic do
|
||||||
|
|
||||||
describe 'trash!' do
|
describe 'trash!' do
|
||||||
context "its category's topic count" do
|
context "its category's topic count" do
|
||||||
let(:moderator) { Fabricate(:moderator) }
|
fab!(:moderator) { Fabricate(:moderator) }
|
||||||
let(:category) { Fabricate(:category) }
|
fab!(:category) { Fabricate(:category) }
|
||||||
|
|
||||||
it "subtracts 1 if topic is being deleted" do
|
it "subtracts 1 if topic is being deleted" do
|
||||||
topic = Fabricate(:topic, category: category)
|
topic = Fabricate(:topic, category: category)
|
||||||
|
@ -1939,7 +1944,7 @@ describe Topic do
|
||||||
|
|
||||||
describe 'recover!' do
|
describe 'recover!' do
|
||||||
context "its category's topic count" do
|
context "its category's topic count" do
|
||||||
let(:category) { Fabricate(:category) }
|
fab!(:category) { Fabricate(:category) }
|
||||||
|
|
||||||
it "adds 1 if topic is deleted" do
|
it "adds 1 if topic is deleted" do
|
||||||
topic = Fabricate(:topic, category: category, deleted_at: 1.day.ago)
|
topic = Fabricate(:topic, category: category, deleted_at: 1.day.ago)
|
||||||
|
@ -2140,7 +2145,7 @@ describe Topic do
|
||||||
|
|
||||||
context 'featured link' do
|
context 'featured link' do
|
||||||
before { SiteSetting.topic_featured_link_enabled = true }
|
before { SiteSetting.topic_featured_link_enabled = true }
|
||||||
let(:topic) { Fabricate(:topic) }
|
fab!(:topic) { Fabricate(:topic) }
|
||||||
|
|
||||||
it 'can validate featured link' do
|
it 'can validate featured link' do
|
||||||
topic.featured_link = ' invalid string'
|
topic.featured_link = ' invalid string'
|
||||||
|
@ -2158,7 +2163,7 @@ describe Topic do
|
||||||
|
|
||||||
context 'when category restricts present' do
|
context 'when category restricts present' do
|
||||||
let!(:link_category) { Fabricate(:link_category) }
|
let!(:link_category) { Fabricate(:link_category) }
|
||||||
let(:topic) { Fabricate(:topic) }
|
fab!(:topic) { Fabricate(:topic) }
|
||||||
let(:link_topic) { Fabricate(:topic, category: link_category) }
|
let(:link_topic) { Fabricate(:topic, category: link_category) }
|
||||||
|
|
||||||
it 'can save the featured link if it belongs to that category' do
|
it 'can save the featured link if it belongs to that category' do
|
||||||
|
@ -2277,7 +2282,6 @@ describe Topic do
|
||||||
|
|
||||||
describe '#pm_with_non_human_user?' do
|
describe '#pm_with_non_human_user?' do
|
||||||
let(:robot) { Fabricate(:user, id: -3) }
|
let(:robot) { Fabricate(:user, id: -3) }
|
||||||
let(:user) { Fabricate(:user) }
|
|
||||||
|
|
||||||
let(:topic) do
|
let(:topic) do
|
||||||
topic = Fabricate(:private_message_topic,
|
topic = Fabricate(:private_message_topic,
|
||||||
|
@ -2331,7 +2335,7 @@ describe Topic do
|
||||||
end
|
end
|
||||||
|
|
||||||
describe '#remove_allowed_user' do
|
describe '#remove_allowed_user' do
|
||||||
let(:another_user) { Fabricate(:user) }
|
fab!(:topic) { Fabricate(:topic) }
|
||||||
|
|
||||||
describe 'removing oneself' do
|
describe 'removing oneself' do
|
||||||
it 'should remove onself' do
|
it 'should remove onself' do
|
||||||
|
|
Loading…
Reference in New Issue