diff --git a/lib/gitlab/pages/url_builder.rb b/lib/gitlab/pages/url_builder.rb index 4d025af4ce5477d66b76f159b91ad2a2cce935ea..f01ec54b853a38c70661eda2938a099b5991292c 100644 --- a/lib/gitlab/pages/url_builder.rb +++ b/lib/gitlab/pages/url_builder.rb @@ -14,7 +14,18 @@ def initialize(project) end def pages_url(with_unique_domain: false) - find_url(with_unique_domain).downcase + return namespace_in_path_url(with_unique_domain && unique_domain_enabled?) if config.namespace_in_path + return unique_url if with_unique_domain && unique_domain_enabled? + + project_path_url = "#{config.protocol}://#{project_path}".downcase + + # If the project path is the same as host, we serve it as group page + # On development we ignore the URL port to make it work on GDK + return namespace_url if Rails.env.development? && portless(namespace_url) == project_path_url + # If the project path is the same as host, we serve it as group page + return namespace_url if namespace_url == project_path_url + + "#{namespace_url}/#{project_path}" end def unique_host @@ -52,21 +63,6 @@ def artifact_url_available?(artifact, job) attr_reader :project, :project_path - def find_url(with_unique_domain) - return namespace_in_path_url(with_unique_domain && unique_domain_enabled?) if config.namespace_in_path - return unique_url if with_unique_domain && unique_domain_enabled? - - project_path_url = "#{config.protocol}://#{project_path}" - - # If the project path is the same as host, we serve it as group page - # On development we ignore the URL port to make it work on GDK - return namespace_url if Rails.env.development? && portless(namespace_url) == project_path_url - # If the project path is the same as host, we serve it as group page - return namespace_url if namespace_url == project_path_url - - "#{namespace_url}/#{project_path}" - end - def namespace_url @namespace_url ||= url_for(project_namespace) end @@ -79,13 +75,14 @@ def pages_base_url @pages_url ||= URI(config.url) .tap { |url| url.port = config.port } .to_s + .downcase end def namespace_in_path_url(with_unique_domain) if with_unique_domain - "#{pages_base_url}/#{project.project_setting.pages_unique_domain}" + "#{pages_base_url}/#{project.project_setting.pages_unique_domain}".downcase else - "#{pages_base_url}/#{project_namespace}/#{project_path}" + "#{pages_base_url}/#{project_namespace}/#{project_path}".downcase end end @@ -94,6 +91,7 @@ def url_for(subdomain) .tap { |url| url.port = config.port } .tap { |url| url.host.prepend("#{subdomain}.") } .to_s + .downcase end def portless(url) diff --git a/spec/lib/gitlab/pages/url_builder_spec.rb b/spec/lib/gitlab/pages/url_builder_spec.rb index 863c4481c9ef6f31879d66df5cdc399a93ee11cc..1a97ca01c3eaf17c7b8efa782acea301041e415f 100644 --- a/spec/lib/gitlab/pages/url_builder_spec.rb +++ b/spec/lib/gitlab/pages/url_builder_spec.rb @@ -63,12 +63,6 @@ it { is_expected.to eq('http://group.example.com/project') } end - context 'when project is upper cased' do - let(:full_path) { 'group/Project' } - - it { is_expected.to eq('http://group.example.com/project') } - end - context 'when project is in a nested group page' do let(:full_path) { 'group/subgroup/project' } @@ -133,12 +127,6 @@ it { is_expected.to eq('http://example.com/group/project') } end - context 'when project is upper cased' do - let(:full_path) { 'group/Project' } - - it { is_expected.to eq('http://example.com/group/project') } - end - context 'when project is in a nested group page' do let(:full_path) { 'group/subgroup/project' }