Decorate Gitlab::Git::Commit with Commit
This commit is contained in:
parent
9dc644635f
commit
26323046fd
5 changed files with 13 additions and 3 deletions
|
@ -12,6 +12,7 @@ class CommitLoadContext < BaseContext
|
||||||
commit = project.repository.commit(params[:id])
|
commit = project.repository.commit(params[:id])
|
||||||
|
|
||||||
if commit
|
if commit
|
||||||
|
commit = Commit.new(commit)
|
||||||
commit = CommitDecorator.decorate(commit)
|
commit = CommitDecorator.decorate(commit)
|
||||||
line_notes = project.notes.for_commit_id(commit.id).inline
|
line_notes = project.notes.for_commit_id(commit.id).inline
|
||||||
|
|
||||||
|
|
|
@ -13,6 +13,7 @@ class CommitsController < ProjectResourceController
|
||||||
@limit, @offset = (params[:limit] || 40), (params[:offset] || 0)
|
@limit, @offset = (params[:limit] || 40), (params[:offset] || 0)
|
||||||
|
|
||||||
@commits = @repo.commits(@ref, @path, @limit, @offset)
|
@commits = @repo.commits(@ref, @path, @limit, @offset)
|
||||||
|
@commits = Commit.decorate(@commits)
|
||||||
@commits = CommitDecorator.decorate_collection(@commits)
|
@commits = CommitDecorator.decorate_collection(@commits)
|
||||||
|
|
||||||
respond_to do |format|
|
respond_to do |format|
|
||||||
|
|
|
@ -10,12 +10,20 @@ class Commit
|
||||||
|
|
||||||
attr_accessor :raw
|
attr_accessor :raw
|
||||||
|
|
||||||
|
def self.decorate(commits)
|
||||||
|
commits.map { |c| Commit.new(c) }
|
||||||
|
end
|
||||||
|
|
||||||
def initialize(raw_commit)
|
def initialize(raw_commit)
|
||||||
raise "Nil as raw commit passed" unless raw_commit
|
raise "Nil as raw commit passed" unless raw_commit
|
||||||
|
|
||||||
@raw = raw_commit
|
@raw = raw_commit
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def id
|
||||||
|
@raw.id
|
||||||
|
end
|
||||||
|
|
||||||
def method_missing(m, *args, &block)
|
def method_missing(m, *args, &block)
|
||||||
@raw.send(m, *args, &block)
|
@raw.send(m, *args, &block)
|
||||||
end
|
end
|
||||||
|
|
|
@ -7,8 +7,8 @@ module Gitlab
|
||||||
attr_accessor :raw_commit, :head, :refs
|
attr_accessor :raw_commit, :head, :refs
|
||||||
|
|
||||||
delegate :message, :authored_date, :committed_date, :parents, :sha,
|
delegate :message, :authored_date, :committed_date, :parents, :sha,
|
||||||
:date, :committer, :author, :diffs, :tree, :id, :stats,
|
:date, :committer, :author, :diffs, :tree, :id, :stats, :to_patch,
|
||||||
:to_patch, to: :raw_commit
|
to: :raw_commit
|
||||||
|
|
||||||
class << self
|
class << self
|
||||||
def find_or_first(repo, commit_id = nil, root_ref)
|
def find_or_first(repo, commit_id = nil, root_ref)
|
||||||
|
|
|
@ -7,7 +7,7 @@ describe GitlabMarkdownHelper do
|
||||||
let!(:project) { create(:project) }
|
let!(:project) { create(:project) }
|
||||||
|
|
||||||
let(:user) { create(:user, username: 'gfm') }
|
let(:user) { create(:user, username: 'gfm') }
|
||||||
let(:commit) { CommitDecorator.decorate(project.repository.commit) }
|
let(:commit) { CommitDecorator.decorate(Commit.new(project.repository.commit)) }
|
||||||
let(:issue) { create(:issue, project: project) }
|
let(:issue) { create(:issue, project: project) }
|
||||||
let(:merge_request) { create(:merge_request, project: project) }
|
let(:merge_request) { create(:merge_request, project: project) }
|
||||||
let(:snippet) { create(:snippet, project: project) }
|
let(:snippet) { create(:snippet, project: project) }
|
||||||
|
|
Loading…
Add table
Reference in a new issue