trabajo-afectivo/spec/requests/knowledge_base_public/custom_path_spec.rb

92 lines
2.9 KiB
Ruby
Raw Permalink Normal View History

2022-01-01 13:38:12 +00:00
# Copyright (C) 2012-2022 Zammad Foundation, https://zammad-foundation.org/
2020-10-06 18:05:07 +00:00
require 'rails_helper'
# Custom subdomain is handled by rewriting at web server
# Calling the original /help URL with a custom URL in header to simulate
RSpec.describe 'KnowledgeBase public custom path', type: :request do
let!(:knowledge_base) { create(:knowledge_base, custom_address: custom_address) }
let(:path) { '/path' }
let(:subdomain) { 'subdomain.example.net' }
let(:locale) { knowledge_base.kb_locales.first.system_locale.locale }
shared_examples 'accepting original URL' do
before { fetch }
it { expect(response).to have_http_status(:found) }
it { expect(response).to redirect_to "/help/#{locale}" }
end
context 'with no custom path' do
let(:custom_address) { nil }
it_behaves_like 'accepting original URL'
context 'when called with the subdomain' do
before { fetch subdomain: subdomain, path: '/' }
it { expect(response).to have_http_status(:found) }
it { expect(response).to redirect_to "/help/#{locale}" }
end
end
context 'with custom path' do
let(:custom_address) { path }
it_behaves_like 'accepting original URL'
context 'when called with the path' do
before { fetch path: path }
it { expect(response).to have_http_status(:found) }
it { expect(response).to redirect_to "/path/#{locale}" }
end
context 'when called with a custom port' do
before { fetch path: path, port: 8080 }
it { expect(response).to have_http_status(:found) }
it { expect(response).to redirect_to ":8080/path/#{locale}" }
end
context 'when called with the path and subdomain' do
before { fetch path: path, subdomain: subdomain }
it { expect(response).to have_http_status(:found) }
it { expect(response).to redirect_to "http://subdomain.example.net/path/#{locale}" }
end
end
context 'with custom subdomain' do
let(:custom_address) { subdomain }
it_behaves_like 'accepting original URL'
context 'when called with the subdomain' do
before { fetch subdomain: subdomain, path: '/' }
it { expect(response).to have_http_status(:found) }
it { expect(response).to redirect_to "http://subdomain.example.net/#{locale}" }
end
end
context 'with custom subdomain and path' do
let(:custom_address) { "#{subdomain}#{path}" }
it_behaves_like 'accepting original URL'
context 'when called with the path and subdomain' do
before { fetch path: path, subdomain: subdomain }
it { expect(response).to have_http_status(:found) }
it { expect(response).to redirect_to "http://subdomain.example.net/path/#{locale}" }
end
end
def fetch(path: nil, subdomain: nil, port: nil)
headers = { HTTP_X_ORIGINAL_URL: path, SERVER_NAME: subdomain, SERVER_PORT: port }.compact
get '/help', headers: headers
end
end