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
fbd559d4
Commit
fbd559d4
authored
Jul 04, 2012
by
Nihad Abbasov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
add API version
parent
378dc55d
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
37 additions
and
34 deletions
+37
-34
lib/api.rb
lib/api.rb
+3
-0
spec/api/projects_spec.rb
spec/api/projects_spec.rb
+19
-25
spec/api/users_spec.rb
spec/api/users_spec.rb
+8
-9
spec/support/api.rb
spec/support/api.rb
+7
-0
spec/support/security.rb
spec/support/security.rb
+0
-0
No files found.
lib/api.rb
View file @
fbd559d4
...
...
@@ -2,6 +2,9 @@ Dir["#{Rails.root}/lib/api/*.rb"].each {|file| require file}
module
Gitlab
class
API
<
Grape
::
API
VERSION
=
'v2'
version
VERSION
,
:using
=>
:path
format
:json
error_format
:json
helpers
APIHelpers
...
...
spec/api/projects_spec.rb
View file @
fbd559d4
...
...
@@ -8,75 +8,69 @@ describe Gitlab::API do
describe
"GET /projects"
do
it
"should return authentication error"
do
get
"
/api
/projects"
get
"
#{
api_prefix
}
/projects"
response
.
status
.
should
==
401
end
describe
"authenticated GET /projects"
do
it
"should return an array of projects"
do
get
"
/api
/projects?private_token=
#{
user
.
private_token
}
"
get
"
#{
api_prefix
}
/projects?private_token=
#{
user
.
private_token
}
"
response
.
status
.
should
==
200
json
=
JSON
.
parse
(
response
.
body
)
json
.
should
be_an
Array
json
.
first
[
'name'
].
should
==
project
.
name
json
.
first
[
'owner'
][
'email'
].
should
==
user
.
email
json_response
.
should
be_an
Array
json_response
.
first
[
'name'
].
should
==
project
.
name
json_response
.
first
[
'owner'
][
'email'
].
should
==
user
.
email
end
end
end
describe
"GET /projects/:id"
do
it
"should return a project by id"
do
get
"
/api
/projects/
#{
project
.
code
}
?private_token=
#{
user
.
private_token
}
"
get
"
#{
api_prefix
}
/projects/
#{
project
.
code
}
?private_token=
#{
user
.
private_token
}
"
response
.
status
.
should
==
200
json
=
JSON
.
parse
(
response
.
body
)
json
[
'name'
].
should
==
project
.
name
json
[
'owner'
][
'email'
].
should
==
user
.
email
json_response
[
'name'
].
should
==
project
.
name
json_response
[
'owner'
][
'email'
].
should
==
user
.
email
end
end
describe
"GET /projects/:id/repository/branches"
do
it
"should return an array of project branches"
do
get
"
/api
/projects/
#{
project
.
code
}
/repository/branches?private_token=
#{
user
.
private_token
}
"
get
"
#{
api_prefix
}
/projects/
#{
project
.
code
}
/repository/branches?private_token=
#{
user
.
private_token
}
"
response
.
status
.
should
==
200
json
=
JSON
.
parse
(
response
.
body
)
json
.
should
be_an
Array
json
.
first
[
'name'
].
should
==
project
.
repo
.
heads
.
sort_by
(
&
:name
).
first
.
name
json_response
.
should
be_an
Array
json_response
.
first
[
'name'
].
should
==
project
.
repo
.
heads
.
sort_by
(
&
:name
).
first
.
name
end
end
describe
"GET /projects/:id/repository/tags"
do
it
"should return an array of project tags"
do
get
"
/api
/projects/
#{
project
.
code
}
/repository/tags?private_token=
#{
user
.
private_token
}
"
get
"
#{
api_prefix
}
/projects/
#{
project
.
code
}
/repository/tags?private_token=
#{
user
.
private_token
}
"
response
.
status
.
should
==
200
json
=
JSON
.
parse
(
response
.
body
)
json
.
should
be_an
Array
json
.
first
[
'name'
].
should
==
project
.
repo
.
tags
.
sort_by
(
&
:name
).
reverse
.
first
.
name
json_response
.
should
be_an
Array
json_response
.
first
[
'name'
].
should
==
project
.
repo
.
tags
.
sort_by
(
&
:name
).
reverse
.
first
.
name
end
end
describe
"GET /projects/:id/snippets/:snippet_id"
do
it
"should return a project snippet"
do
get
"
/api
/projects/
#{
project
.
code
}
/snippets/
#{
snippet
.
id
}
?private_token=
#{
user
.
private_token
}
"
get
"
#{
api_prefix
}
/projects/
#{
project
.
code
}
/snippets/
#{
snippet
.
id
}
?private_token=
#{
user
.
private_token
}
"
response
.
status
.
should
==
200
json
=
JSON
.
parse
(
response
.
body
)
json
[
'title'
].
should
==
snippet
.
title
json_response
[
'title'
].
should
==
snippet
.
title
end
end
describe
"POST /projects/:id/snippets"
do
it
"should create a new project snippet"
do
post
"
/api
/projects/
#{
project
.
code
}
/snippets?private_token=
#{
user
.
private_token
}
"
,
post
"
#{
api_prefix
}
/projects/
#{
project
.
code
}
/snippets?private_token=
#{
user
.
private_token
}
"
,
:title
=>
'api test'
,
:file_name
=>
'sample.rb'
,
:code
=>
'test'
response
.
status
.
should
==
201
json
=
JSON
.
parse
(
response
.
body
)
json
[
'title'
].
should
==
'api test'
json_response
[
'title'
].
should
==
'api test'
end
end
describe
"DELETE /projects/:id/snippets/:snippet_id"
do
it
"should create a new project snippet"
do
expect
{
delete
"
/api
/projects/
#{
project
.
code
}
/snippets/
#{
snippet
.
id
}
?private_token=
#{
user
.
private_token
}
"
delete
"
#{
api_prefix
}
/projects/
#{
project
.
code
}
/snippets/
#{
snippet
.
id
}
?private_token=
#{
user
.
private_token
}
"
}.
should
change
{
Snippet
.
count
}.
by
(
-
1
)
end
end
...
...
spec/api/users_spec.rb
View file @
fbd559d4
...
...
@@ -5,34 +5,33 @@ describe Gitlab::API do
describe
"GET /users"
do
it
"should return authentication error"
do
get
"
/api
/users"
get
"
#{
api_prefix
}
/users"
response
.
status
.
should
==
401
end
describe
"authenticated GET /users"
do
it
"should return an array of users"
do
get
"
/api
/users?private_token=
#{
user
.
private_token
}
"
get
"
#{
api_prefix
}
/users?private_token=
#{
user
.
private_token
}
"
response
.
status
.
should
==
200
json
=
JSON
.
parse
(
response
.
body
)
json
.
should
be_an
Array
json
.
first
[
'email'
].
should
==
user
.
email
json_response
.
should
be_an
Array
json_response
.
first
[
'email'
].
should
==
user
.
email
end
end
end
describe
"GET /users/:id"
do
it
"should return a user by id"
do
get
"
/api
/users/
#{
user
.
id
}
?private_token=
#{
user
.
private_token
}
"
get
"
#{
api_prefix
}
/users/
#{
user
.
id
}
?private_token=
#{
user
.
private_token
}
"
response
.
status
.
should
==
200
JSON
.
parse
(
response
.
body
)
[
'email'
].
should
==
user
.
email
json_response
[
'email'
].
should
==
user
.
email
end
end
describe
"GET /user"
do
it
"should return current user"
do
get
"
/api
/user?private_token=
#{
user
.
private_token
}
"
get
"
#{
api_prefix
}
/user?private_token=
#{
user
.
private_token
}
"
response
.
status
.
should
==
200
JSON
.
parse
(
response
.
body
)
[
'email'
].
should
==
user
.
email
json_response
[
'email'
].
should
==
user
.
email
end
end
end
spec/support/api.rb
0 → 100644
View file @
fbd559d4
def
api_prefix
"/api/
#{
Gitlab
::
API
::
VERSION
}
"
end
def
json_response
JSON
.
parse
(
response
.
body
)
end
spec/support/security.rb
deleted
100644 → 0
View file @
378dc55d
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