You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
164 lines
5.6 KiB
164 lines
5.6 KiB
require "rails_helper" |
|
|
|
RSpec.describe MaintenanceController, type: :request do |
|
let(:page) { Capybara::Node::Simple.new(response.body) } |
|
let(:user) { FactoryBot.create(:user) } |
|
let(:storage_service) { instance_double(Storage::S3Service, get_file_metadata: nil) } |
|
|
|
before do |
|
allow(Storage::S3Service).to receive(:new).and_return(storage_service) |
|
allow(storage_service).to receive(:configuration).and_return(OpenStruct.new(bucket_name: "core-test-collection-resources")) |
|
sign_in user |
|
end |
|
|
|
describe "when the service has moved" do |
|
before do |
|
allow(FeatureToggle).to receive(:service_moved?).and_return(true) |
|
end |
|
|
|
context "when a user visits a page other than the service moved page" do |
|
before do |
|
get "/service-unavailable" |
|
end |
|
|
|
it "redirects the user to the service moved page" do |
|
expect(response).to redirect_to(service_moved_path) |
|
follow_redirect! |
|
expect(page).to have_content("The URL for this service has changed") |
|
end |
|
|
|
it "the cookie banner is visible" do |
|
follow_redirect! |
|
expect(page).to have_content("We’d like to use analytics cookies so we can understand how you use the service and make improvements.") |
|
end |
|
end |
|
|
|
context "when a user visits the service moved page" do |
|
before do |
|
get "/service-moved" |
|
end |
|
|
|
it "keeps the user on the service moved page" do |
|
expect(response).not_to redirect_to(service_moved_path) |
|
expect(page).to have_content("The URL for this service has changed") |
|
end |
|
|
|
it "the cookie banner is visible" do |
|
expect(page).to have_content("We’d like to use analytics cookies so we can understand how you use the service and make improvements.") |
|
end |
|
end |
|
end |
|
|
|
describe "when the service is unavailable" do |
|
before do |
|
allow(FeatureToggle).to receive(:service_unavailable?).and_return(true) |
|
end |
|
|
|
context "when a user visits a page other than the service unavailable page" do |
|
before do |
|
get "/lettings-logs" |
|
end |
|
|
|
it "redirects the user to the service unavailable page" do |
|
expect(response).to redirect_to(service_unavailable_path) |
|
follow_redirect! |
|
expect(page).to have_content("Sorry, the service is unavailable") |
|
end |
|
|
|
it "the cookie banner is visible" do |
|
follow_redirect! |
|
expect(page).to have_content("We’d like to use analytics cookies so we can understand how you use the service and make improvements.") |
|
end |
|
end |
|
|
|
context "when a user visits the service unavailable page" do |
|
before do |
|
get "/service-unavailable" |
|
end |
|
|
|
it "keeps the user on the service unavailable page" do |
|
expect(response).not_to redirect_to(service_unavailable_path) |
|
expect(page).to have_content("Sorry, the service is unavailable") |
|
end |
|
|
|
it "the cookie banner is visible" do |
|
expect(page).to have_content("We’d like to use analytics cookies so we can understand how you use the service and make improvements.") |
|
end |
|
end |
|
end |
|
|
|
describe "when both the service_moved? and service_unavailable? feature toggles are on" do |
|
before do |
|
allow(FeatureToggle).to receive(:service_moved?).and_return(true) |
|
allow(FeatureToggle).to receive(:service_unavailable?).and_return(true) |
|
end |
|
|
|
context "when a user visits a page other than the service moved page" do |
|
before do |
|
get "/service-unavailable" |
|
end |
|
|
|
it "redirects the user to the service moved page" do |
|
expect(response).to redirect_to(service_moved_path) |
|
follow_redirect! |
|
expect(page).to have_content("The URL for this service has changed") |
|
end |
|
|
|
it "the cookie banner is visible" do |
|
follow_redirect! |
|
expect(page).to have_content("We’d like to use analytics cookies so we can understand how you use the service and make improvements.") |
|
end |
|
end |
|
|
|
context "when a user visits the service moved page" do |
|
before do |
|
get "/service-moved" |
|
end |
|
|
|
it "keeps the user on the service moved page" do |
|
expect(response).not_to redirect_to(service_moved_path) |
|
expect(page).to have_content("The URL for this service has changed") |
|
end |
|
|
|
it "the cookie banner is visible" do |
|
expect(page).to have_content("We’d like to use analytics cookies so we can understand how you use the service and make improvements.") |
|
end |
|
end |
|
end |
|
|
|
describe "when the service is available" do |
|
before do |
|
allow(FeatureToggle).to receive(:service_unavailable?).and_return(false) |
|
end |
|
|
|
context "when a user visits a page other than the service unavailable page" do |
|
before do |
|
get "/lettings-logs" |
|
end |
|
|
|
it "doesn't redirect the user to the service unavailable page" do |
|
expect(response).not_to redirect_to(service_unavailable_path) |
|
expect(page).to have_content("Create a new lettings log") |
|
end |
|
|
|
it "the cookie banner is visible" do |
|
expect(page).to have_content("We’d like to use analytics cookies so we can understand how you use the service and make improvements.") |
|
end |
|
end |
|
|
|
context "when a user visits the service unavailable page" do |
|
before do |
|
get "/service-unavailable" |
|
end |
|
|
|
it "redirects the user to the start page" do |
|
expect(response).to redirect_to(root_path) |
|
end |
|
|
|
it "the cookie banner is visible" do |
|
follow_redirect! |
|
expect(page).to have_content("We’d like to use analytics cookies so we can understand how you use the service and make improvements.") |
|
end |
|
end |
|
end |
|
end
|
|
|