DEV: Fix a flaky test (#15374)
See: https://github.com/discourse/discourse/runs/4589134998?check_suite_focus=true
This commit is contained in:
parent
76498db7e5
commit
c209be09f1
|
@ -1365,52 +1365,61 @@ RSpec.describe TopicsController do
|
||||||
expect(response.status).to eq(200)
|
expect(response.status).to eq(200)
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'when using SiteSetting.disable_category_edit_notifications or SiteSetting.disable_tags_edit_notifications' do
|
context "when using SiteSetting.disable_category_edit_notifications" do
|
||||||
shared_examples 'a topic bump suppressor' do
|
|
||||||
it "doesn't bump the topic if the setting is enabled" do
|
it "doesn't bump the topic if the setting is enabled" do
|
||||||
enable_setting
|
SiteSetting.disable_category_edit_notifications = true
|
||||||
last_bumped_at = topic.bumped_at
|
last_bumped_at = topic.bumped_at
|
||||||
expect(last_bumped_at).not_to be_nil
|
expect(last_bumped_at).not_to be_nil
|
||||||
|
|
||||||
expect do
|
expect do
|
||||||
put "/t/#{topic.slug}/#{topic.id}.json", params: params
|
put "/t/#{topic.slug}/#{topic.id}.json", params: { category_id: category.id }
|
||||||
end.to change { topic.reload.send(attribute_to_change) }.to(expected_new_value)
|
end.to change { topic.reload.category_id }.to(category.id)
|
||||||
|
|
||||||
expect(response.status).to eq(200)
|
expect(response.status).to eq(200)
|
||||||
expect(topic.reload.bumped_at).to eq_time(last_bumped_at)
|
expect(topic.reload.bumped_at).to eq_time(last_bumped_at)
|
||||||
end
|
end
|
||||||
|
|
||||||
it "bumps the topic if the setting is disabled" do
|
it "bumps the topic if the setting is disabled" do
|
||||||
disable_setting
|
SiteSetting.disable_category_edit_notifications = false
|
||||||
last_bumped_at = topic.bumped_at
|
last_bumped_at = topic.bumped_at
|
||||||
expect(last_bumped_at).not_to be_nil
|
expect(last_bumped_at).not_to be_nil
|
||||||
|
|
||||||
expect do
|
expect do
|
||||||
put "/t/#{topic.slug}/#{topic.id}.json", params: params
|
put "/t/#{topic.slug}/#{topic.id}.json", params: { category_id: category.id }
|
||||||
end.to change { topic.reload.send(attribute_to_change) }.to(expected_new_value)
|
end.to change { topic.reload.category_id }.to(category.id)
|
||||||
|
|
||||||
expect(response.status).to eq(200)
|
expect(response.status).to eq(200)
|
||||||
expect(topic.reload.bumped_at).not_to eq_time(last_bumped_at)
|
expect(topic.reload.bumped_at).not_to eq_time(last_bumped_at)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
it_behaves_like 'a topic bump suppressor' do
|
context "when using SiteSetting.disable_tags_edit_notifications" do
|
||||||
let(:attribute_to_change) { :category_id }
|
|
||||||
let(:expected_new_value) { category.id }
|
|
||||||
let(:params) { { category_id: category.id } }
|
|
||||||
let(:enable_setting) { SiteSetting.disable_category_edit_notifications = true }
|
|
||||||
let(:disable_setting) { SiteSetting.disable_category_edit_notifications = false }
|
|
||||||
end
|
|
||||||
|
|
||||||
it_behaves_like 'a topic bump suppressor' do
|
|
||||||
fab!(:t1) { Fabricate(:tag) }
|
fab!(:t1) { Fabricate(:tag) }
|
||||||
fab!(:t2) { Fabricate(:tag) }
|
fab!(:t2) { Fabricate(:tag) }
|
||||||
let(:tags) { [t1, t2] }
|
let(:tags) { [t1, t2] }
|
||||||
let(:attribute_to_change) { :tags }
|
|
||||||
let(:expected_new_value) { tags }
|
it "doesn't bump the topic if the setting is enabled" do
|
||||||
let(:params) { { tags: tags.map(&:name) } }
|
SiteSetting.disable_tags_edit_notifications = true
|
||||||
let(:enable_setting) { SiteSetting.disable_tags_edit_notifications = true }
|
last_bumped_at = topic.bumped_at
|
||||||
let(:disable_setting) { SiteSetting.disable_tags_edit_notifications = false }
|
expect(last_bumped_at).not_to be_nil
|
||||||
|
|
||||||
|
put "/t/#{topic.slug}/#{topic.id}.json", params: { tags: tags.map(&:name) }
|
||||||
|
|
||||||
|
expect(topic.reload.tags).to match_array(tags)
|
||||||
|
expect(response.status).to eq(200)
|
||||||
|
expect(topic.reload.bumped_at).to eq_time(last_bumped_at)
|
||||||
|
end
|
||||||
|
|
||||||
|
it "bumps the topic if the setting is disabled" do
|
||||||
|
SiteSetting.disable_tags_edit_notifications = false
|
||||||
|
last_bumped_at = topic.bumped_at
|
||||||
|
expect(last_bumped_at).not_to be_nil
|
||||||
|
|
||||||
|
put "/t/#{topic.slug}/#{topic.id}.json", params: { tags: tags.map(&:name) }
|
||||||
|
|
||||||
|
expect(topic.reload.tags).to match_array(tags)
|
||||||
|
expect(response.status).to eq(200)
|
||||||
|
expect(topic.reload.bumped_at).not_to eq_time(last_bumped_at)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue