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
0
Merge Requests
0
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
Boxiang Sun
gitlab-ce
Commits
dc229c07
Commit
dc229c07
authored
Jan 26, 2018
by
Tiago Botelho
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Abstracts ProjectMoved and ProjectCreated into a BaseProject
parent
e42a548f
Changes
14
Hide whitespace changes
Inline
Side-by-side
Showing
14 changed files
with
141 additions
and
158 deletions
+141
-158
app/services/projects/create_from_push_service.rb
app/services/projects/create_from_push_service.rb
+1
-1
lib/api/helpers/internal_helpers.rb
lib/api/helpers/internal_helpers.rb
+6
-2
lib/api/internal.rb
lib/api/internal.rb
+2
-2
lib/gitlab/checks/base_project.rb
lib/gitlab/checks/base_project.rb
+46
-0
lib/gitlab/checks/project_created.rb
lib/gitlab/checks/project_created.rb
+4
-35
lib/gitlab/checks/project_moved.rb
lib/gitlab/checks/project_moved.rb
+8
-30
lib/gitlab/git_access.rb
lib/gitlab/git_access.rb
+12
-22
lib/gitlab/path_regex.rb
lib/gitlab/path_regex.rb
+1
-1
spec/lib/gitlab/checks/project_created_spec.rb
spec/lib/gitlab/checks/project_created_spec.rb
+11
-11
spec/lib/gitlab/checks/project_moved_spec.rb
spec/lib/gitlab/checks/project_moved_spec.rb
+20
-20
spec/lib/gitlab/git_access_spec.rb
spec/lib/gitlab/git_access_spec.rb
+7
-23
spec/requests/api/internal_spec.rb
spec/requests/api/internal_spec.rb
+18
-6
spec/requests/git_http_spec.rb
spec/requests/git_http_spec.rb
+4
-4
spec/services/projects/create_from_push_service_spec.rb
spec/services/projects/create_from_push_service_spec.rb
+1
-1
No files found.
app/services/projects/create_from_push_service.rb
View file @
dc229c07
...
@@ -15,7 +15,7 @@ module Projects
...
@@ -15,7 +15,7 @@ module Projects
project
=
Projects
::
CreateService
.
new
(
user
,
project_params
).
execute
project
=
Projects
::
CreateService
.
new
(
user
,
project_params
).
execute
if
project
.
saved?
if
project
.
saved?
Gitlab
::
Checks
::
ProjectCreated
.
new
(
user
,
project
,
protocol
).
add_project_create
d_message
Gitlab
::
Checks
::
ProjectCreated
.
new
(
project
,
user
,
protocol
).
ad
d_message
else
else
raise
Gitlab
::
GitAccess
::
ProjectCreationError
,
"Could not create project:
#{
project
.
errors
.
full_messages
.
join
(
', '
)
}
"
raise
Gitlab
::
GitAccess
::
ProjectCreationError
,
"Could not create project:
#{
project
.
errors
.
full_messages
.
join
(
', '
)
}
"
end
end
...
...
lib/api/helpers/internal_helpers.rb
View file @
dc229c07
module
API
module
API
module
Helpers
module
Helpers
module
InternalHelpers
module
InternalHelpers
include
Gitlab
::
Utils
::
StrongMemoize
attr_reader
:redirected_path
attr_reader
:redirected_path
def
wiki?
def
wiki?
...
@@ -65,13 +67,15 @@ module API
...
@@ -65,13 +67,15 @@ module API
end
end
def
project_namespace
def
project_namespace
@project_namespace
||=
project
&
.
namespace
||
Namespace
.
find_by_full_path
(
project_match
[
:namespace_path
])
strong_memoize
(
:project_namespace
)
do
project
&
.
namespace
||
Namespace
.
find_by_full_path
(
project_match
[
:namespace_path
])
end
end
end
private
private
def
project_match
def
project_match
@project_match
||=
params
[
:project
].
match
(
Gitlab
::
PathRegex
.
full_project_git_path_regex
)
@project_match
||=
params
[
:project
].
match
(
Gitlab
::
PathRegex
.
full_project_git_path_regex
)
||
{}
end
end
# rubocop:disable Gitlab/ModuleWithInstanceVariables
# rubocop:disable Gitlab/ModuleWithInstanceVariables
...
...
lib/api/internal.rb
View file @
dc229c07
...
@@ -215,8 +215,8 @@ module API
...
@@ -215,8 +215,8 @@ module API
# A user is not guaranteed to be returned; an orphaned write deploy
# A user is not guaranteed to be returned; an orphaned write deploy
# key could be used
# key could be used
if
user
if
user
redirect_message
=
Gitlab
::
Checks
::
ProjectMoved
.
fetch_
redirect_
message
(
user
.
id
,
project
.
id
)
redirect_message
=
Gitlab
::
Checks
::
ProjectMoved
.
fetch_message
(
user
.
id
,
project
.
id
)
project_created_message
=
Gitlab
::
Checks
::
ProjectCreated
.
fetch_
project_created_
message
(
user
.
id
,
project
.
id
)
project_created_message
=
Gitlab
::
Checks
::
ProjectCreated
.
fetch_message
(
user
.
id
,
project
.
id
)
output
[
:redirected_message
]
=
redirect_message
if
redirect_message
output
[
:redirected_message
]
=
redirect_message
if
redirect_message
output
[
:project_created_message
]
=
project_created_message
if
project_created_message
output
[
:project_created_message
]
=
project_created_message
if
project_created_message
...
...
lib/gitlab/checks/base_project.rb
0 → 100644
View file @
dc229c07
module
Gitlab
module
Checks
class
BaseProject
def
initialize
(
project
,
user
,
protocol
)
@project
=
project
@user
=
user
@protocol
=
protocol
end
def
self
.
fetch_message
(
user_id
,
project_id
)
key
=
message_key
(
user_id
,
project_id
)
Gitlab
::
Redis
::
SharedState
.
with
do
|
redis
|
message
=
redis
.
get
(
key
)
redis
.
del
(
key
)
message
end
end
def
add_message
return
unless
user
.
present?
&&
project
.
present?
Gitlab
::
Redis
::
SharedState
.
with
do
|
redis
|
key
=
self
.
class
.
message_key
(
user
.
id
,
project
.
id
)
redis
.
setex
(
key
,
5
.
minutes
,
message
)
end
end
def
message
raise
NotImplementedError
end
protected
attr_reader
:project
,
:user
,
:protocol
def
self
.
message_key
(
user_id
,
project_id
)
raise
NotImplementedError
end
def
url_to_repo
protocol
==
'ssh'
?
project
.
ssh_url_to_repo
:
project
.
http_url_to_repo
end
end
end
end
lib/gitlab/checks/project_created.rb
View file @
dc229c07
module
Gitlab
module
Gitlab
module
Checks
module
Checks
class
ProjectCreated
class
ProjectCreated
<
BaseProject
PROJECT_CREATED
=
"project_created"
.
freeze
PROJECT_CREATED
=
"project_created"
.
freeze
def
initialize
(
user
,
project
,
protocol
)
def
message
@user
=
user
@project
=
project
@protocol
=
protocol
end
def
self
.
fetch_project_created_message
(
user_id
,
project_id
)
project_created_key
=
project_created_message_key
(
user_id
,
project_id
)
Gitlab
::
Redis
::
SharedState
.
with
do
|
redis
|
message
=
redis
.
get
(
project_created_key
)
redis
.
del
(
project_created_key
)
message
end
end
def
add_project_created_message
return
unless
user
.
present?
&&
project
.
present?
Gitlab
::
Redis
::
SharedState
.
with
do
|
redis
|
key
=
self
.
class
.
project_created_message_key
(
user
.
id
,
project
.
id
)
redis
.
setex
(
key
,
5
.
minutes
,
project_created_message
)
end
end
def
project_created_message
<<~
MESSAGE
.
strip_heredoc
<<~
MESSAGE
.
strip_heredoc
The private project
#{
project
.
full_path
}
was created.
The private project
#{
project
.
full_path
}
was created.
To configure the remote, run:
To configure the remote, run:
git remote add origin
#{
git_url
}
git remote add origin
#{
url_to_repo
}
To view the project, visit:
To view the project, visit:
#{
project_url
}
#{
project_url
}
...
@@ -44,19 +19,13 @@ module Gitlab
...
@@ -44,19 +19,13 @@ module Gitlab
private
private
attr_reader
:project
,
:user
,
:protocol
def
self
.
message_key
(
user_id
,
project_id
)
def
self
.
project_created_message_key
(
user_id
,
project_id
)
"
#{
PROJECT_CREATED
}
:
#{
user_id
}
:
#{
project_id
}
"
"
#{
PROJECT_CREATED
}
:
#{
user_id
}
:
#{
project_id
}
"
end
end
def
project_url
def
project_url
Gitlab
::
Routing
.
url_helpers
.
project_url
(
project
)
Gitlab
::
Routing
.
url_helpers
.
project_url
(
project
)
end
end
def
git_url
protocol
==
'ssh'
?
project
.
ssh_url_to_repo
:
project
.
http_url_to_repo
end
end
end
end
end
end
end
lib/gitlab/checks/project_moved.rb
View file @
dc229c07
module
Gitlab
module
Gitlab
module
Checks
module
Checks
class
ProjectMoved
class
ProjectMoved
<
BaseProject
REDIRECT_NAMESPACE
=
"redirect_namespace"
.
freeze
REDIRECT_NAMESPACE
=
"redirect_namespace"
.
freeze
def
initialize
(
project
,
user
,
redirected_path
,
protocol
)
def
initialize
(
project
,
user
,
protocol
,
redirected_path
)
@project
=
project
@user
=
user
@redirected_path
=
redirected_path
@redirected_path
=
redirected_path
@protocol
=
protocol
end
def
self
.
fetch_redirect_message
(
user_id
,
project_id
)
redirect_key
=
redirect_message_key
(
user_id
,
project_id
)
Gitlab
::
Redis
::
SharedState
.
with
do
|
redis
|
super
(
project
,
user
,
protocol
)
message
=
redis
.
get
(
redirect_key
)
redis
.
del
(
redirect_key
)
message
end
end
def
add_redirect_message
# Don't bother with sending a redirect message for anonymous clones
# because they never see it via the `/internal/post_receive` endpoint
return
unless
user
.
present?
&&
project
.
present?
Gitlab
::
Redis
::
SharedState
.
with
do
|
redis
|
key
=
self
.
class
.
redirect_message_key
(
user
.
id
,
project
.
id
)
redis
.
setex
(
key
,
5
.
minutes
,
redirect_message
)
end
end
end
def
redirect_
message
(
rejected:
false
)
def
message
(
rejected:
false
)
<<~
MESSAGE
.
strip_heredoc
<<~
MESSAGE
.
strip_heredoc
Project '
#{
redirected_path
}
' was moved to '
#{
project
.
full_path
}
'.
Project '
#{
redirected_path
}
' was moved to '
#{
project
.
full_path
}
'.
...
@@ -47,17 +25,17 @@ module Gitlab
...
@@ -47,17 +25,17 @@ module Gitlab
private
private
attr_reader
:
project
,
:redirected_path
,
:protocol
,
:user
attr_reader
:
redirected_path
def
self
.
redirect_
message_key
(
user_id
,
project_id
)
def
self
.
message_key
(
user_id
,
project_id
)
"
#{
REDIRECT_NAMESPACE
}
:
#{
user_id
}
:
#{
project_id
}
"
"
#{
REDIRECT_NAMESPACE
}
:
#{
user_id
}
:
#{
project_id
}
"
end
end
def
remote_url_message
(
rejected
)
def
remote_url_message
(
rejected
)
if
rejected
if
rejected
"git remote set-url origin
#{
url
}
and try again."
"git remote set-url origin
#{
url
_to_repo
}
and try again."
else
else
"git remote set-url origin
#{
url
}
"
"git remote set-url origin
#{
url
_to_repo
}
"
end
end
end
end
...
...
lib/gitlab/git_access.rb
View file @
dc229c07
...
@@ -19,8 +19,7 @@ module Gitlab
...
@@ -19,8 +19,7 @@ module Gitlab
upload_pack_disabled_over_http:
'Pulling over HTTP is not allowed.'
,
upload_pack_disabled_over_http:
'Pulling over HTTP is not allowed.'
,
receive_pack_disabled_over_http:
'Pushing over HTTP is not allowed.'
,
receive_pack_disabled_over_http:
'Pushing over HTTP is not allowed.'
,
read_only:
'The repository is temporarily read-only. Please try again later.'
,
read_only:
'The repository is temporarily read-only. Please try again later.'
,
cannot_push_to_read_only:
"You can't push code to a read-only GitLab instance."
,
cannot_push_to_read_only:
"You can't push code to a read-only GitLab instance."
namespace_not_found:
'The namespace you were looking for could not be found.'
}.
freeze
}.
freeze
DOWNLOAD_COMMANDS
=
%w{ git-upload-pack git-upload-archive }
.
freeze
DOWNLOAD_COMMANDS
=
%w{ git-upload-pack git-upload-archive }
.
freeze
...
@@ -53,7 +52,6 @@ module Gitlab
...
@@ -53,7 +52,6 @@ module Gitlab
check_download_access!
check_download_access!
when
*
PUSH_COMMANDS
when
*
PUSH_COMMANDS
check_push_access!
(
cmd
,
changes
)
check_push_access!
(
cmd
,
changes
)
check_namespace_accessibility!
end
end
true
true
...
@@ -100,7 +98,7 @@ module Gitlab
...
@@ -100,7 +98,7 @@ module Gitlab
end
end
def
check_project_accessibility!
(
cmd
)
def
check_project_accessibility!
(
cmd
)
if
(
project
.
blank?
||
!
can_read_project?
)
&&
!
can_create_project_in_namespace?
(
cmd
)
unless
can_create_project_in_namespace?
(
cmd
)
||
can_read_project?
raise
NotFoundError
,
ERROR_MESSAGES
[
:project_not_found
]
raise
NotFoundError
,
ERROR_MESSAGES
[
:project_not_found
]
end
end
end
end
...
@@ -108,12 +106,12 @@ module Gitlab
...
@@ -108,12 +106,12 @@ module Gitlab
def
check_project_moved!
def
check_project_moved!
return
if
redirected_path
.
nil?
return
if
redirected_path
.
nil?
project_moved
=
Checks
::
ProjectMoved
.
new
(
project
,
user
,
redirected_path
,
protocol
)
project_moved
=
Checks
::
ProjectMoved
.
new
(
project
,
user
,
protocol
,
redirected_path
)
if
project_moved
.
permanent_redirect?
if
project_moved
.
permanent_redirect?
project_moved
.
add_
redirect_
message
project_moved
.
add_message
else
else
raise
ProjectMovedError
,
project_moved
.
redirect_
message
(
rejected:
true
)
raise
ProjectMovedError
,
project_moved
.
message
(
rejected:
true
)
end
end
end
end
...
@@ -144,19 +142,11 @@ module Gitlab
...
@@ -144,19 +142,11 @@ module Gitlab
end
end
def
check_repository_existence!
(
cmd
)
def
check_repository_existence!
(
cmd
)
if
(
project
.
blank?
||
!
project
.
repository
.
exists?
)
&&
!
can_create_project_in_namespace?
(
cmd
)
unless
can_create_project_in_namespace?
(
cmd
)
||
project
.
repository
.
exists?
raise
UnauthorizedError
,
ERROR_MESSAGES
[
:no_repo
]
raise
UnauthorizedError
,
ERROR_MESSAGES
[
:no_repo
]
end
end
end
end
def
check_namespace_accessibility!
return
unless
project
.
blank?
unless
target_namespace
raise
NotFoundError
,
ERROR_MESSAGES
[
:namespace_not_found
]
end
end
def
check_download_access!
def
check_download_access!
return
if
deploy_key?
return
if
deploy_key?
...
@@ -170,16 +160,16 @@ module Gitlab
...
@@ -170,16 +160,16 @@ module Gitlab
end
end
def
check_push_access!
(
cmd
,
changes
)
def
check_push_access!
(
cmd
,
changes
)
return
if
project
.
blank?
&&
can_create_project_in_namespace?
(
cmd
)
if
Gitlab
::
Database
.
read_only?
raise
UnauthorizedError
,
push_to_read_only_message
end
return
if
can_create_project_in_namespace?
(
cmd
)
if
project
.
repository_read_only?
if
project
.
repository_read_only?
raise
UnauthorizedError
,
ERROR_MESSAGES
[
:read_only
]
raise
UnauthorizedError
,
ERROR_MESSAGES
[
:read_only
]
end
end
if
Gitlab
::
Database
.
read_only?
raise
UnauthorizedError
,
push_to_read_only_message
end
if
deploy_key
if
deploy_key
check_deploy_key_push_access!
check_deploy_key_push_access!
elsif
user
elsif
user
...
@@ -249,7 +239,7 @@ module Gitlab
...
@@ -249,7 +239,7 @@ module Gitlab
end
end
def
can_create_project_in_namespace?
(
cmd
)
def
can_create_project_in_namespace?
(
cmd
)
return
false
unless
push?
(
cmd
)
&&
target_namespace
return
false
unless
push?
(
cmd
)
&&
target_namespace
&&
project
.
blank?
user
.
can?
(
:create_projects
,
target_namespace
)
user
.
can?
(
:create_projects
,
target_namespace
)
end
end
...
...
lib/gitlab/path_regex.rb
View file @
dc229c07
...
@@ -188,7 +188,7 @@ module Gitlab
...
@@ -188,7 +188,7 @@ module Gitlab
end
end
def
full_project_git_path_regex
def
full_project_git_path_regex
@full_project_git_path_regex
||=
/\A
(\/|)
(?<namespace_path>
#{
full_namespace_route_regex
}
)\/(?<project_path>
#{
project_git_route_regex
}
)\z/
.
freeze
@full_project_git_path_regex
||=
/\A
\/?
(?<namespace_path>
#{
full_namespace_route_regex
}
)\/(?<project_path>
#{
project_git_route_regex
}
)\z/
.
freeze
end
end
def
full_namespace_format_regex
def
full_namespace_format_regex
...
...
spec/lib/gitlab/checks/project_created_spec.rb
View file @
dc229c07
...
@@ -4,43 +4,43 @@ describe Gitlab::Checks::ProjectCreated, :clean_gitlab_redis_shared_state do
...
@@ -4,43 +4,43 @@ describe Gitlab::Checks::ProjectCreated, :clean_gitlab_redis_shared_state do
let
(
:user
)
{
create
(
:user
)
}
let
(
:user
)
{
create
(
:user
)
}
let
(
:project
)
{
create
(
:project
)
}
let
(
:project
)
{
create
(
:project
)
}
describe
'.fetch_
project_created_
message'
do
describe
'.fetch_message'
do
context
'with a project created message queue'
do
context
'with a project created message queue'
do
let
(
:project_created
)
{
described_class
.
new
(
user
,
project
,
'http'
)
}
let
(
:project_created
)
{
described_class
.
new
(
project
,
user
,
'http'
)
}
before
do
before
do
project_created
.
add_
project_created_
message
project_created
.
add_message
end
end
it
'returns project created message'
do
it
'returns project created message'
do
expect
(
described_class
.
fetch_
project_created_message
(
user
.
id
,
project
.
id
)).
to
eq
(
project_created
.
project_created_
message
)
expect
(
described_class
.
fetch_
message
(
user
.
id
,
project
.
id
)).
to
eq
(
project_created
.
message
)
end
end
it
'deletes the project created message from redis'
do
it
'deletes the project created message from redis'
do
expect
(
Gitlab
::
Redis
::
SharedState
.
with
{
|
redis
|
redis
.
get
(
"project_created:
#{
user
.
id
}
:
#{
project
.
id
}
"
)
}).
not_to
be_nil
expect
(
Gitlab
::
Redis
::
SharedState
.
with
{
|
redis
|
redis
.
get
(
"project_created:
#{
user
.
id
}
:
#{
project
.
id
}
"
)
}).
not_to
be_nil
described_class
.
fetch_
project_created_
message
(
user
.
id
,
project
.
id
)
described_class
.
fetch_message
(
user
.
id
,
project
.
id
)
expect
(
Gitlab
::
Redis
::
SharedState
.
with
{
|
redis
|
redis
.
get
(
"project_created:
#{
user
.
id
}
:
#{
project
.
id
}
"
)
}).
to
be_nil
expect
(
Gitlab
::
Redis
::
SharedState
.
with
{
|
redis
|
redis
.
get
(
"project_created:
#{
user
.
id
}
:
#{
project
.
id
}
"
)
}).
to
be_nil
end
end
end
end
context
'with no project created message queue'
do
context
'with no project created message queue'
do
it
'returns nil'
do
it
'returns nil'
do
expect
(
described_class
.
fetch_
project_created_
message
(
1
,
2
)).
to
be_nil
expect
(
described_class
.
fetch_message
(
1
,
2
)).
to
be_nil
end
end
end
end
end
end
describe
'#add_
project_created_
message'
do
describe
'#add_message'
do
it
'queues a project created message'
do
it
'queues a project created message'
do
project_created
=
described_class
.
new
(
user
,
project
,
'http'
)
project_created
=
described_class
.
new
(
project
,
user
,
'http'
)
expect
(
project_created
.
add_
project_created_
message
).
to
eq
(
'OK'
)
expect
(
project_created
.
add_message
).
to
eq
(
'OK'
)
end
end
it
'handles anonymous push'
do
it
'handles anonymous push'
do
project_created
=
described_class
.
new
(
user
,
nil
,
'http'
)
project_created
=
described_class
.
new
(
nil
,
user
,
'http'
)
expect
(
project_created
.
add_
project_created_
message
).
to
be_nil
expect
(
project_created
.
add_message
).
to
be_nil
end
end
end
end
end
end
spec/lib/gitlab/checks/project_moved_spec.rb
View file @
dc229c07
...
@@ -4,65 +4,65 @@ describe Gitlab::Checks::ProjectMoved, :clean_gitlab_redis_shared_state do
...
@@ -4,65 +4,65 @@ describe Gitlab::Checks::ProjectMoved, :clean_gitlab_redis_shared_state do
let
(
:user
)
{
create
(
:user
)
}
let
(
:user
)
{
create
(
:user
)
}
let
(
:project
)
{
create
(
:project
)
}
let
(
:project
)
{
create
(
:project
)
}
describe
'.fetch_
redirct_
message'
do
describe
'.fetch_message'
do
context
'with a redirect message queue'
do
context
'with a redirect message queue'
do
it
'returns the redirect message'
do
it
'returns the redirect message'
do
project_moved
=
described_class
.
new
(
project
,
user
,
'
foo/bar'
,
'http
'
)
project_moved
=
described_class
.
new
(
project
,
user
,
'
http'
,
'foo/bar
'
)
project_moved
.
add_
redirect_
message
project_moved
.
add_message
expect
(
described_class
.
fetch_
redirect_message
(
user
.
id
,
project
.
id
)).
to
eq
(
project_moved
.
redirect_
message
)
expect
(
described_class
.
fetch_
message
(
user
.
id
,
project
.
id
)).
to
eq
(
project_moved
.
message
)
end
end
it
'deletes the redirect message from redis'
do
it
'deletes the redirect message from redis'
do
project_moved
=
described_class
.
new
(
project
,
user
,
'
foo/bar'
,
'http
'
)
project_moved
=
described_class
.
new
(
project
,
user
,
'
http'
,
'foo/bar
'
)
project_moved
.
add_
redirect_
message
project_moved
.
add_message
expect
(
Gitlab
::
Redis
::
SharedState
.
with
{
|
redis
|
redis
.
get
(
"redirect_namespace:
#{
user
.
id
}
:
#{
project
.
id
}
"
)
}).
not_to
be_nil
expect
(
Gitlab
::
Redis
::
SharedState
.
with
{
|
redis
|
redis
.
get
(
"redirect_namespace:
#{
user
.
id
}
:
#{
project
.
id
}
"
)
}).
not_to
be_nil
described_class
.
fetch_
redirect_
message
(
user
.
id
,
project
.
id
)
described_class
.
fetch_message
(
user
.
id
,
project
.
id
)
expect
(
Gitlab
::
Redis
::
SharedState
.
with
{
|
redis
|
redis
.
get
(
"redirect_namespace:
#{
user
.
id
}
:
#{
project
.
id
}
"
)
}).
to
be_nil
expect
(
Gitlab
::
Redis
::
SharedState
.
with
{
|
redis
|
redis
.
get
(
"redirect_namespace:
#{
user
.
id
}
:
#{
project
.
id
}
"
)
}).
to
be_nil
end
end
end
end
context
'with no redirect message queue'
do
context
'with no redirect message queue'
do
it
'returns nil'
do
it
'returns nil'
do
expect
(
described_class
.
fetch_
redirect_
message
(
1
,
2
)).
to
be_nil
expect
(
described_class
.
fetch_message
(
1
,
2
)).
to
be_nil
end
end
end
end
end
end
describe
'#add_
redirect_
message'
do
describe
'#add_message'
do
it
'queues a redirect message'
do
it
'queues a redirect message'
do
project_moved
=
described_class
.
new
(
project
,
user
,
'
foo/bar'
,
'http
'
)
project_moved
=
described_class
.
new
(
project
,
user
,
'
http'
,
'foo/bar
'
)
expect
(
project_moved
.
add_
redirect_
message
).
to
eq
(
"OK"
)
expect
(
project_moved
.
add_message
).
to
eq
(
"OK"
)
end
end
it
'handles anonymous clones'
do
it
'handles anonymous clones'
do
project_moved
=
described_class
.
new
(
project
,
nil
,
'
foo/bar'
,
'http
'
)
project_moved
=
described_class
.
new
(
project
,
nil
,
'
http'
,
'foo/bar
'
)
expect
(
project_moved
.
add_
redirect_
message
).
to
eq
(
nil
)
expect
(
project_moved
.
add_message
).
to
eq
(
nil
)
end
end
end
end
describe
'#
redirect_
message'
do
describe
'#message'
do
context
'when the push is rejected'
do
context
'when the push is rejected'
do
it
'returns a redirect message telling the user to try again'
do
it
'returns a redirect message telling the user to try again'
do
project_moved
=
described_class
.
new
(
project
,
user
,
'
foo/bar'
,
'http
'
)
project_moved
=
described_class
.
new
(
project
,
user
,
'
http'
,
'foo/bar
'
)
message
=
"Project 'foo/bar' was moved to '
#{
project
.
full_path
}
'."
+
message
=
"Project 'foo/bar' was moved to '
#{
project
.
full_path
}
'."
+
"
\n\n
Please update your Git remote:"
+
"
\n\n
Please update your Git remote:"
+
"
\n\n
git remote set-url origin
#{
project
.
http_url_to_repo
}
and try again.
\n
"
"
\n\n
git remote set-url origin
#{
project
.
http_url_to_repo
}
and try again.
\n
"
expect
(
project_moved
.
redirect_
message
(
rejected:
true
)).
to
eq
(
message
)
expect
(
project_moved
.
message
(
rejected:
true
)).
to
eq
(
message
)
end
end
end
end
context
'when the push is not rejected'
do
context
'when the push is not rejected'
do
it
'returns a redirect message'
do
it
'returns a redirect message'
do
project_moved
=
described_class
.
new
(
project
,
user
,
'
foo/bar'
,
'http
'
)
project_moved
=
described_class
.
new
(
project
,
user
,
'
http'
,
'foo/bar
'
)
message
=
"Project 'foo/bar' was moved to '
#{
project
.
full_path
}
'."
+
message
=
"Project 'foo/bar' was moved to '
#{
project
.
full_path
}
'."
+
"
\n\n
Please update your Git remote:"
+
"
\n\n
Please update your Git remote:"
+
"
\n\n
git remote set-url origin
#{
project
.
http_url_to_repo
}
\n
"
"
\n\n
git remote set-url origin
#{
project
.
http_url_to_repo
}
\n
"
expect
(
project_moved
.
redirect_
message
).
to
eq
(
message
)
expect
(
project_moved
.
message
).
to
eq
(
message
)
end
end
end
end
end
end
...
@@ -71,7 +71,7 @@ describe Gitlab::Checks::ProjectMoved, :clean_gitlab_redis_shared_state do
...
@@ -71,7 +71,7 @@ describe Gitlab::Checks::ProjectMoved, :clean_gitlab_redis_shared_state do
context
'with a permanent RedirectRoute'
do
context
'with a permanent RedirectRoute'
do
it
'returns true'
do
it
'returns true'
do
project
.
route
.
create_redirect
(
'foo/bar'
,
permanent:
true
)
project
.
route
.
create_redirect
(
'foo/bar'
,
permanent:
true
)
project_moved
=
described_class
.
new
(
project
,
user
,
'
foo/bar'
,
'http
'
)
project_moved
=
described_class
.
new
(
project
,
user
,
'
http'
,
'foo/bar
'
)
expect
(
project_moved
.
permanent_redirect?
).
to
be_truthy
expect
(
project_moved
.
permanent_redirect?
).
to
be_truthy
end
end
end
end
...
@@ -79,7 +79,7 @@ describe Gitlab::Checks::ProjectMoved, :clean_gitlab_redis_shared_state do
...
@@ -79,7 +79,7 @@ describe Gitlab::Checks::ProjectMoved, :clean_gitlab_redis_shared_state do
context
'without a permanent RedirectRoute'
do
context
'without a permanent RedirectRoute'
do
it
'returns false'
do
it
'returns false'
do
project
.
route
.
create_redirect
(
'foo/bar'
)
project
.
route
.
create_redirect
(
'foo/bar'
)
project_moved
=
described_class
.
new
(
project
,
user
,
'
foo/bar'
,
'http
'
)
project_moved
=
described_class
.
new
(
project
,
user
,
'
http'
,
'foo/bar
'
)
expect
(
project_moved
.
permanent_redirect?
).
to
be_falsy
expect
(
project_moved
.
permanent_redirect?
).
to
be_falsy
end
end
end
end
...
...
spec/lib/gitlab/git_access_spec.rb
View file @
dc229c07
...
@@ -221,7 +221,7 @@ describe Gitlab::GitAccess do
...
@@ -221,7 +221,7 @@ describe Gitlab::GitAccess do
it
'enqueues a redirected message'
do
it
'enqueues a redirected message'
do
push_access_check
push_access_check
expect
(
Gitlab
::
Checks
::
ProjectMoved
.
fetch_
redirect_
message
(
user
.
id
,
project
.
id
)).
not_to
be_nil
expect
(
Gitlab
::
Checks
::
ProjectMoved
.
fetch_message
(
user
.
id
,
project
.
id
)).
not_to
be_nil
end
end
end
end
...
@@ -335,7 +335,7 @@ describe Gitlab::GitAccess do
...
@@ -335,7 +335,7 @@ describe Gitlab::GitAccess do
end
end
end
end
describe
'#check_namespace_
existence
!'
do
describe
'#check_namespace_
accessibility
!'
do
context
'when project exists'
do
context
'when project exists'
do
context
'when user can pull or push'
do
context
'when user can pull or push'
do
before
do
before
do
...
@@ -352,28 +352,16 @@ describe Gitlab::GitAccess do
...
@@ -352,28 +352,16 @@ describe Gitlab::GitAccess do
end
end
context
'when project does not exist'
do
context
'when project does not exist'
do
context
'when namespace does not exist'
do
let
(
:access
)
{
described_class
.
new
(
actor
,
nil
,
protocol
,
authentication_abilities:
authentication_abilities
,
redirected_path:
redirected_path
,
target_namespace:
nil
)
}
it
'blocks push and pull'
do
aggregate_failures
do
expect
{
push_access_check
}.
not_to
raise_namespace_not_found
expect
{
pull_access_check
}.
not_to
raise_namespace_not_found
end
end
end
context
'when namespace exists'
do
context
'when namespace exists'
do
context
'when user is unable to push to namespace'
do
context
'when user is unable to push to namespace'
do
let
(
:user2
)
{
create
(
:user
)
}
let
(
:user2
)
{
create
(
:user
)
}
let
(
:access
)
{
described_class
.
new
(
actor
,
nil
,
protocol
,
authentication_abilities:
authentication_abilities
,
redirected_path:
redirected_path
,
target_namespace:
user2
.
namespace
)
}
let
(
:access
)
{
described_class
.
new
(
actor
,
nil
,
protocol
,
authentication_abilities:
authentication_abilities
,
redirected_path:
redirected_path
,
target_namespace:
user2
.
namespace
)
}
it
'blocks push'
do
it
'blocks push and pull'
do
expect
{
push_access_check
}.
to
raise_project_create
aggregate_failures
do
end
expect
{
push_access_check
}.
to
raise_not_found
expect
{
pull_access_check
}.
to
raise_not_found
it
'does not block pull'
do
end
expect
{
push_access_check
}.
to
raise_error
end
end
end
end
end
end
...
@@ -841,10 +829,6 @@ describe Gitlab::GitAccess do
...
@@ -841,10 +829,6 @@ describe Gitlab::GitAccess do
raise_error
(
Gitlab
::
GitAccess
::
NotFoundError
,
Gitlab
::
GitAccess
::
ERROR_MESSAGES
[
:project_not_found
])
raise_error
(
Gitlab
::
GitAccess
::
NotFoundError
,
Gitlab
::
GitAccess
::
ERROR_MESSAGES
[
:project_not_found
])
end
end
def
raise_namespace_not_found
raise_error
(
Gitlab
::
GitAccess
::
NotFoundError
,
Gitlab
::
GitAccess
::
ERROR_MESSAGES
[
:namespace_not_found
])
end
def
build_authentication_abilities
def
build_authentication_abilities
[
[
:read_project
,
:read_project
,
...
...
spec/requests/api/internal_spec.rb
View file @
dc229c07
...
@@ -399,6 +399,18 @@ describe API::Internal do
...
@@ -399,6 +399,18 @@ describe API::Internal do
expect
(
json_response
[
"status"
]).
to
be_truthy
expect
(
json_response
[
"status"
]).
to
be_truthy
expect
(
json_response
[
"gitaly"
][
"repository"
][
"relative_path"
]).
to
eq
(
path
)
expect
(
json_response
[
"gitaly"
][
"repository"
][
"relative_path"
]).
to
eq
(
path
)
end
end
it
'handles project creation failure'
do
path
=
"
#{
user
.
namespace
.
path
}
/new.git"
expect
do
push_with_path
(
key
,
path
)
end
.
not_to
change
{
Project
.
count
}
expect
(
response
).
to
have_gitlab_http_status
(
200
)
expect
(
json_response
[
"status"
]).
to
be_falsey
expect
(
json_response
[
"message"
]).
to
eq
(
"Could not create project: Path new is a reserved name"
)
end
end
end
end
end
end
end
...
@@ -821,27 +833,27 @@ describe API::Internal do
...
@@ -821,27 +833,27 @@ describe API::Internal do
context
'with a redirected data'
do
context
'with a redirected data'
do
it
'returns redirected message on the response'
do
it
'returns redirected message on the response'
do
project_moved
=
Gitlab
::
Checks
::
ProjectMoved
.
new
(
project
,
user
,
'
foo/baz'
,
'http
'
)
project_moved
=
Gitlab
::
Checks
::
ProjectMoved
.
new
(
project
,
user
,
'
http'
,
'foo/baz
'
)
project_moved
.
add_
redirect_
message
project_moved
.
add_message
post
api
(
"/internal/post_receive"
),
valid_params
post
api
(
"/internal/post_receive"
),
valid_params
expect
(
response
).
to
have_gitlab_http_status
(
200
)
expect
(
response
).
to
have_gitlab_http_status
(
200
)
expect
(
json_response
[
"redirected_message"
]).
to
be_present
expect
(
json_response
[
"redirected_message"
]).
to
be_present
expect
(
json_response
[
"redirected_message"
]).
to
eq
(
project_moved
.
redirect_
message
)
expect
(
json_response
[
"redirected_message"
]).
to
eq
(
project_moved
.
message
)
end
end
end
end
context
'with new project data'
do
context
'with new project data'
do
it
'returns new project message on the response'
do
it
'returns new project message on the response'
do
project_created
=
Gitlab
::
Checks
::
ProjectCreated
.
new
(
user
,
project
,
'http'
)
project_created
=
Gitlab
::
Checks
::
ProjectCreated
.
new
(
project
,
user
,
'http'
)
project_created
.
add_
project_created_
message
project_created
.
add_message
post
api
(
"/internal/post_receive"
),
valid_params
post
api
(
"/internal/post_receive"
),
valid_params
expect
(
response
).
to
have_gitlab_http_status
(
200
)
expect
(
response
).
to
have_gitlab_http_status
(
200
)
expect
(
json_response
[
"project_created_message"
]).
to
be_present
expect
(
json_response
[
"project_created_message"
]).
to
be_present
expect
(
json_response
[
"project_created_message"
]).
to
eq
(
project_created
.
project_created_
message
)
expect
(
json_response
[
"project_created_message"
]).
to
eq
(
project_created
.
message
)
end
end
end
end
...
...
spec/requests/git_http_spec.rb
View file @
dc229c07
...
@@ -134,12 +134,12 @@ describe 'Git HTTP requests' do
...
@@ -134,12 +134,12 @@ describe 'Git HTTP requests' do
end
.
to
change
{
user
.
projects
.
count
}.
by
(
1
)
end
.
to
change
{
user
.
projects
.
count
}.
by
(
1
)
end
end
it
'rejects
upload with 404 Not Found
when project is invalid'
do
it
'rejects
push with 422 Unprocessable Entity
when project is invalid'
do
path
=
"
#{
user
.
namespace
.
path
}
/new.git"
path
=
"
#{
user
.
namespace
.
path
}
/new.git"
upload
(
path
,
user:
user
.
username
,
password:
user
.
password
)
do
|
response
|
push_get
(
path
,
user:
user
.
username
,
password:
user
.
password
)
expect
(
response
).
to
have_gitlab_http_status
(
:not_found
)
e
nd
e
xpect
(
response
).
to
have_gitlab_http_status
(
:unprocessable_entity
)
end
end
end
end
end
end
...
...
spec/services/projects/create_from_push_service_spec.rb
View file @
dc229c07
...
@@ -23,7 +23,7 @@ describe Projects::CreateFromPushService do
...
@@ -23,7 +23,7 @@ describe Projects::CreateFromPushService do
context
'when user is nil'
do
context
'when user is nil'
do
let
(
:user
)
{
nil
}
let
(
:user
)
{
nil
}
subject
{
described_class
.
new
(
user
,
project_path
,
namespace
,
cmd
,
protocol
)
}
subject
{
described_class
.
new
(
user
,
project_path
,
namespace
,
protocol
)
}
it
'returns nil'
do
it
'returns nil'
do
expect_any_instance_of
(
Projects
::
CreateService
).
not_to
receive
(
:execute
)
expect_any_instance_of
(
Projects
::
CreateService
).
not_to
receive
(
:execute
)
...
...
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