-
Notifications
You must be signed in to change notification settings - Fork 43
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Redirect to root controller or legacy root controller based design_sy…
…stem_publications_filter switch
- Loading branch information
1 parent
e933c78
commit 7488b66
Showing
3 changed files
with
155 additions
and
8 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,116 @@ | ||
require "integration_test_helper" | ||
|
||
class GetContentByContentIdTest < IntegrationTest | ||
def setup | ||
login_as_stub_user | ||
@artefact = FactoryBot.create(:artefact, name: "browser extension test") | ||
@test_strategy = Flipflop::FeatureSet.current.test! | ||
end | ||
|
||
context "design_system_publications_filter switch is enabled" do | ||
setup do | ||
@test_strategy.switch!(:design_system_publications_filter, true) | ||
end | ||
|
||
should "show only one edition when content item has only one draft edition" do | ||
create_draft_edition | ||
visit "by-content-id/#{@draft_edition.content_id}" | ||
|
||
assert_content("1 document(s)") | ||
assert page.has_content?("answer edition") | ||
end | ||
|
||
should "show only one edition when content item has only one published edition" do | ||
create_published_edition | ||
visit "by-content-id/#{@published_edition.content_id}" | ||
|
||
assert_content("1 document(s)") | ||
assert page.has_content?("answer edition") | ||
end | ||
|
||
should "show two editions when content item has one published and one draft edition" do | ||
create_published_edition | ||
create_draft_edition | ||
visit "by-content-id/#{@published_edition.content_id}" | ||
|
||
assert_content("2 document(s)") | ||
assert page.has_content?("answer edition") | ||
end | ||
end | ||
|
||
context "design_system_publications_filter switch is disabled" do | ||
setup do | ||
@test_strategy.switch!(:design_system_publications_filter, false) | ||
end | ||
|
||
context "Content items that have only one edition, in the draft state" do | ||
should "show main list as empty and 'filter by status' counts as all zero except for 'Drafts'" do | ||
filter_by_status = ["Filter by Status", "Drafts 1", "In review 0", "Amends needed 0", "Out for fact check 0", "Fact check received 0", "Ready 0", "Scheduled 0", "Published 0", "Archived 0"] | ||
create_draft_edition | ||
visit "by-content-id/#{@draft_edition.content_id}" | ||
|
||
sidebar_filter_by_status = find_all(".nav-list")[0] | ||
within sidebar_filter_by_status do | ||
statuses = find_all("li") | ||
statuses.each do |status| | ||
assert filter_by_status.include?(status.text) | ||
end | ||
end | ||
|
||
assert page.has_no_css?("#publication-list-container table tbody tr") | ||
assert page.has_no_content?("answer edition") | ||
end | ||
end | ||
|
||
context "Content items that have only one edition, in the published state " do | ||
should "show main list with a single edition and a 'Create new edition' button and 'filter by status' counts as all zero except for 'Published'" do | ||
filter_by_status = ["Filter by Status", "Drafts 0", "In review 0", "Amends needed 0", "Out for fact check 0", "Fact check received 0", "Ready 0", "Scheduled 0", "Published 1", "Archived 0"] | ||
create_published_edition | ||
visit "by-content-id/#{@published_edition.content_id}" | ||
|
||
sidebar_filter_by_status = find_all(".nav-list")[0] | ||
within sidebar_filter_by_status do | ||
statuses = find_all("li") | ||
statuses.each do |status| | ||
assert filter_by_status.include?(status.text) | ||
end | ||
end | ||
|
||
assert page.has_css?("#publication-list-container table tbody tr") | ||
assert page.has_content?("answer edition") | ||
assert page.has_link?("Create new edition") | ||
end | ||
end | ||
|
||
context "Content items that have one edition in the published state and one item in draft state " do | ||
should "show main list with a single edition and a 'Edit newer edition' button and 'filter by status' counts as all zero except for 'Published' and 'Draft'" do | ||
filter_by_status = ["Filter by Status", "Drafts 1", "In review 0", "Amends needed 0", "Out for fact check 0", "Fact check received 0", "Ready 0", "Scheduled 0", "Published 1", "Archived 0"] | ||
create_published_edition | ||
create_draft_edition | ||
visit "by-content-id/#{@published_edition.content_id}" | ||
|
||
sidebar_filter_by_status = find_all(".nav-list")[0] | ||
within sidebar_filter_by_status do | ||
statuses = find_all("li") | ||
statuses.each do |status| | ||
assert filter_by_status.include?(status.text) | ||
end | ||
end | ||
|
||
assert page.has_css?("#publication-list-container table tbody tr") | ||
assert page.has_content?("answer edition") | ||
assert page.has_link?("Edit newer edition") | ||
end | ||
end | ||
end | ||
|
||
private | ||
|
||
def create_draft_edition | ||
@draft_edition = FactoryBot.create(:guide_edition, state: :draft, title: "answer edition", panopticon_id: @artefact.id, slug: "browser-extension-test") | ||
end | ||
|
||
def create_published_edition | ||
@published_edition = FactoryBot.create(:guide_edition, state: :published, title: "answer edition", panopticon_id: @artefact.id, slug: "browser-extension-test") | ||
end | ||
end |