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
9772cefc
Commit
9772cefc
authored
Nov 19, 2013
by
Dmitriy Zaporozhets
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'feature/api_delete_file' of /home/git/repositories/gitlab/gitlabhq
parents
b0f30006
a185cce5
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
77 additions
and
3 deletions
+77
-3
doc/api/repositories.md
doc/api/repositories.md
+12
-0
lib/api/files.rb
lib/api/files.rb
+31
-3
spec/requests/api/files_spec.rb
spec/requests/api/files_spec.rb
+34
-0
No files found.
doc/api/repositories.md
View file @
9772cefc
...
@@ -397,3 +397,15 @@ Parameters:
...
@@ -397,3 +397,15 @@ Parameters:
+
`branch_name`
(required) - The name of branch
+
`branch_name`
(required) - The name of branch
+
`content`
(required) - New file content
+
`content`
(required) - New file content
+
`commit_message`
(required) - Commit message
+
`commit_message`
(required) - Commit message
## Delete existing file in repository
```
DELETE /projects/:id/repository/files
```
Parameters:
+
`file_path`
(required) - Full path to file. Ex. lib/class.rb
+
`branch_name`
(required) - The name of branch
+
`commit_message`
(required) - Commit message
lib/api/files.rb
View file @
9772cefc
...
@@ -40,8 +40,7 @@ module API
...
@@ -40,8 +40,7 @@ module API
# Update existing file in repository
# Update existing file in repository
#
#
# Parameters:
# Parameters:
# file_name (required) - The name of new file. Ex. class.rb
# file_path (optional) - The path to file. Ex. lib/class.rb
# file_path (optional) - The path to new file. Ex. lib/
# branch_name (required) - The name of branch
# branch_name (required) - The name of branch
# content (required) - File content
# content (required) - File content
# commit_message (required) - Commit message
# commit_message (required) - Commit message
...
@@ -67,7 +66,36 @@ module API
...
@@ -67,7 +66,36 @@ module API
render_api_error!
(
result
[
:error
],
400
)
render_api_error!
(
result
[
:error
],
400
)
end
end
end
end
# Delete existing file in repository
#
# Parameters:
# file_path (optional) - The path to file. Ex. lib/class.rb
# branch_name (required) - The name of branch
# content (required) - File content
# commit_message (required) - Commit message
#
# Example Request:
# DELETE /projects/:id/repository/files
#
delete
":id/repository/files"
do
required_attributes!
[
:file_path
,
:branch_name
,
:commit_message
]
attrs
=
attributes_for_keys
[
:file_path
,
:branch_name
,
:commit_message
]
branch_name
=
attrs
.
delete
(
:branch_name
)
file_path
=
attrs
.
delete
(
:file_path
)
result
=
::
Files
::
DeleteContext
.
new
(
user_project
,
current_user
,
attrs
,
branch_name
,
file_path
).
execute
if
result
[
:status
]
==
:success
status
(
200
)
{
file_path:
file_path
,
branch_name:
branch_name
}
else
render_api_error!
(
result
[
:error
],
400
)
end
end
end
end
end
end
end
end
spec/requests/api/files_spec.rb
View file @
9772cefc
...
@@ -78,4 +78,38 @@ describe API::API do
...
@@ -78,4 +78,38 @@ describe API::API do
response
.
status
.
should
==
400
response
.
status
.
should
==
400
end
end
end
end
describe
"DELETE /projects/:id/repository/files"
do
let
(
:valid_params
)
{
{
file_path:
'spec/spec_helper.rb'
,
branch_name:
'master'
,
commit_message:
'Changed file'
}
}
it
"should delete existing file in project repo"
do
Gitlab
::
Satellite
::
DeleteFileAction
.
any_instance
.
stub
(
commit!:
true
,
)
delete
api
(
"/projects/
#{
project
.
id
}
/repository/files"
,
user
),
valid_params
response
.
status
.
should
==
200
json_response
[
'file_path'
].
should
==
'spec/spec_helper.rb'
end
it
"should return a 400 bad request if no params given"
do
delete
api
(
"/projects/
#{
project
.
id
}
/repository/files"
,
user
)
response
.
status
.
should
==
400
end
it
"should return a 400 if satellite fails to create file"
do
Gitlab
::
Satellite
::
DeleteFileAction
.
any_instance
.
stub
(
commit!:
false
,
)
delete
api
(
"/projects/
#{
project
.
id
}
/repository/files"
,
user
),
valid_params
response
.
status
.
should
==
400
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