diff options
author | Douwe Maan <douwe@gitlab.com> | 2017-07-07 17:13:31 +0000 |
---|---|---|
committer | Douwe Maan <douwe@gitlab.com> | 2017-07-07 17:13:31 +0000 |
commit | 820aeb4e8d8df9ed5a197a4f9529e107a170e9de (patch) | |
tree | 8783945cd1a61351beb3a772c2cf51c082eb6b04 /spec/requests/api/issues_spec.rb | |
parent | c5e11d0405ce6f1b28af50e918af24cd330cfd65 (diff) | |
parent | 4c735e1bd4bd0d67dc6f5496e13346a8b5926cd0 (diff) | |
download | gitlab-ce-820aeb4e8d8df9ed5a197a4f9529e107a170e9de.tar.gz |
Merge branch 'feature/user-agent-details-api' into 'master'
Allow admins to retrieve user agent details for an issue or snippet
Closes #29508
See merge request !12655
Diffstat (limited to 'spec/requests/api/issues_spec.rb')
-rw-r--r-- | spec/requests/api/issues_spec.rb | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/spec/requests/api/issues_spec.rb b/spec/requests/api/issues_spec.rb index 9b53164b4a2..9837fedb522 100644 --- a/spec/requests/api/issues_spec.rb +++ b/spec/requests/api/issues_spec.rb @@ -1462,6 +1462,25 @@ describe API::Issues do end end + describe "GET /projects/:id/issues/:issue_iid/user_agent_detail" do + let!(:user_agent_detail) { create(:user_agent_detail, subject: issue) } + + it 'exposes known attributes' do + get api("/projects/#{project.id}/issues/#{issue.iid}/user_agent_detail", admin) + + expect(response).to have_http_status(200) + expect(json_response['user_agent']).to eq(user_agent_detail.user_agent) + expect(json_response['ip_address']).to eq(user_agent_detail.ip_address) + expect(json_response['akismet_submitted']).to eq(user_agent_detail.submitted) + end + + it "returns unautorized for non-admin users" do + get api("/projects/#{project.id}/issues/#{issue.iid}/user_agent_detail", user) + + expect(response).to have_http_status(403) + end + end + def expect_paginated_array_response(size: nil) expect(response).to have_http_status(200) expect(response).to include_pagination_headers |