Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
99537660
Commit
99537660
authored
Oct 21, 2019
by
Jesse Hall
Committed by
Sean McGivern
Oct 21, 2019
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Feature #33533, redirect to root when path does not exist on branch
parent
20251668
Changes
11
Hide whitespace changes
Inline
Side-by-side
Showing
11 changed files
with
113 additions
and
16 deletions
+113
-16
app/controllers/concerns/redirects_for_missing_path_on_tree.rb
...ontrollers/concerns/redirects_for_missing_path_on_tree.rb
+17
-0
app/controllers/projects/blame_controller.rb
app/controllers/projects/blame_controller.rb
+4
-1
app/controllers/projects/blob_controller.rb
app/controllers/projects/blob_controller.rb
+2
-1
app/controllers/projects/tree_controller.rb
app/controllers/projects/tree_controller.rb
+3
-5
changelogs/unreleased/33533-go-to-root-if-no-path-on-branch.yml
...logs/unreleased/33533-go-to-root-if-no-path-on-branch.yml
+6
-0
locale/gitlab.pot
locale/gitlab.pot
+3
-0
spec/controllers/concerns/redirects_for_missing_path_on_tree_spec.rb
...llers/concerns/redirects_for_missing_path_on_tree_spec.rb
+33
-0
spec/controllers/projects/blame_controller_spec.rb
spec/controllers/projects/blame_controller_spec.rb
+15
-4
spec/controllers/projects/blob_controller_spec.rb
spec/controllers/projects/blob_controller_spec.rb
+10
-1
spec/controllers/projects/tree_controller_spec.rb
spec/controllers/projects/tree_controller_spec.rb
+18
-2
spec/requests/git_http_spec.rb
spec/requests/git_http_spec.rb
+2
-2
No files found.
app/controllers/concerns/redirects_for_missing_path_on_tree.rb
0 → 100644
View file @
99537660
# frozen_string_literal: true
module
RedirectsForMissingPathOnTree
def
redirect_to_tree_root_for_missing_path
(
project
,
ref
,
path
)
redirect_to
project_tree_path
(
project
,
ref
),
notice:
missing_path_on_ref
(
path
,
ref
)
end
private
def
missing_path_on_ref
(
path
,
ref
)
_
(
'"%{path}" did not exist on "%{ref}"'
)
%
{
path:
truncate_path
(
path
),
ref:
ref
}
end
def
truncate_path
(
path
)
path
.
reverse
.
truncate
(
60
,
separator:
"/"
).
reverse
end
end
app/controllers/projects/blame_controller.rb
View file @
99537660
...
@@ -3,6 +3,7 @@
...
@@ -3,6 +3,7 @@
# Controller for viewing a file's blame
# Controller for viewing a file's blame
class
Projects::BlameController
<
Projects
::
ApplicationController
class
Projects::BlameController
<
Projects
::
ApplicationController
include
ExtractsPath
include
ExtractsPath
include
RedirectsForMissingPathOnTree
before_action
:require_non_empty_project
before_action
:require_non_empty_project
before_action
:assign_ref_vars
before_action
:assign_ref_vars
...
@@ -11,7 +12,9 @@ class Projects::BlameController < Projects::ApplicationController
...
@@ -11,7 +12,9 @@ class Projects::BlameController < Projects::ApplicationController
def
show
def
show
@blob
=
@repository
.
blob_at
(
@commit
.
id
,
@path
)
@blob
=
@repository
.
blob_at
(
@commit
.
id
,
@path
)
return
render_404
unless
@blob
unless
@blob
return
redirect_to_tree_root_for_missing_path
(
@project
,
@ref
,
@path
)
end
environment_params
=
@repository
.
branch_exists?
(
@ref
)
?
{
ref:
@ref
}
:
{
commit:
@commit
}
environment_params
=
@repository
.
branch_exists?
(
@ref
)
?
{
ref:
@ref
}
:
{
commit:
@commit
}
@environment
=
EnvironmentsFinder
.
new
(
@project
,
current_user
,
environment_params
).
execute
.
last
@environment
=
EnvironmentsFinder
.
new
(
@project
,
current_user
,
environment_params
).
execute
.
last
...
...
app/controllers/projects/blob_controller.rb
View file @
99537660
...
@@ -7,6 +7,7 @@ class Projects::BlobController < Projects::ApplicationController
...
@@ -7,6 +7,7 @@ class Projects::BlobController < Projects::ApplicationController
include
RendersBlob
include
RendersBlob
include
NotesHelper
include
NotesHelper
include
ActionView
::
Helpers
::
SanitizeHelper
include
ActionView
::
Helpers
::
SanitizeHelper
include
RedirectsForMissingPathOnTree
prepend_before_action
:authenticate_user!
,
only:
[
:edit
]
prepend_before_action
:authenticate_user!
,
only:
[
:edit
]
around_action
:allow_gitaly_ref_name_caching
,
only:
[
:show
]
around_action
:allow_gitaly_ref_name_caching
,
only:
[
:show
]
...
@@ -119,7 +120,7 @@ class Projects::BlobController < Projects::ApplicationController
...
@@ -119,7 +120,7 @@ class Projects::BlobController < Projects::ApplicationController
end
end
end
end
return
re
nder_404
return
re
direct_to_tree_root_for_missing_path
(
@project
,
@ref
,
@path
)
end
end
end
end
...
...
app/controllers/projects/tree_controller.rb
View file @
99537660
...
@@ -5,6 +5,7 @@ class Projects::TreeController < Projects::ApplicationController
...
@@ -5,6 +5,7 @@ class Projects::TreeController < Projects::ApplicationController
include
ExtractsPath
include
ExtractsPath
include
CreatesCommit
include
CreatesCommit
include
ActionView
::
Helpers
::
SanitizeHelper
include
ActionView
::
Helpers
::
SanitizeHelper
include
RedirectsForMissingPathOnTree
around_action
:allow_gitaly_ref_name_caching
,
only:
[
:show
]
around_action
:allow_gitaly_ref_name_caching
,
only:
[
:show
]
...
@@ -19,12 +20,9 @@ class Projects::TreeController < Projects::ApplicationController
...
@@ -19,12 +20,9 @@ class Projects::TreeController < Projects::ApplicationController
if
tree
.
entries
.
empty?
if
tree
.
entries
.
empty?
if
@repository
.
blob_at
(
@commit
.
id
,
@path
)
if
@repository
.
blob_at
(
@commit
.
id
,
@path
)
return
redirect_to
(
return
redirect_to
project_blob_path
(
@project
,
File
.
join
(
@ref
,
@path
))
project_blob_path
(
@project
,
File
.
join
(
@ref
,
@path
))
)
elsif
@path
.
present?
elsif
@path
.
present?
return
re
nder_404
return
re
direct_to_tree_root_for_missing_path
(
@project
,
@ref
,
@path
)
end
end
end
end
...
...
changelogs/unreleased/33533-go-to-root-if-no-path-on-branch.yml
0 → 100644
View file @
99537660
---
title
:
When a user views a file's blame or blob and switches to a branch where the
current file does not exist, they will now be redirected to the root of the repository.
merge_request
:
18169
author
:
Jesse Hall @jessehall3
type
:
changed
locale/gitlab.pot
View file @
99537660
...
@@ -62,6 +62,9 @@ msgstr ""
...
@@ -62,6 +62,9 @@ msgstr ""
msgid " or references (e.g. path/to/project!merge_request_id)"
msgid " or references (e.g. path/to/project!merge_request_id)"
msgstr ""
msgstr ""
msgid "\"%{path}\" did not exist on \"%{ref}\""
msgstr ""
msgid "%d comment"
msgid "%d comment"
msgid_plural "%d comments"
msgid_plural "%d comments"
msgstr[0] ""
msgstr[0] ""
...
...
spec/controllers/concerns/redirects_for_missing_path_on_tree_spec.rb
0 → 100644
View file @
99537660
# frozen_string_literal: true
require
'spec_helper'
describe
RedirectsForMissingPathOnTree
,
type: :controller
do
controller
(
ActionController
::
Base
)
do
include
Gitlab
::
Routing
.
url_helpers
include
RedirectsForMissingPathOnTree
def
fake
redirect_to_tree_root_for_missing_path
(
Project
.
find
(
params
[
:project_id
]),
params
[
:ref
],
params
[
:file_path
])
end
end
let
(
:project
)
{
create
(
:project
)
}
before
do
routes
.
draw
{
get
'fake'
=>
'anonymous#fake'
}
end
describe
'#redirect_to_root_path'
do
it
'redirects to the tree path with a notice'
do
long_file_path
=
(
'a/b/'
*
30
)
+
'foo.txt'
truncated_file_path
=
'...b/'
+
(
'a/b/'
*
12
)
+
'foo.txt'
expected_message
=
"
\"
#{
truncated_file_path
}
\"
did not exist on
\"
theref
\"
"
get
:fake
,
params:
{
project_id:
project
.
id
,
ref:
'theref'
,
file_path:
long_file_path
}
expect
(
response
).
to
redirect_to
project_tree_path
(
project
,
'theref'
)
expect
(
response
.
flash
[
:notice
]).
to
eq
(
expected_message
)
end
end
end
spec/controllers/projects/blame_controller_spec.rb
View file @
99537660
...
@@ -25,14 +25,25 @@ describe Projects::BlameController do
...
@@ -25,14 +25,25 @@ describe Projects::BlameController do
})
})
end
end
context
"valid file"
do
context
"valid
branch, valid
file"
do
let
(
:id
)
{
'master/files/ruby/popen.rb'
}
let
(
:id
)
{
'master/files/ruby/popen.rb'
}
it
{
is_expected
.
to
respond_with
(
:success
)
}
it
{
is_expected
.
to
respond_with
(
:success
)
}
end
end
context
"invalid file"
do
context
"valid branch, invalid file"
do
let
(
:id
)
{
'master/files/ruby/missing_file.rb'
}
let
(
:id
)
{
'master/files/ruby/invalid-path.rb'
}
it
{
expect
(
response
).
to
have_gitlab_http_status
(
404
)
}
it
'redirects'
do
expect
(
subject
)
.
to
redirect_to
(
"/
#{
project
.
full_path
}
/tree/master"
)
end
end
context
"invalid branch, valid file"
do
let
(
:id
)
{
'invalid-branch/files/ruby/missing_file.rb'
}
it
{
is_expected
.
to
respond_with
(
:not_found
)
}
end
end
end
end
end
end
spec/controllers/projects/blob_controller_spec.rb
View file @
99537660
...
@@ -24,26 +24,34 @@ describe Projects::BlobController do
...
@@ -24,26 +24,34 @@ describe Projects::BlobController do
context
"valid branch, valid file"
do
context
"valid branch, valid file"
do
let
(
:id
)
{
'master/README.md'
}
let
(
:id
)
{
'master/README.md'
}
it
{
is_expected
.
to
respond_with
(
:success
)
}
it
{
is_expected
.
to
respond_with
(
:success
)
}
end
end
context
"valid branch, invalid file"
do
context
"valid branch, invalid file"
do
let
(
:id
)
{
'master/invalid-path.rb'
}
let
(
:id
)
{
'master/invalid-path.rb'
}
it
{
is_expected
.
to
respond_with
(
:not_found
)
}
it
'redirects'
do
expect
(
subject
)
.
to
redirect_to
(
"/
#{
project
.
full_path
}
/tree/master"
)
end
end
end
context
"invalid branch, valid file"
do
context
"invalid branch, valid file"
do
let
(
:id
)
{
'invalid-branch/README.md'
}
let
(
:id
)
{
'invalid-branch/README.md'
}
it
{
is_expected
.
to
respond_with
(
:not_found
)
}
it
{
is_expected
.
to
respond_with
(
:not_found
)
}
end
end
context
"binary file"
do
context
"binary file"
do
let
(
:id
)
{
'binary-encoding/encoding/binary-1.bin'
}
let
(
:id
)
{
'binary-encoding/encoding/binary-1.bin'
}
it
{
is_expected
.
to
respond_with
(
:success
)
}
it
{
is_expected
.
to
respond_with
(
:success
)
}
end
end
context
"Markdown file"
do
context
"Markdown file"
do
let
(
:id
)
{
'master/README.md'
}
let
(
:id
)
{
'master/README.md'
}
it
{
is_expected
.
to
respond_with
(
:success
)
}
it
{
is_expected
.
to
respond_with
(
:success
)
}
end
end
end
end
...
@@ -104,6 +112,7 @@ describe Projects::BlobController do
...
@@ -104,6 +112,7 @@ describe Projects::BlobController do
context
'redirect to tree'
do
context
'redirect to tree'
do
let
(
:id
)
{
'markdown/doc'
}
let
(
:id
)
{
'markdown/doc'
}
it
'redirects'
do
it
'redirects'
do
expect
(
subject
)
expect
(
subject
)
.
to
redirect_to
(
"/
#{
project
.
full_path
}
/tree/markdown/doc"
)
.
to
redirect_to
(
"/
#{
project
.
full_path
}
/tree/markdown/doc"
)
...
...
spec/controllers/projects/tree_controller_spec.rb
View file @
99537660
...
@@ -30,46 +30,61 @@ describe Projects::TreeController do
...
@@ -30,46 +30,61 @@ describe Projects::TreeController do
context
"valid branch, no path"
do
context
"valid branch, no path"
do
let
(
:id
)
{
'master'
}
let
(
:id
)
{
'master'
}
it
{
is_expected
.
to
respond_with
(
:success
)
}
it
{
is_expected
.
to
respond_with
(
:success
)
}
end
end
context
"valid branch, valid path"
do
context
"valid branch, valid path"
do
let
(
:id
)
{
'master/encoding/'
}
let
(
:id
)
{
'master/encoding/'
}
it
{
is_expected
.
to
respond_with
(
:success
)
}
it
{
is_expected
.
to
respond_with
(
:success
)
}
end
end
context
"valid branch, invalid path"
do
context
"valid branch, invalid path"
do
let
(
:id
)
{
'master/invalid-path/'
}
let
(
:id
)
{
'master/invalid-path/'
}
it
{
is_expected
.
to
respond_with
(
:not_found
)
}
it
'redirects'
do
expect
(
subject
)
.
to
redirect_to
(
"/
#{
project
.
full_path
}
/tree/master"
)
end
end
end
context
"invalid branch, valid path"
do
context
"invalid branch, valid path"
do
let
(
:id
)
{
'invalid-branch/encoding/'
}
let
(
:id
)
{
'invalid-branch/encoding/'
}
it
{
is_expected
.
to
respond_with
(
:not_found
)
}
it
{
is_expected
.
to
respond_with
(
:not_found
)
}
end
end
context
"valid empty branch, invalid path"
do
context
"valid empty branch, invalid path"
do
let
(
:id
)
{
'empty-branch/invalid-path/'
}
let
(
:id
)
{
'empty-branch/invalid-path/'
}
it
{
is_expected
.
to
respond_with
(
:not_found
)
}
it
'redirects'
do
expect
(
subject
)
.
to
redirect_to
(
"/
#{
project
.
full_path
}
/tree/empty-branch"
)
end
end
end
context
"valid empty branch"
do
context
"valid empty branch"
do
let
(
:id
)
{
'empty-branch'
}
let
(
:id
)
{
'empty-branch'
}
it
{
is_expected
.
to
respond_with
(
:success
)
}
it
{
is_expected
.
to
respond_with
(
:success
)
}
end
end
context
"invalid SHA commit ID"
do
context
"invalid SHA commit ID"
do
let
(
:id
)
{
'ff39438/.gitignore'
}
let
(
:id
)
{
'ff39438/.gitignore'
}
it
{
is_expected
.
to
respond_with
(
:not_found
)
}
it
{
is_expected
.
to
respond_with
(
:not_found
)
}
end
end
context
"valid SHA commit ID"
do
context
"valid SHA commit ID"
do
let
(
:id
)
{
'6d39438'
}
let
(
:id
)
{
'6d39438'
}
it
{
is_expected
.
to
respond_with
(
:success
)
}
it
{
is_expected
.
to
respond_with
(
:success
)
}
end
end
context
"valid SHA commit ID with path"
do
context
"valid SHA commit ID with path"
do
let
(
:id
)
{
'6d39438/.gitignore'
}
let
(
:id
)
{
'6d39438/.gitignore'
}
it
{
expect
(
response
).
to
have_gitlab_http_status
(
302
)
}
it
{
expect
(
response
).
to
have_gitlab_http_status
(
302
)
}
end
end
end
end
...
@@ -108,6 +123,7 @@ describe Projects::TreeController do
...
@@ -108,6 +123,7 @@ describe Projects::TreeController do
context
'redirect to blob'
do
context
'redirect to blob'
do
let
(
:id
)
{
'master/README.md'
}
let
(
:id
)
{
'master/README.md'
}
it
'redirects'
do
it
'redirects'
do
redirect_url
=
"/
#{
project
.
full_path
}
/blob/master/README.md"
redirect_url
=
"/
#{
project
.
full_path
}
/blob/master/README.md"
expect
(
subject
)
expect
(
subject
)
...
...
spec/requests/git_http_spec.rb
View file @
99537660
...
@@ -843,8 +843,8 @@ describe 'Git HTTP requests' do
...
@@ -843,8 +843,8 @@ describe 'Git HTTP requests' do
get
"/
#{
project
.
full_path
}
/blob/master/info/refs"
get
"/
#{
project
.
full_path
}
/blob/master/info/refs"
end
end
it
"re
turns not found
"
do
it
"re
directs
"
do
expect
(
response
).
to
have_gitlab_http_status
(
:not_found
)
expect
(
response
).
to
have_gitlab_http_status
(
302
)
end
end
end
end
end
end
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment