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
e799a458
Commit
e799a458
authored
Dec 19, 2016
by
Rémy Coutable
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Improve specs for Repositories API
Signed-off-by:
Rémy Coutable
<
remy@rymai.me
>
parent
56e7a4dd
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
266 additions
and
114 deletions
+266
-114
changelogs/unreleased/4269-public-repositories-api.yml
changelogs/unreleased/4269-public-repositories-api.yml
+1
-1
spec/requests/api/repositories_spec.rb
spec/requests/api/repositories_spec.rb
+223
-113
spec/support/api/status_shared_examples.rb
spec/support/api/status_shared_examples.rb
+42
-0
No files found.
changelogs/unreleased/4269-public-repositories-api.yml
View file @
e799a458
---
title
:
Allow Repositories API GET endpoints to be requested anonymously
merge_request
:
merge_request
:
8148
author
:
spec/requests/api/repositories_spec.rb
View file @
e799a458
...
...
@@ -7,174 +7,239 @@ describe API::Repositories, api: true do
include
WorkhorseHelpers
let
(
:user
)
{
create
(
:user
)
}
let
(
:
user2
)
{
create
(
:user
)
}
let
(
:
guest
)
{
create
(
:user
).
tap
{
|
u
|
create
(
:project_member
,
:guest
,
user:
u
,
project:
project
)
}
}
let!
(
:project
)
{
create
(
:project
,
creator_id:
user
.
id
)
}
let!
(
:master
)
{
create
(
:project_member
,
:master
,
user:
user
,
project:
project
)
}
let!
(
:guest
)
{
create
(
:project_member
,
:guest
,
user:
user2
,
project:
project
)
}
shared_context
'disabled repository'
do
before
do
project
.
project_feature
.
update_attributes!
(
repository_access_level:
ProjectFeature
::
DISABLED
,
merge_requests_access_level:
ProjectFeature
::
DISABLED
,
builds_access_level:
ProjectFeature
::
DISABLED
)
expect
(
project
.
feature_available?
(
:repository
,
current_user
)).
to
be
false
end
end
describe
"GET /projects/:id/repository/tree"
do
context
"authorized user"
do
before
{
project
.
team
<<
[
user2
,
:reporter
]
}
let
(
:route
)
{
"/projects/
#{
project
.
id
}
/repository/tree"
}
shared_examples_for
'repository tree'
do
it
'returns the repository tree'
do
get
api
(
"/projects/
#{
project
.
id
}
/repository/tree"
,
current_user
)
shared_examples_for
'repository tree'
do
it
'returns the repository tree'
do
get
api
(
route
,
current_user
)
expect
(
response
).
to
have_http_status
(
200
)
expect
(
response
).
to
have_http_status
(
200
)
first_commit
=
json_response
.
first
first_commit
=
json_response
.
first
expect
(
json_response
).
to
be_an
Array
expect
(
first_commit
[
'name'
]).
to
eq
(
'bar'
)
expect
(
first_commit
[
'type'
]).
to
eq
(
'tree'
)
expect
(
first_commit
[
'mode'
]).
to
eq
(
'040000'
)
end
expect
(
json_response
).
to
be_an
Array
expect
(
first_commit
[
'name'
]).
to
eq
(
'bar'
)
expect
(
first_commit
[
'type'
]).
to
eq
(
'tree'
)
expect
(
first_commit
[
'mode'
]).
to
eq
(
'040000'
)
end
context
'when
unauthenticated
'
do
it_behaves_like
'
repository tre
e'
do
let
(
:
project
)
{
create
(
:project
,
:public
)
}
let
(
:
current_user
)
{
nil
}
context
'when
ref does not exist
'
do
it_behaves_like
'
404 respons
e'
do
let
(
:
request
)
{
get
api
(
"
#{
route
}
?ref_name=foo"
,
current_user
)
}
let
(
:
message
)
{
'404 Tree Not Found'
}
end
end
context
'when authenticated'
do
it_behaves_like
'repository tree'
do
let
(
:current_user
)
{
user
}
context
'when repository is disabled'
do
include_context
'disabled repository'
it_behaves_like
'403 response'
do
let
(
:request
)
{
get
api
(
route
,
current_user
)
}
end
end
it
'returns a 404 for unknown ref
'
do
get
api
(
"/projects/
#{
project
.
id
}
/repository/tree?ref_name=foo"
,
user
)
expect
(
response
).
to
have_http_status
(
404
)
context
'with recursive=1
'
do
it
'returns recursive project paths tree'
do
get
api
(
"
#{
route
}
?recursive=1"
,
current_user
)
expect
(
json_response
).
to
be_an
Object
json_response
[
'message'
]
==
'404 Tree Not Found'
end
end
expect
(
response
.
status
).
to
eq
(
200
)
expect
(
json_response
).
to
be_an
Array
expect
(
json_response
[
4
][
'name'
]).
to
eq
(
'html'
)
expect
(
json_response
[
4
][
'path'
]).
to
eq
(
'files/html'
)
expect
(
json_response
[
4
][
'type'
]).
to
eq
(
'tree'
)
expect
(
json_response
[
4
][
'mode'
]).
to
eq
(
'040000'
)
end
context
"unauthorized user"
do
it
"does not return project commits"
do
get
api
(
"/projects/
#{
project
.
id
}
/repository/tree"
)
context
'when repository is disabled'
do
include_context
'disabled repository'
expect
(
response
).
to
have_http_status
(
404
)
it_behaves_like
'403 response'
do
let
(
:request
)
{
get
api
(
route
,
current_user
)
}
end
end
context
'when ref does not exist'
do
it_behaves_like
'404 response'
do
let
(
:request
)
{
get
api
(
"
#{
route
}
?recursive=1&ref_name=foo"
,
current_user
)
}
let
(
:message
)
{
'404 Tree Not Found'
}
end
end
end
end
end
describe
'GET /projects/:id/repository/tree?recursive=1'
do
context
'authorized user'
do
before
{
project
.
team
<<
[
user2
,
:reporter
]
}
it
'should return recursive project paths tree'
do
get
api
(
"/projects/
#{
project
.
id
}
/repository/tree?recursive=1"
,
user
)
expect
(
response
.
status
).
to
eq
(
200
)
expect
(
json_response
).
to
be_an
Array
expect
(
json_response
[
4
][
'name'
]).
to
eq
(
'html'
)
expect
(
json_response
[
4
][
'path'
]).
to
eq
(
'files/html'
)
expect
(
json_response
[
4
][
'type'
]).
to
eq
(
'tree'
)
expect
(
json_response
[
4
][
'mode'
]).
to
eq
(
'040000'
)
context
'when unauthenticated'
,
'and project is public'
do
it_behaves_like
'repository tree'
do
let
(
:project
)
{
create
(
:project
,
:public
)
}
let
(
:current_user
)
{
nil
}
end
end
it
'returns a 404 for unknown ref'
do
get
api
(
"/projects/
#{
project
.
id
}
/repository/tree?ref_name=foo&recursive=1"
,
user
)
expect
(
response
).
to
have_http_status
(
404
)
expect
(
json_response
).
to
be_an
Object
json_response
[
'message'
]
==
'404 Tree Not Found'
context
'when unauthenticated'
,
'and project is private'
do
it_behaves_like
'404 response'
do
let
(
:request
)
{
get
api
(
route
)
}
let
(
:message
)
{
'404 Project Not Found'
}
end
end
context
"unauthorized user"
do
it
"does not return project commits"
do
get
api
(
"/projects/
#{
project
.
id
}
/repository/tree?recursive=1"
)
context
'when authenticated'
,
'as a developer'
do
it_behaves_like
'repository tree'
do
let
(
:current_user
)
{
user
}
end
end
expect
(
response
).
to
have_http_status
(
404
)
context
'when authenticated'
,
'as a guest'
do
it_behaves_like
'403 response'
do
let
(
:request
)
{
get
api
(
route
,
guest
)
}
end
end
end
describe
"GET /projects/:id/repository/blobs/:sha & /projects/:id/repository/commits/:sha"
do
shared_examples_for
'repository blob'
do
it
'returns the repository blob for /repository/blobs/master'
do
get
api
(
"/projects/
#{
project
.
id
}
/repository/blobs/master?filepath=README.md"
,
current_user
)
{
'blobs/:sha'
=>
'blobs/master'
,
'commits/:sha/blob'
=>
'commits/master/blob'
}.
each
do
|
desc_path
,
example_path
|
describe
"GET /projects/:id/repository/
#{
desc_path
}
"
do
let
(
:route
)
{
"/projects/
#{
project
.
id
}
/repository/
#{
example_path
}
?filepath=README.md"
}
expect
(
response
).
to
have_http_status
(
200
)
end
shared_examples_for
'repository blob'
do
it
'returns the repository blob'
do
get
api
(
route
,
current_user
)
it
'returns the repository blob for /repository/commits/master'
do
get
api
(
"/projects/
#{
project
.
id
}
/repository/commits/master/blob?filepath=README.md"
,
current_user
)
expect
(
response
).
to
have_http_status
(
200
)
end
expect
(
response
).
to
have_http_status
(
200
)
end
end
context
'when sha does not exist'
do
it_behaves_like
'404 response'
do
let
(
:request
)
{
get
api
(
route
.
sub
(
'master'
,
'invalid_branch_name'
),
current_user
)
}
let
(
:message
)
{
'404 Commit Not Found'
}
end
end
context
'when unauthenticated'
do
it_behaves_like
'repository blob'
do
let
(
:project
)
{
create
(
:project
,
:public
)
}
let
(
:current_user
)
{
nil
}
context
'when filepath does not exist'
do
it_behaves_like
'404 response'
do
let
(
:request
)
{
get
api
(
route
.
sub
(
'README.md'
,
'README.invalid'
),
current_user
)
}
let
(
:message
)
{
'404 File Not Found'
}
end
end
context
'when no filepath is given'
do
it_behaves_like
'400 response'
do
let
(
:request
)
{
get
api
(
route
.
sub
(
'?filepath=README.md'
,
''
),
current_user
)
}
end
end
context
'when repository is disabled'
do
include_context
'disabled repository'
it_behaves_like
'403 response'
do
let
(
:request
)
{
get
api
(
route
,
current_user
)
}
end
end
end
end
context
'when authenticated'
do
it_behaves_like
'repository blob'
do
let
(
:current_user
)
{
user
}
context
'when unauthenticated'
,
'and project is public'
do
it_behaves_like
'repository blob'
do
let
(
:project
)
{
create
(
:project
,
:public
)
}
let
(
:current_user
)
{
nil
}
end
end
end
it
"returns 404 for invalid branch_name"
do
get
api
(
"/projects/
#{
project
.
id
}
/repository/blobs/invalid_branch_name?filepath=README.md"
,
user
)
expect
(
response
).
to
have_http_status
(
404
)
end
context
'when unauthenticated'
,
'and project is private'
do
it_behaves_like
'404 response'
do
let
(
:request
)
{
get
api
(
route
)
}
let
(
:message
)
{
'404 Project Not Found'
}
end
end
it
"returns 404 for invalid file"
do
get
api
(
"/projects/
#{
project
.
id
}
/repository/blobs/master?filepath=README.invalid"
,
user
)
expect
(
response
).
to
have_http_status
(
404
)
end
context
'when authenticated'
,
'as a developer'
do
it_behaves_like
'repository blob'
do
let
(
:current_user
)
{
user
}
end
end
it
"returns a 400 error if filepath is missing"
do
get
api
(
"/projects/
#{
project
.
id
}
/repository/blobs/master"
,
user
)
expect
(
response
).
to
have_http_status
(
400
)
context
'when authenticated'
,
'as a guest'
do
it_behaves_like
'403 response'
do
let
(
:request
)
{
get
api
(
route
,
guest
)
}
end
end
end
end
describe
"GET /projects/:id/repository/raw_blobs/:sha"
do
let
(
:route
)
{
"/projects/
#{
project
.
id
}
/repository/raw_blobs/
#{
sample_blob
.
oid
}
"
}
shared_examples_for
'repository raw blob'
do
it
'returns the repository raw blob'
do
get
api
(
"/projects/
#{
project
.
id
}
/repository/raw_blobs/
#{
sample_blob
.
oid
}
"
,
current_user
)
get
api
(
route
,
current_user
)
expect
(
response
).
to
have_http_status
(
200
)
end
context
'when sha does not exist'
do
it_behaves_like
'404 response'
do
let
(
:request
)
{
get
api
(
route
.
sub
(
sample_blob
.
oid
,
'123456'
),
current_user
)
}
let
(
:message
)
{
'404 Blob Not Found'
}
end
end
context
'when repository is disabled'
do
include_context
'disabled repository'
it_behaves_like
'403 response'
do
let
(
:request
)
{
get
api
(
route
,
current_user
)
}
end
end
end
context
'when unauthenticated'
do
context
'when unauthenticated'
,
'and project is public'
do
it_behaves_like
'repository raw blob'
do
let
(
:project
)
{
create
(
:project
,
:public
)
}
let
(
:current_user
)
{
nil
}
end
end
context
'when authenticated'
do
context
'when unauthenticated'
,
'and project is private'
do
it_behaves_like
'404 response'
do
let
(
:request
)
{
get
api
(
route
)
}
let
(
:message
)
{
'404 Project Not Found'
}
end
end
context
'when authenticated'
,
'as a developer'
do
it_behaves_like
'repository raw blob'
do
let
(
:current_user
)
{
user
}
end
end
it
'returns a 404 for unknown blob'
do
get
api
(
"/projects/
#{
project
.
id
}
/repository/raw_blobs/123456"
,
user
)
expect
(
response
).
to
have_http_status
(
404
)
expect
(
json_response
).
to
be_an
Object
json_response
[
'message'
]
==
'404 Blob Not Found'
context
'when authenticated'
,
'as a guest'
do
it_behaves_like
'403 response'
do
let
(
:request
)
{
get
api
(
route
,
guest
)
}
end
end
end
describe
"GET /projects/:id/repository/archive(.:format)?:sha"
do
let
(
:route
)
{
"/projects/
#{
project
.
id
}
/repository/archive"
}
shared_examples_for
'repository archive'
do
it
'returns the repository archive'
do
get
api
(
"/projects/
#{
project
.
id
}
/repository/archive"
,
current_user
)
get
api
(
route
,
current_user
)
expect
(
response
).
to
have_http_status
(
200
)
...
...
@@ -208,31 +273,48 @@ describe API::Repositories, api: true do
expect
(
type
).
to
eq
(
'git-archive'
)
expect
(
params
[
'ArchivePath'
]).
to
match
(
/
#{
repo_name
}
\-[^\.]+\.tar.bz2/
)
end
context
'when sha does not exist'
do
it_behaves_like
'404 response'
do
let
(
:request
)
{
get
api
(
"
#{
route
}
?sha=xxx"
,
current_user
)
}
let
(
:message
)
{
'404 File Not Found'
}
end
end
end
context
'when unauthenticated'
do
context
'when unauthenticated'
,
'and project is public'
do
it_behaves_like
'repository archive'
do
let
(
:project
)
{
create
(
:project
,
:public
)
}
let
(
:current_user
)
{
nil
}
end
end
context
'when authenticated'
do
context
'when unauthenticated'
,
'and project is private'
do
it_behaves_like
'404 response'
do
let
(
:request
)
{
get
api
(
route
)
}
let
(
:message
)
{
'404 Project Not Found'
}
end
end
context
'when authenticated'
,
'as a developer'
do
it_behaves_like
'repository archive'
do
let
(
:current_user
)
{
user
}
end
end
it
"returns 404 for invalid sha"
do
get
api
(
"/projects/
#{
project
.
id
}
/repository/archive/?sha=xxx"
,
user
)
expect
(
response
).
to
have_http_status
(
404
)
context
'when authenticated'
,
'as a guest'
do
it_behaves_like
'403 response'
do
let
(
:request
)
{
get
api
(
route
,
guest
)
}
end
end
end
describe
'GET /projects/:id/repository/compare'
do
let
(
:route
)
{
"/projects/
#{
project
.
id
}
/repository/compare"
}
shared_examples_for
'repository compare'
do
it
"compares branches"
do
get
api
(
"/projects/
#{
project
.
id
}
/repository/compare"
,
current_user
),
from:
'master'
,
to:
'feature'
get
api
(
route
,
current_user
),
from:
'master'
,
to:
'feature'
expect
(
response
).
to
have_http_status
(
200
)
expect
(
json_response
[
'commits'
]).
to
be_present
...
...
@@ -240,7 +322,7 @@ describe API::Repositories, api: true do
end
it
"compares tags"
do
get
api
(
"/projects/
#{
project
.
id
}
/repository/compare"
,
current_user
),
from:
'v1.0.0'
,
to:
'v1.1.0'
get
api
(
route
,
current_user
),
from:
'v1.0.0'
,
to:
'v1.1.0'
expect
(
response
).
to
have_http_status
(
200
)
expect
(
json_response
[
'commits'
]).
to
be_present
...
...
@@ -248,7 +330,7 @@ describe API::Repositories, api: true do
end
it
"compares commits"
do
get
api
(
"/projects/
#{
project
.
id
}
/repository/compare"
,
current_user
),
from:
sample_commit
.
id
,
to:
sample_commit
.
parent_id
get
api
(
route
,
current_user
),
from:
sample_commit
.
id
,
to:
sample_commit
.
parent_id
expect
(
response
).
to
have_http_status
(
200
)
expect
(
json_response
[
'commits'
]).
to
be_empty
...
...
@@ -257,7 +339,7 @@ describe API::Repositories, api: true do
end
it
"compares commits in reverse order"
do
get
api
(
"/projects/
#{
project
.
id
}
/repository/compare"
,
current_user
),
from:
sample_commit
.
parent_id
,
to:
sample_commit
.
id
get
api
(
route
,
current_user
),
from:
sample_commit
.
parent_id
,
to:
sample_commit
.
id
expect
(
response
).
to
have_http_status
(
200
)
expect
(
json_response
[
'commits'
]).
to
be_present
...
...
@@ -265,7 +347,7 @@ describe API::Repositories, api: true do
end
it
"compares same refs"
do
get
api
(
"/projects/
#{
project
.
id
}
/repository/compare"
,
current_user
),
from:
'master'
,
to:
'master'
get
api
(
route
,
current_user
),
from:
'master'
,
to:
'master'
expect
(
response
).
to
have_http_status
(
200
)
expect
(
json_response
[
'commits'
]).
to
be_empty
...
...
@@ -274,24 +356,39 @@ describe API::Repositories, api: true do
end
end
context
'when unauthenticated'
do
context
'when unauthenticated'
,
'and project is public'
do
it_behaves_like
'repository compare'
do
let
(
:project
)
{
create
(
:project
,
:public
)
}
let
(
:current_user
)
{
nil
}
end
end
context
'when authenticated'
do
context
'when unauthenticated'
,
'and project is private'
do
it_behaves_like
'404 response'
do
let
(
:request
)
{
get
api
(
route
)
}
let
(
:message
)
{
'404 Project Not Found'
}
end
end
context
'when authenticated'
,
'as a developer'
do
it_behaves_like
'repository compare'
do
let
(
:current_user
)
{
user
}
end
end
context
'when authenticated'
,
'as a guest'
do
it_behaves_like
'403 response'
do
let
(
:request
)
{
get
api
(
route
,
guest
)
}
end
end
end
describe
'GET /projects/:id/repository/contributors'
do
let
(
:route
)
{
"/projects/
#{
project
.
id
}
/repository/contributors"
}
shared_examples_for
'repository contributors'
do
it
'returns valid data'
do
get
api
(
"/projects/
#{
project
.
id
}
/repository/contributors"
,
user
)
get
api
(
route
,
current_
user
)
expect
(
response
).
to
have_http_status
(
200
)
expect
(
json_response
).
to
be_an
Array
...
...
@@ -306,17 +403,30 @@ describe API::Repositories, api: true do
end
end
context
'when unauthenticated'
do
context
'when unauthenticated'
,
'and project is public'
do
it_behaves_like
'repository contributors'
do
let
(
:project
)
{
create
(
:project
,
:public
)
}
let
(
:current_user
)
{
nil
}
end
end
context
'when authenticated'
do
context
'when unauthenticated'
,
'and project is private'
do
it_behaves_like
'404 response'
do
let
(
:request
)
{
get
api
(
route
)
}
let
(
:message
)
{
'404 Project Not Found'
}
end
end
context
'when authenticated'
,
'as a developer'
do
it_behaves_like
'repository contributors'
do
let
(
:current_user
)
{
user
}
end
end
context
'when authenticated'
,
'as a guest'
do
it_behaves_like
'403 response'
do
let
(
:request
)
{
get
api
(
route
,
guest
)
}
end
end
end
end
spec/support/api/status_shared_examples.rb
0 → 100644
View file @
e799a458
# Specs for status checking.
#
# Requires an API request:
# let(:request) { get api("/projects/#{project.id}/repository/branches", user) }
shared_examples_for
'400 response'
do
before
do
# Fires the request
request
end
it
'returns 400'
do
expect
(
response
).
to
have_http_status
(
400
)
end
end
shared_examples_for
'403 response'
do
before
do
# Fires the request
request
end
it
'returns 403'
do
expect
(
response
).
to
have_http_status
(
403
)
end
end
shared_examples_for
'404 response'
do
let
(
:message
)
{
nil
}
before
do
# Fires the request
request
end
it
'returns 404'
do
expect
(
response
).
to
have_http_status
(
404
)
expect
(
json_response
).
to
be_an
Object
if
message
.
present?
expect
(
json_response
[
'message'
]).
to
eq
(
message
)
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