DEV: reorganize the specs in context blocks
This commit is contained in:
parent
4af5591985
commit
678b645145
|
@ -329,7 +329,8 @@ describe DiscourseAutomation::Triggers::TOPIC_TAGS_CHANGED do
|
||||||
expect(list.length).to eq(1)
|
expect(list.length).to eq(1)
|
||||||
end
|
end
|
||||||
|
|
||||||
it "should only fire if tag is added if TAGS_ADDED is set" do
|
context "with TAGS_ADDED set in trigger_on field" do
|
||||||
|
it "should fire if tag is added" do
|
||||||
automation.upsert_field!(
|
automation.upsert_field!(
|
||||||
"trigger_on",
|
"trigger_on",
|
||||||
"choices",
|
"choices",
|
||||||
|
@ -348,7 +349,25 @@ describe DiscourseAutomation::Triggers::TOPIC_TAGS_CHANGED do
|
||||||
expect(list[0]["kind"]).to eq(DiscourseAutomation::Triggers::TOPIC_TAGS_CHANGED)
|
expect(list[0]["kind"]).to eq(DiscourseAutomation::Triggers::TOPIC_TAGS_CHANGED)
|
||||||
end
|
end
|
||||||
|
|
||||||
it "should only fire if tag is removed if TAGS_REMOVED is set" do
|
it "should not fire if tag is removed" do
|
||||||
|
automation.upsert_field!(
|
||||||
|
"trigger_on",
|
||||||
|
"choices",
|
||||||
|
{ value: DiscourseAutomation::Triggers::TopicTagsChanged::TriggerOn::TAGS_ADDED },
|
||||||
|
target: "trigger",
|
||||||
|
)
|
||||||
|
|
||||||
|
topic_0 = Fabricate(:topic, user: user, tags: [cool_tag])
|
||||||
|
|
||||||
|
list =
|
||||||
|
capture_contexts { DiscourseTagging.tag_topic_by_names(topic_0, Guardian.new(user), []) }
|
||||||
|
|
||||||
|
expect(list.length).to eq(0)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context "with TAGS_REMOVED set in trigger_on field" do
|
||||||
|
it "should fire if tag is removed" do
|
||||||
automation.upsert_field!(
|
automation.upsert_field!(
|
||||||
"trigger_on",
|
"trigger_on",
|
||||||
"choices",
|
"choices",
|
||||||
|
@ -365,23 +384,7 @@ describe DiscourseAutomation::Triggers::TOPIC_TAGS_CHANGED do
|
||||||
expect(list[0]["kind"]).to eq(DiscourseAutomation::Triggers::TOPIC_TAGS_CHANGED)
|
expect(list[0]["kind"]).to eq(DiscourseAutomation::Triggers::TOPIC_TAGS_CHANGED)
|
||||||
end
|
end
|
||||||
|
|
||||||
it "should not fire if tag is removed and TAGS_ADDED is set" do
|
it "should not fire if tag is added" do
|
||||||
automation.upsert_field!(
|
|
||||||
"trigger_on",
|
|
||||||
"choices",
|
|
||||||
{ value: DiscourseAutomation::Triggers::TopicTagsChanged::TriggerOn::TAGS_ADDED },
|
|
||||||
target: "trigger",
|
|
||||||
)
|
|
||||||
|
|
||||||
topic_0 = Fabricate(:topic, user: user, tags: [cool_tag])
|
|
||||||
|
|
||||||
list =
|
|
||||||
capture_contexts { DiscourseTagging.tag_topic_by_names(topic_0, Guardian.new(user), []) }
|
|
||||||
|
|
||||||
expect(list.length).to eq(0)
|
|
||||||
end
|
|
||||||
|
|
||||||
it "should not fire if tag is added and TAGS_REMOVED is set" do
|
|
||||||
automation.upsert_field!(
|
automation.upsert_field!(
|
||||||
"trigger_on",
|
"trigger_on",
|
||||||
"choices",
|
"choices",
|
||||||
|
@ -400,3 +403,4 @@ describe DiscourseAutomation::Triggers::TOPIC_TAGS_CHANGED do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
Loading…
Reference in New Issue