2019-09-06 00:06:25 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
2020-06-24 02:09:01 -04:00
|
|
|
RSpec.describe API::Internal::Pages do
|
2020-04-08 05:09:43 -04:00
|
|
|
let(:auth_headers) do
|
|
|
|
jwt_token = JWT.encode({ 'iss' => 'gitlab-pages' }, Gitlab::Pages.secret, 'HS256')
|
|
|
|
{ Gitlab::Pages::INTERNAL_API_REQUEST_HEADER => jwt_token }
|
|
|
|
end
|
|
|
|
let(:pages_secret) { SecureRandom.random_bytes(Gitlab::Pages::SECRET_LENGTH) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
allow(Gitlab::Pages).to receive(:secret).and_return(pages_secret)
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "GET /internal/pages/status" do
|
|
|
|
def query_enabled(headers = {})
|
|
|
|
get api("/internal/pages/status"), headers: headers
|
|
|
|
end
|
2019-09-06 00:06:25 -04:00
|
|
|
|
2020-04-08 05:09:43 -04:00
|
|
|
it 'responds with 401 Unauthorized' do
|
|
|
|
query_enabled
|
|
|
|
|
|
|
|
expect(response).to have_gitlab_http_status(:unauthorized)
|
2019-09-06 00:06:25 -04:00
|
|
|
end
|
|
|
|
|
2020-04-08 05:09:43 -04:00
|
|
|
it 'responds with 204 no content' do
|
|
|
|
query_enabled(auth_headers)
|
|
|
|
|
|
|
|
expect(response).to have_gitlab_http_status(:no_content)
|
|
|
|
expect(response.body).to be_empty
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "GET /internal/pages" do
|
2019-09-06 00:06:25 -04:00
|
|
|
def query_host(host, headers = {})
|
|
|
|
get api("/internal/pages"), headers: headers, params: { host: host }
|
|
|
|
end
|
|
|
|
|
2020-04-06 02:09:19 -04:00
|
|
|
context 'not authenticated' do
|
|
|
|
it 'responds with 401 Unauthorized' do
|
2019-09-06 00:06:25 -04:00
|
|
|
query_host('pages.gitlab.io')
|
|
|
|
|
2020-04-06 02:09:19 -04:00
|
|
|
expect(response).to have_gitlab_http_status(:unauthorized)
|
2019-09-06 00:06:25 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-04-06 02:09:19 -04:00
|
|
|
context 'authenticated' do
|
|
|
|
def query_host(host)
|
|
|
|
jwt_token = JWT.encode({ 'iss' => 'gitlab-pages' }, Gitlab::Pages.secret, 'HS256')
|
|
|
|
headers = { Gitlab::Pages::INTERNAL_API_REQUEST_HEADER => jwt_token }
|
2019-09-06 00:06:25 -04:00
|
|
|
|
2020-04-06 02:09:19 -04:00
|
|
|
super(host, headers)
|
2019-09-06 00:06:25 -04:00
|
|
|
end
|
|
|
|
|
2020-04-06 02:09:19 -04:00
|
|
|
def deploy_pages(project)
|
|
|
|
project.mark_pages_as_deployed
|
|
|
|
end
|
2019-09-06 00:06:25 -04:00
|
|
|
|
2020-04-06 02:09:19 -04:00
|
|
|
context 'domain does not exist' do
|
|
|
|
it 'responds with 204 no content' do
|
|
|
|
query_host('pages.gitlab.io')
|
2019-09-06 00:06:25 -04:00
|
|
|
|
2020-04-06 02:09:19 -04:00
|
|
|
expect(response).to have_gitlab_http_status(:no_content)
|
|
|
|
expect(response.body).to be_empty
|
2019-09-25 05:06:04 -04:00
|
|
|
end
|
2020-04-06 02:09:19 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
context 'serverless domain' do
|
|
|
|
let(:namespace) { create(:namespace, name: 'gitlab-org') }
|
|
|
|
let(:project) { create(:project, namespace: namespace, name: 'gitlab-ce') }
|
|
|
|
let(:environment) { create(:environment, project: project) }
|
|
|
|
let(:pages_domain) { create(:pages_domain, domain: 'serverless.gitlab.io') }
|
|
|
|
let(:knative_without_ingress) { create(:clusters_applications_knative) }
|
|
|
|
let(:knative_with_ingress) { create(:clusters_applications_knative, external_ip: '10.0.0.1') }
|
|
|
|
|
|
|
|
context 'without a knative ingress gateway IP' do
|
|
|
|
let!(:serverless_domain_cluster) do
|
|
|
|
create(
|
|
|
|
:serverless_domain_cluster,
|
|
|
|
uuid: 'abcdef12345678',
|
|
|
|
pages_domain: pages_domain,
|
|
|
|
knative: knative_without_ingress
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
|
|
|
let(:serverless_domain) do
|
|
|
|
create(
|
|
|
|
:serverless_domain,
|
|
|
|
serverless_domain_cluster: serverless_domain_cluster,
|
|
|
|
environment: environment
|
|
|
|
)
|
|
|
|
end
|
2019-09-25 05:06:04 -04:00
|
|
|
|
2019-12-04 07:07:12 -05:00
|
|
|
it 'responds with 204 no content' do
|
2020-04-06 02:09:19 -04:00
|
|
|
query_host(serverless_domain.uri.host)
|
2019-09-06 01:20:05 -04:00
|
|
|
|
2020-02-17 13:09:00 -05:00
|
|
|
expect(response).to have_gitlab_http_status(:no_content)
|
2019-12-04 07:07:12 -05:00
|
|
|
expect(response.body).to be_empty
|
2019-09-06 01:20:05 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-04-06 02:09:19 -04:00
|
|
|
context 'with a knative ingress gateway IP' do
|
|
|
|
let!(:serverless_domain_cluster) do
|
|
|
|
create(
|
|
|
|
:serverless_domain_cluster,
|
|
|
|
uuid: 'abcdef12345678',
|
|
|
|
pages_domain: pages_domain,
|
|
|
|
knative: knative_with_ingress
|
|
|
|
)
|
2020-02-24 07:09:00 -05:00
|
|
|
end
|
|
|
|
|
2020-04-06 02:09:19 -04:00
|
|
|
let(:serverless_domain) do
|
|
|
|
create(
|
|
|
|
:serverless_domain,
|
|
|
|
serverless_domain_cluster: serverless_domain_cluster,
|
|
|
|
environment: environment
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'responds with proxy configuration' do
|
|
|
|
query_host(serverless_domain.uri.host)
|
|
|
|
|
|
|
|
expect(response).to have_gitlab_http_status(:ok)
|
|
|
|
expect(response).to match_response_schema('internal/serverless/virtual_domain')
|
|
|
|
|
|
|
|
expect(json_response['certificate']).to eq(pages_domain.certificate)
|
|
|
|
expect(json_response['key']).to eq(pages_domain.key)
|
|
|
|
|
|
|
|
expect(json_response['lookup_paths']).to eq(
|
|
|
|
[
|
|
|
|
{
|
|
|
|
'source' => {
|
|
|
|
'type' => 'serverless',
|
|
|
|
'service' => "test-function.#{project.name}-#{project.id}-#{environment.slug}.#{serverless_domain_cluster.knative.hostname}",
|
|
|
|
'cluster' => {
|
|
|
|
'hostname' => serverless_domain_cluster.knative.hostname,
|
|
|
|
'address' => serverless_domain_cluster.knative.external_ip,
|
|
|
|
'port' => 443,
|
|
|
|
'cert' => serverless_domain_cluster.certificate,
|
|
|
|
'key' => serverless_domain_cluster.key
|
2020-02-24 07:09:00 -05:00
|
|
|
}
|
|
|
|
}
|
2020-04-06 02:09:19 -04:00
|
|
|
}
|
|
|
|
]
|
|
|
|
)
|
2020-02-24 07:09:00 -05:00
|
|
|
end
|
|
|
|
end
|
2020-04-06 02:09:19 -04:00
|
|
|
end
|
2020-02-24 07:09:00 -05:00
|
|
|
|
2020-04-06 02:09:19 -04:00
|
|
|
context 'custom domain' do
|
|
|
|
let(:namespace) { create(:namespace, name: 'gitlab-org') }
|
|
|
|
let(:project) { create(:project, namespace: namespace, name: 'gitlab-ce') }
|
|
|
|
let!(:pages_domain) { create(:pages_domain, domain: 'pages.io', project: project) }
|
2019-09-06 01:20:05 -04:00
|
|
|
|
2020-04-06 02:09:19 -04:00
|
|
|
context 'when there are no pages deployed for the related project' do
|
|
|
|
it 'responds with 204 No Content' do
|
|
|
|
query_host('pages.io')
|
2019-09-06 01:20:05 -04:00
|
|
|
|
2020-04-06 02:09:19 -04:00
|
|
|
expect(response).to have_gitlab_http_status(:no_content)
|
2019-09-25 05:06:04 -04:00
|
|
|
end
|
2020-04-06 02:09:19 -04:00
|
|
|
end
|
2019-09-06 01:20:05 -04:00
|
|
|
|
2020-04-06 02:09:19 -04:00
|
|
|
context 'when there are pages deployed for the related project' do
|
|
|
|
it 'domain lookup is case insensitive' do
|
|
|
|
deploy_pages(project)
|
2020-02-25 16:09:23 -05:00
|
|
|
|
2020-04-06 02:09:19 -04:00
|
|
|
query_host('Pages.IO')
|
2020-02-25 16:09:23 -05:00
|
|
|
|
2020-04-06 02:09:19 -04:00
|
|
|
expect(response).to have_gitlab_http_status(:ok)
|
|
|
|
end
|
2020-02-25 16:09:23 -05:00
|
|
|
|
2020-04-06 02:09:19 -04:00
|
|
|
it 'responds with the correct domain configuration' do
|
|
|
|
deploy_pages(project)
|
2019-09-25 05:06:04 -04:00
|
|
|
|
2020-04-06 02:09:19 -04:00
|
|
|
query_host('pages.io')
|
2019-09-25 05:06:04 -04:00
|
|
|
|
2020-04-06 02:09:19 -04:00
|
|
|
expect(response).to have_gitlab_http_status(:ok)
|
|
|
|
expect(response).to match_response_schema('internal/pages/virtual_domain')
|
2019-09-25 05:06:04 -04:00
|
|
|
|
2020-04-06 02:09:19 -04:00
|
|
|
expect(json_response['certificate']).to eq(pages_domain.certificate)
|
|
|
|
expect(json_response['key']).to eq(pages_domain.key)
|
2019-09-25 05:06:04 -04:00
|
|
|
|
2020-04-06 02:09:19 -04:00
|
|
|
expect(json_response['lookup_paths']).to eq(
|
|
|
|
[
|
|
|
|
{
|
|
|
|
'project_id' => project.id,
|
|
|
|
'access_control' => false,
|
|
|
|
'https_only' => false,
|
|
|
|
'prefix' => '/',
|
|
|
|
'source' => {
|
|
|
|
'type' => 'file',
|
|
|
|
'path' => 'gitlab-org/gitlab-ce/public/'
|
2019-09-25 05:06:04 -04:00
|
|
|
}
|
2020-04-06 02:09:19 -04:00
|
|
|
}
|
|
|
|
]
|
|
|
|
)
|
2019-09-25 05:06:04 -04:00
|
|
|
end
|
|
|
|
end
|
2020-04-06 02:09:19 -04:00
|
|
|
end
|
2019-09-25 05:06:04 -04:00
|
|
|
|
2020-04-06 02:09:19 -04:00
|
|
|
context 'namespaced domain' do
|
|
|
|
let(:group) { create(:group, name: 'mygroup') }
|
2019-09-25 05:06:04 -04:00
|
|
|
|
2020-04-06 02:09:19 -04:00
|
|
|
before do
|
|
|
|
allow(Settings.pages).to receive(:host).and_return('gitlab-pages.io')
|
|
|
|
allow(Gitlab.config.pages).to receive(:url).and_return("http://gitlab-pages.io")
|
|
|
|
end
|
2019-09-25 05:06:04 -04:00
|
|
|
|
2020-04-06 02:09:19 -04:00
|
|
|
context 'regular project' do
|
|
|
|
it 'responds with the correct domain configuration' do
|
|
|
|
project = create(:project, group: group, name: 'myproject')
|
|
|
|
deploy_pages(project)
|
|
|
|
|
|
|
|
query_host('mygroup.gitlab-pages.io')
|
|
|
|
|
|
|
|
expect(response).to have_gitlab_http_status(:ok)
|
|
|
|
expect(response).to match_response_schema('internal/pages/virtual_domain')
|
|
|
|
|
|
|
|
expect(json_response['lookup_paths']).to eq(
|
|
|
|
[
|
|
|
|
{
|
|
|
|
'project_id' => project.id,
|
|
|
|
'access_control' => false,
|
|
|
|
'https_only' => false,
|
|
|
|
'prefix' => '/myproject/',
|
|
|
|
'source' => {
|
|
|
|
'type' => 'file',
|
|
|
|
'path' => 'mygroup/myproject/public/'
|
2019-09-25 05:06:04 -04:00
|
|
|
}
|
2020-04-06 02:09:19 -04:00
|
|
|
}
|
|
|
|
]
|
|
|
|
)
|
2019-09-25 05:06:04 -04:00
|
|
|
end
|
2020-04-06 02:09:19 -04:00
|
|
|
end
|
2019-09-06 00:06:25 -04:00
|
|
|
|
2020-04-06 02:09:19 -04:00
|
|
|
context 'group root project' do
|
|
|
|
it 'responds with the correct domain configuration' do
|
|
|
|
project = create(:project, group: group, name: 'mygroup.gitlab-pages.io')
|
|
|
|
deploy_pages(project)
|
|
|
|
|
|
|
|
query_host('mygroup.gitlab-pages.io')
|
|
|
|
|
|
|
|
expect(response).to have_gitlab_http_status(:ok)
|
|
|
|
expect(response).to match_response_schema('internal/pages/virtual_domain')
|
|
|
|
|
|
|
|
expect(json_response['lookup_paths']).to eq(
|
|
|
|
[
|
|
|
|
{
|
|
|
|
'project_id' => project.id,
|
|
|
|
'access_control' => false,
|
|
|
|
'https_only' => false,
|
|
|
|
'prefix' => '/',
|
|
|
|
'source' => {
|
|
|
|
'type' => 'file',
|
|
|
|
'path' => 'mygroup/mygroup.gitlab-pages.io/public/'
|
2019-09-25 05:06:04 -04:00
|
|
|
}
|
2020-04-06 02:09:19 -04:00
|
|
|
}
|
|
|
|
]
|
|
|
|
)
|
2019-09-06 01:20:05 -04:00
|
|
|
end
|
2019-09-06 00:06:25 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|