diff options
author | Alexis Reigel <alexis.reigel.ext@siemens.com> | 2018-06-11 15:17:46 +0200 |
---|---|---|
committer | Alexis Reigel <alexis.reigel.ext@siemens.com> | 2018-09-15 21:39:26 +0200 |
commit | 82546888e81488ba7b2a60a970a1cc31febcc1e9 (patch) | |
tree | af69a08e70434642862e57d549c514ff255b65cb /spec | |
parent | 048b4469e8c46327e3e3e9bbdfd7ef9bd27e047f (diff) | |
download | gitlab-ce-82546888e81488ba7b2a60a970a1cc31febcc1e9.tar.gz |
add status param to runners api
Diffstat (limited to 'spec')
-rw-r--r-- | spec/requests/api/runners_spec.rb | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/spec/requests/api/runners_spec.rb b/spec/requests/api/runners_spec.rb index 3a318a0334f..49a79d2ccf9 100644 --- a/spec/requests/api/runners_spec.rb +++ b/spec/requests/api/runners_spec.rb @@ -74,6 +74,22 @@ describe API::Runners do expect(response).to have_gitlab_http_status(400) end + + it 'filters runners by status' do + create(:ci_runner, :project, :inactive, description: 'Inactive project runner', projects: [project]) + + get api('/runners?status=paused', user) + + expect(json_response).to match_array [ + a_hash_including('description' => 'Inactive project runner') + ] + end + + it 'does not filter by invalid status' do + get api('/runners?status=bogus', user) + + expect(response).to have_gitlab_http_status(400) + end end context 'unauthorized user' do @@ -149,6 +165,22 @@ describe API::Runners do expect(response).to have_gitlab_http_status(400) end + + it 'filters runners by status' do + create(:ci_runner, :project, :inactive, description: 'Inactive project runner', projects: [project]) + + get api('/runners/all?status=paused', admin) + + expect(json_response).to match_array [ + a_hash_including('description' => 'Inactive project runner') + ] + end + + it 'does not filter by invalid status' do + get api('/runners/all?status=bogus', admin) + + expect(response).to have_gitlab_http_status(400) + end end context 'without admin privileges' do @@ -668,6 +700,22 @@ describe API::Runners do expect(response).to have_gitlab_http_status(400) end + + it 'filters runners by status' do + create(:ci_runner, :project, :inactive, description: 'Inactive project runner', projects: [project]) + + get api("/projects/#{project.id}/runners?status=paused", user) + + expect(json_response).to match_array [ + a_hash_including('description' => 'Inactive project runner') + ] + end + + it 'does not filter by invalid status' do + get api("/projects/#{project.id}/runners?status=bogus", user) + + expect(response).to have_gitlab_http_status(400) + end end context 'authorized user without maintainer privileges' do |