get rid of light url builder and fix wrong spec
This commit is contained in:
parent
ca6da6ea30
commit
f93607a305
2 changed files with 97 additions and 119 deletions
|
@ -1,67 +0,0 @@
|
||||||
module Gitlab
|
|
||||||
# Similar to UrlBuilder, but using IDs to avoid querying the DB for objects
|
|
||||||
# Useful for using in conjunction with Arel queries.
|
|
||||||
class LightUrlBuilder
|
|
||||||
include Gitlab::Routing.url_helpers
|
|
||||||
include GitlabRoutingHelper
|
|
||||||
include ActionView::RecordIdentifier
|
|
||||||
|
|
||||||
def self.build(*args)
|
|
||||||
new(*args).url
|
|
||||||
end
|
|
||||||
|
|
||||||
def initialize(entity:, project: nil, id:, opts: {})
|
|
||||||
@entity = entity
|
|
||||||
@project = project
|
|
||||||
@id = id
|
|
||||||
@opts = opts
|
|
||||||
end
|
|
||||||
|
|
||||||
def url
|
|
||||||
url_method = "#{@entity}_url"
|
|
||||||
raise NotImplementedError.new("No Light URL builder defined for #{@entity}") unless respond_to?(url_method)
|
|
||||||
|
|
||||||
public_send(url_method)
|
|
||||||
end
|
|
||||||
|
|
||||||
def issue_url
|
|
||||||
namespace_project_issue_url({
|
|
||||||
namespace_id: @project.namespace,
|
|
||||||
project_id: @project,
|
|
||||||
id: @id
|
|
||||||
}.merge!(@opts))
|
|
||||||
end
|
|
||||||
|
|
||||||
def user_avatar_url
|
|
||||||
User.find(@id).avatar_url
|
|
||||||
end
|
|
||||||
|
|
||||||
def commit_url
|
|
||||||
namespace_project_commit_url({
|
|
||||||
namespace_id: @project.namespace,
|
|
||||||
project_id: @project,
|
|
||||||
id: @id
|
|
||||||
}.merge!(@opts))
|
|
||||||
end
|
|
||||||
|
|
||||||
def merge_request_url
|
|
||||||
namespace_project_merge_request_url({
|
|
||||||
namespace_id: @project.namespace,
|
|
||||||
project_id: @project,
|
|
||||||
id: @id
|
|
||||||
}.merge!(@opts))
|
|
||||||
end
|
|
||||||
|
|
||||||
def branch_url
|
|
||||||
namespace_project_commit_url(@project.namespace, @project, @id)
|
|
||||||
end
|
|
||||||
|
|
||||||
def user_url
|
|
||||||
Gitlab::Routing.url_helpers.user_url(@id)
|
|
||||||
end
|
|
||||||
|
|
||||||
def build_url
|
|
||||||
namespace_project_build_url(@project.namespace, @project, @id)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
|
@ -1,74 +1,119 @@
|
||||||
require 'spec_helper'
|
require 'spec_helper'
|
||||||
|
|
||||||
describe Gitlab::LightUrlBuilder, lib: true do
|
describe Gitlab::UrlBuilder, lib: true do
|
||||||
context 'when passing a Commit' do
|
describe '.build' do
|
||||||
it 'returns a proper URL' do
|
context 'when passing a Commit' do
|
||||||
commit = build_stubbed(:commit)
|
it 'returns a proper URL' do
|
||||||
|
commit = build_stubbed(:commit)
|
||||||
|
|
||||||
url = described_class.build(entity: :commit, project: commit.project, id: commit.id)
|
url = described_class.build(commit)
|
||||||
|
|
||||||
expect(url).to eq "#{Settings.gitlab['url']}/#{commit.project.path_with_namespace}/commit/#{commit.id}"
|
expect(url).to eq "#{Settings.gitlab['url']}/#{commit.project.path_with_namespace}/commit/#{commit.id}"
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
|
||||||
|
|
||||||
context 'when passing an Issue' do
|
context 'when passing an Issue' do
|
||||||
it 'returns a proper URL' do
|
it 'returns a proper URL' do
|
||||||
issue = build_stubbed(:issue, iid: 42)
|
issue = build_stubbed(:issue, iid: 42)
|
||||||
|
|
||||||
url = described_class.build(entity: :issue, project: issue.project, id: issue.iid)
|
url = described_class.build(issue)
|
||||||
|
|
||||||
expect(url).to eq "#{Settings.gitlab['url']}/#{issue.project.path_with_namespace}/issues/#{issue.iid}"
|
expect(url).to eq "#{Settings.gitlab['url']}/#{issue.project.path_with_namespace}/issues/#{issue.iid}"
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
|
||||||
|
|
||||||
context 'when passing a MergeRequest' do
|
context 'when passing a MergeRequest' do
|
||||||
it 'returns a proper URL' do
|
it 'returns a proper URL' do
|
||||||
merge_request = build_stubbed(:merge_request, iid: 42)
|
merge_request = build_stubbed(:merge_request, iid: 42)
|
||||||
|
|
||||||
url = described_class.build(entity: :merge_request, project: merge_request.project, id: merge_request.iid)
|
url = described_class.build(merge_request)
|
||||||
|
|
||||||
expect(url).to eq "#{Settings.gitlab['url']}/#{merge_request.project.path_with_namespace}/merge_requests/#{merge_request.iid}"
|
expect(url).to eq "#{Settings.gitlab['url']}/#{merge_request.project.path_with_namespace}/merge_requests/#{merge_request.iid}"
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
|
||||||
|
|
||||||
context 'when passing a build' do
|
context 'when passing a Note' do
|
||||||
it 'returns a proper URL' do
|
context 'on a Commit' do
|
||||||
build = build_stubbed(:ci_build, project: build_stubbed(:empty_project))
|
it 'returns a proper URL' do
|
||||||
|
note = build_stubbed(:note_on_commit)
|
||||||
|
|
||||||
url = described_class.build(entity: :build, project: build.project, id: build.id)
|
url = described_class.build(note)
|
||||||
|
|
||||||
expect(url).to eq "#{Settings.gitlab['url']}/#{build.project.path_with_namespace}/builds/#{build.id}"
|
expect(url).to eq "#{Settings.gitlab['url']}/#{note.project.path_with_namespace}/commit/#{note.commit_id}#note_#{note.id}"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'on a Commit Diff' do
|
||||||
|
it 'returns a proper URL' do
|
||||||
|
note = build_stubbed(:diff_note_on_commit)
|
||||||
|
|
||||||
|
url = described_class.build(note)
|
||||||
|
|
||||||
|
expect(url).to eq "#{Settings.gitlab['url']}/#{note.project.path_with_namespace}/commit/#{note.commit_id}#note_#{note.id}"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'on an Issue' do
|
||||||
|
it 'returns a proper URL' do
|
||||||
|
issue = create(:issue, iid: 42)
|
||||||
|
note = build_stubbed(:note_on_issue, noteable: issue)
|
||||||
|
|
||||||
|
url = described_class.build(note)
|
||||||
|
|
||||||
|
expect(url).to eq "#{Settings.gitlab['url']}/#{issue.project.path_with_namespace}/issues/#{issue.iid}#note_#{note.id}"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'on a MergeRequest' do
|
||||||
|
it 'returns a proper URL' do
|
||||||
|
merge_request = create(:merge_request, iid: 42)
|
||||||
|
note = build_stubbed(:note_on_merge_request, noteable: merge_request)
|
||||||
|
|
||||||
|
url = described_class.build(note)
|
||||||
|
|
||||||
|
expect(url).to eq "#{Settings.gitlab['url']}/#{merge_request.project.path_with_namespace}/merge_requests/#{merge_request.iid}#note_#{note.id}"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'on a MergeRequest Diff' do
|
||||||
|
it 'returns a proper URL' do
|
||||||
|
merge_request = create(:merge_request, iid: 42)
|
||||||
|
note = build_stubbed(:diff_note_on_merge_request, noteable: merge_request)
|
||||||
|
|
||||||
|
url = described_class.build(note)
|
||||||
|
|
||||||
|
expect(url).to eq "#{Settings.gitlab['url']}/#{merge_request.project.path_with_namespace}/merge_requests/#{merge_request.iid}#note_#{note.id}"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'on a ProjectSnippet' do
|
||||||
|
it 'returns a proper URL' do
|
||||||
|
project_snippet = create(:project_snippet)
|
||||||
|
note = build_stubbed(:note_on_project_snippet, noteable: project_snippet)
|
||||||
|
|
||||||
|
url = described_class.build(note)
|
||||||
|
|
||||||
|
expect(url).to eq "#{Settings.gitlab['url']}/#{project_snippet.project.path_with_namespace}/snippets/#{note.noteable_id}#note_#{note.id}"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'on another object' do
|
||||||
|
it 'returns a proper URL' do
|
||||||
|
project = build_stubbed(:project)
|
||||||
|
|
||||||
|
expect { described_class.build(project) }.
|
||||||
|
to raise_error(NotImplementedError, 'No URL builder defined for Project')
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
|
||||||
|
|
||||||
context 'when passing a branch' do
|
context 'when passing a WikiPage' do
|
||||||
it 'returns a proper URL' do
|
it 'returns a proper URL' do
|
||||||
branch = 'branch_name'
|
wiki_page = build(:wiki_page)
|
||||||
project = build_stubbed(:empty_project)
|
url = described_class.build(wiki_page)
|
||||||
|
|
||||||
url = described_class.build(entity: :branch, project: project, id: branch)
|
expect(url).to eq "#{Gitlab.config.gitlab.url}#{wiki_page.wiki.wiki_base_path}/#{wiki_page.slug}"
|
||||||
|
end
|
||||||
expect(url).to eq "#{Settings.gitlab['url']}/#{project.path_with_namespace}/commits/#{branch}"
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
context 'on a User' do
|
|
||||||
it 'returns a proper URL' do
|
|
||||||
user = build_stubbed(:user)
|
|
||||||
|
|
||||||
url = described_class.build(entity: :user, id: user.username)
|
|
||||||
|
|
||||||
expect(url).to eq "#{Settings.gitlab['url']}/#{user.username}"
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
context 'on a user avatar' do
|
|
||||||
it 'returns a proper URL' do
|
|
||||||
user = create(:user)
|
|
||||||
|
|
||||||
url = described_class.build(entity: :user_avatar, id: user.id)
|
|
||||||
|
|
||||||
expect(url).to eq user.avatar_url
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue