Add BlameController, remove Refs#blame action
This commit is contained in:
parent
37f0b600bc
commit
39c6579306
8 changed files with 57 additions and 27 deletions
45
app/controllers/blame_controller.rb
Normal file
45
app/controllers/blame_controller.rb
Normal file
|
@ -0,0 +1,45 @@
|
||||||
|
# Controller for viewing a file's blame
|
||||||
|
class BlameController < ApplicationController
|
||||||
|
# Thrown when given an invalid path
|
||||||
|
class InvalidPathError < StandardError; end
|
||||||
|
|
||||||
|
include RefExtractor
|
||||||
|
|
||||||
|
layout "project"
|
||||||
|
|
||||||
|
before_filter :project
|
||||||
|
|
||||||
|
# Authorize
|
||||||
|
before_filter :add_project_abilities
|
||||||
|
before_filter :authorize_read_project!
|
||||||
|
before_filter :authorize_code_access!
|
||||||
|
before_filter :require_non_empty_project
|
||||||
|
|
||||||
|
before_filter :define_tree_vars
|
||||||
|
|
||||||
|
def show
|
||||||
|
@blame = Grit::Blob.blame(@repo, @commit.id, @path)
|
||||||
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
|
def define_tree_vars
|
||||||
|
@ref, @path = extract_ref(params[:id])
|
||||||
|
|
||||||
|
@id = File.join(@ref, @path)
|
||||||
|
@repo = @project.repo
|
||||||
|
@commit = CommitDecorator.decorate(@project.commit(@ref))
|
||||||
|
|
||||||
|
@tree = Tree.new(@commit.tree, @project, @ref, @path)
|
||||||
|
@tree = TreeDecorator.new(@tree)
|
||||||
|
|
||||||
|
raise InvalidPathError if @tree.invalid?
|
||||||
|
|
||||||
|
@hex_path = Digest::SHA1.hexdigest(@path)
|
||||||
|
|
||||||
|
@history_path = project_tree_path(@project, @id)
|
||||||
|
@logs_path = logs_file_project_ref_path(@project, @ref, @path)
|
||||||
|
rescue NoMethodError, InvalidPathError
|
||||||
|
not_found!
|
||||||
|
end
|
||||||
|
end
|
|
@ -9,7 +9,7 @@ class RefsController < ApplicationController
|
||||||
before_filter :require_non_empty_project
|
before_filter :require_non_empty_project
|
||||||
|
|
||||||
before_filter :ref
|
before_filter :ref
|
||||||
before_filter :define_tree_vars, only: [:tree, :blob, :blame, :logs_tree]
|
before_filter :define_tree_vars, only: [:blob, :logs_tree]
|
||||||
before_filter :render_full_content
|
before_filter :render_full_content
|
||||||
|
|
||||||
layout "project"
|
layout "project"
|
||||||
|
@ -79,10 +79,6 @@ class RefsController < ApplicationController
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def blame
|
|
||||||
@blame = Grit::Blob.blame(@repo, @commit.id, params[:path])
|
|
||||||
end
|
|
||||||
|
|
||||||
protected
|
protected
|
||||||
|
|
||||||
def define_tree_vars
|
def define_tree_vars
|
||||||
|
|
|
@ -20,7 +20,7 @@
|
||||||
%span.options
|
%span.options
|
||||||
= link_to "raw", blob_project_ref_path(@project, @ref, path: params[:path]), class: "btn very_small", target: "_blank"
|
= link_to "raw", blob_project_ref_path(@project, @ref, path: params[:path]), class: "btn very_small", target: "_blank"
|
||||||
= link_to "history", project_commits_path(@project, path: params[:path], ref: @ref), class: "btn very_small"
|
= link_to "history", project_commits_path(@project, path: params[:path], ref: @ref), class: "btn very_small"
|
||||||
= link_to "source", project_tree_path(@project, tree_join(@ref, params[:path])), class: "btn very_small"
|
= link_to "source", project_tree_path(@project, @id), class: "btn very_small"
|
||||||
.file_content.blame
|
.file_content.blame
|
||||||
%table
|
%table
|
||||||
- @blame.each do |commit, lines|
|
- @blame.each do |commit, lines|
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
%span.options
|
%span.options
|
||||||
= link_to "raw", blob_project_ref_path(@project, @ref, path: @path), class: "btn very_small", target: "_blank"
|
= link_to "raw", blob_project_ref_path(@project, @ref, path: @path), class: "btn very_small", target: "_blank"
|
||||||
= link_to "history", project_commits_path(@project, path: params[:path], ref: @ref), class: "btn very_small"
|
= link_to "history", project_commits_path(@project, path: params[:path], ref: @ref), class: "btn very_small"
|
||||||
= link_to "blame", blame_file_project_ref_path(@project, @ref, path: @path.gsub(/^\//, '')), class: "btn very_small"
|
= link_to "blame", project_blame_path(@project, @id), class: "btn very_small"
|
||||||
- if file.text?
|
- if file.text?
|
||||||
- if gitlab_markdown?(name)
|
- if gitlab_markdown?(name)
|
||||||
.file_content.wiki
|
.file_content.wiki
|
||||||
|
|
|
@ -136,14 +136,6 @@ Gitlab::Application.routes.draw do
|
||||||
id: /[a-zA-Z.0-9\/_\-]+/,
|
id: /[a-zA-Z.0-9\/_\-]+/,
|
||||||
path: /.*/
|
path: /.*/
|
||||||
}
|
}
|
||||||
|
|
||||||
# blame
|
|
||||||
get "blame/:path" => "refs#blame",
|
|
||||||
as: :blame_file,
|
|
||||||
constraints: {
|
|
||||||
id: /[a-zA-Z.0-9\/_\-]+/,
|
|
||||||
path: /.*/
|
|
||||||
}
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -204,7 +196,7 @@ Gitlab::Application.routes.draw do
|
||||||
end
|
end
|
||||||
|
|
||||||
# XXX: WIP
|
# XXX: WIP
|
||||||
# resources :blame, only: [:show], constraints: {id: /.+/}
|
resources :blame, only: [:show], constraints: {id: /.+/}
|
||||||
# resources :blob, only: [:show], constraints: {id: /.+/}
|
# resources :blob, only: [:show], constraints: {id: /.+/}
|
||||||
# resources :raw, only: [:show], constraints: {id: /.+/}
|
# resources :raw, only: [:show], constraints: {id: /.+/}
|
||||||
resources :tree, only: [:show], constraints: {id: /.+/}
|
resources :tree, only: [:show], constraints: {id: /.+/}
|
||||||
|
|
|
@ -69,7 +69,7 @@ describe "Gitlab Flavored Markdown" do
|
||||||
end
|
end
|
||||||
|
|
||||||
it "should render title in refs#blame" do
|
it "should render title in refs#blame" do
|
||||||
visit blame_file_project_ref_path(project, id: @branch_name, path: @test_file)
|
visit blame_file_project_ref_path(project, File.join(@branch_name, @test_file))
|
||||||
|
|
||||||
within(".blame_commit") do
|
within(".blame_commit") do
|
||||||
page.should have_link("##{issue.id}")
|
page.should have_link("##{issue.id}")
|
||||||
|
|
|
@ -195,7 +195,6 @@ end
|
||||||
# blob_project_ref GET /:project_id/:id/blob(.:format) refs#blob
|
# blob_project_ref GET /:project_id/:id/blob(.:format) refs#blob
|
||||||
# logs_tree_project_ref GET /:project_id/:id/logs_tree(.:format) refs#logs_tree
|
# logs_tree_project_ref GET /:project_id/:id/logs_tree(.:format) refs#logs_tree
|
||||||
# logs_file_project_ref GET /:project_id/:id/logs_tree/:path(.:format) refs#logs_tree
|
# logs_file_project_ref GET /:project_id/:id/logs_tree/:path(.:format) refs#logs_tree
|
||||||
# blame_file_project_ref GET /:project_id/:id/blame/:path(.:format) refs#blame
|
|
||||||
describe RefsController, "routing" do
|
describe RefsController, "routing" do
|
||||||
it "to #switch" do
|
it "to #switch" do
|
||||||
get("/gitlabhq/switch").should route_to('refs#switch', project_id: 'gitlabhq')
|
get("/gitlabhq/switch").should route_to('refs#switch', project_id: 'gitlabhq')
|
||||||
|
@ -209,10 +208,6 @@ describe RefsController, "routing" do
|
||||||
it "to #blob" do
|
it "to #blob" do
|
||||||
get("/gitlabhq/stable/blob").should route_to('refs#blob', project_id: 'gitlabhq', id: 'stable')
|
get("/gitlabhq/stable/blob").should route_to('refs#blob', project_id: 'gitlabhq', id: 'stable')
|
||||||
end
|
end
|
||||||
|
|
||||||
it "to #blame" do
|
|
||||||
get("/gitlabhq/stable/blame/foo/bar/baz").should route_to('refs#blame', project_id: 'gitlabhq', id: 'stable', path: 'foo/bar/baz')
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
# diffs_project_merge_request GET /:project_id/merge_requests/:id/diffs(.:format) merge_requests#diffs
|
# diffs_project_merge_request GET /:project_id/merge_requests/:id/diffs(.:format) merge_requests#diffs
|
||||||
|
@ -399,6 +394,12 @@ describe NotesController, "routing" do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
describe BlameController, "routing" do
|
||||||
|
it "to #show" do
|
||||||
|
get("/gitlabhq/blame/master/app/models/project.rb").should route_to('blame#show', project_id: 'gitlabhq', id: 'master/app/models/project.rb')
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
describe TreeController, "routing" do
|
describe TreeController, "routing" do
|
||||||
it "to #show" do
|
it "to #show" do
|
||||||
get("/gitlabhq/tree/master/app/models/project.rb").should route_to('tree#show', project_id: 'gitlabhq', id: 'master/app/models/project.rb')
|
get("/gitlabhq/tree/master/app/models/project.rb").should route_to('tree#show', project_id: 'gitlabhq', id: 'master/app/models/project.rb')
|
||||||
|
@ -432,11 +433,7 @@ end
|
||||||
# /gitlabhq/tree/master/app
|
# /gitlabhq/tree/master/app
|
||||||
# /gitlabhq/tree/test/branch/name/app
|
# /gitlabhq/tree/test/branch/name/app
|
||||||
describe "pending routing" do
|
describe "pending routing" do
|
||||||
describe "/:project_id/blame/:id" do
|
before { pending }
|
||||||
it "routes to a ref with a path" do
|
|
||||||
get("/gitlabhq/blame/master/app/models/project.rb").should route_to('blame#show', project_id: 'gitlabhq', id: 'master/app/models/project.rb')
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
describe "/:project_id/blob/:id" do
|
describe "/:project_id/blob/:id" do
|
||||||
it "routes to a ref with a path" do
|
it "routes to a ref with a path" do
|
||||||
|
|
Loading…
Reference in a new issue