summaryrefslogtreecommitdiff
path: root/spec/requests/api/files_spec.rb
diff options
context:
space:
mode:
authorRémy Coutable <remy@rymai.me>2016-12-16 18:58:24 +0100
committerRémy Coutable <remy@rymai.me>2016-12-20 16:11:09 +0100
commit5652da8bb4ea26acd35a241683e242439fefdd33 (patch)
tree913d4c0936de7b623a1d9297aa8421f7f6805868 /spec/requests/api/files_spec.rb
parentd84cfeaf21bb60c09061ad6c7bf135c37d063162 (diff)
downloadgitlab-ce-5652da8bb4ea26acd35a241683e242439fefdd33.tar.gz
Allow unauthenticated access to Repositories Files API GET endpoints
Signed-off-by: Rémy Coutable <remy@rymai.me>
Diffstat (limited to 'spec/requests/api/files_spec.rb')
-rw-r--r--spec/requests/api/files_spec.rb37
1 files changed, 26 insertions, 11 deletions
diff --git a/spec/requests/api/files_spec.rb b/spec/requests/api/files_spec.rb
index 2081f80ccc1..4dd312e2852 100644
--- a/spec/requests/api/files_spec.rb
+++ b/spec/requests/api/files_spec.rb
@@ -24,19 +24,34 @@ describe API::Files, api: true do
before { project.team << [user, :developer] }
describe "GET /projects/:id/repository/files" do
- it "returns file info" do
- params = {
- file_path: file_path,
- ref: 'master',
- }
+ shared_examples_for 'repository files' do
+ it "returns file info" do
+ params = {
+ file_path: file_path,
+ ref: 'master',
+ }
- get api("/projects/#{project.id}/repository/files", user), params
+ get api("/projects/#{project.id}/repository/files", current_user), params
- expect(response).to have_http_status(200)
- expect(json_response['file_path']).to eq(file_path)
- expect(json_response['file_name']).to eq('popen.rb')
- expect(json_response['last_commit_id']).to eq('570e7b2abdd848b95f2f578043fc23bd6f6fd24d')
- expect(Base64.decode64(json_response['content']).lines.first).to eq("require 'fileutils'\n")
+ expect(response).to have_http_status(200)
+ expect(json_response['file_path']).to eq(file_path)
+ expect(json_response['file_name']).to eq('popen.rb')
+ expect(json_response['last_commit_id']).to eq('570e7b2abdd848b95f2f578043fc23bd6f6fd24d')
+ expect(Base64.decode64(json_response['content']).lines.first).to eq("require 'fileutils'\n")
+ end
+ end
+
+ context 'when unauthenticated' do
+ it_behaves_like 'repository files' do
+ let(:project) { create(:project, :public) }
+ let(:current_user) { nil }
+ end
+ end
+
+ context 'when authenticated' do
+ it_behaves_like 'repository files' do
+ let(:current_user) { user }
+ end
end
it "returns a 400 bad request if no params given" do