# frozen_string_literal: true
require 'spec_helper'
describe Gitlab::Client do
describe '.issues' do
context 'with project ID passed' do
before do
stub_get('/projects/3/issues', 'project_issues')
@issues = Gitlab.issues(3)
end
it 'gets the correct resource' do
expect(a_get('/projects/3/issues')).to have_been_made
end
it "returns a paginated response of project's issues" do
expect(@issues).to be_a Gitlab::PaginatedResponse
expect(@issues.first.project_id).to eq(3)
end
end
context 'with literal project ID passed' do
before do
stub_get('/projects/gitlab-org%2Fgitlab-ce/issues', 'project_issues')
@issues = Gitlab.issues('gitlab-org/gitlab-ce')
end
it 'gets the correct resource' do
expect(a_get('/projects/gitlab-org%2Fgitlab-ce/issues')).to have_been_made
end
it "returns a paginated response of project's issues" do
expect(@issues).to be_a Gitlab::PaginatedResponse
expect(@issues.first.project_id).to eq(3)
end
end
context 'without project ID passed' do
before do
stub_get('/issues', 'issues')
@issues = Gitlab.issues
end
it 'gets the correct resource' do
expect(a_get('/issues')).to have_been_made
end
it "returns a paginated response of user's issues" do
expect(@issues).to be_a Gitlab::PaginatedResponse
expect(@issues.first.closed).to be_falsey
expect(@issues.first.author.name).to eq('John Smith')
end
end
end
describe '.issue' do
before do
stub_get('/projects/3/issues/33', 'issue')
@issue = Gitlab.issue(3, 33)
end
it 'gets the correct resource' do
expect(a_get('/projects/3/issues/33')).to have_been_made
end
it 'returns information about an issue' do
expect(@issue.project_id).to eq(3)
expect(@issue.assignee.name).to eq('Jack Smith')
end
end
describe '.create_issue' do
before do
stub_post('/projects/3/issues', 'issue')
@issue = Gitlab.create_issue(3, 'title')
end
it 'gets the correct resource' do
expect(a_post('/projects/3/issues')
.with(body: { title: 'title' })).to have_been_made
end
it 'returns information about a created issue' do
expect(@issue.project_id).to eq(3)
expect(@issue.assignee.name).to eq('Jack Smith')
end
end
describe '.edit_issue' do
before do
stub_put('/projects/3/issues/33', 'issue')
@issue = Gitlab.edit_issue(3, 33, title: 'title')
end
it 'gets the correct resource' do
expect(a_put('/projects/3/issues/33')
.with(body: { title: 'title' })).to have_been_made
end
it 'returns information about an edited issue' do
expect(@issue.project_id).to eq(3)
expect(@issue.assignee.name).to eq('Jack Smith')
end
end
describe '.close_issue' do
before do
stub_put('/projects/3/issues/33', 'issue')
@issue = Gitlab.close_issue(3, 33)
end
it 'gets the correct resource' do
expect(a_put('/projects/3/issues/33')
.with(body: { state_event: 'close' })).to have_been_made
end
it 'returns information about an closed issue' do
expect(@issue.project_id).to eq(3)
expect(@issue.assignee.name).to eq('Jack Smith')
end
end
describe '.reopen_issue' do
before do
stub_put('/projects/3/issues/33', 'issue')
@issue = Gitlab.reopen_issue(3, 33)
end
it 'gets the correct resource' do
expect(a_put('/projects/3/issues/33')
.with(body: { state_event: 'reopen' })).to have_been_made
end
it 'returns information about an reopened issue' do
expect(@issue.project_id).to eq(3)
expect(@issue.assignee.name).to eq('Jack Smith')
end
end
describe '.subscribe_to_issue' do
before do
stub_post('/projects/3/issues/33/subscribe', 'issue')
@issue = Gitlab.subscribe_to_issue(3, 33)
end
it 'gets the correct resource' do
expect(a_post('/projects/3/issues/33/subscribe')).to have_been_made
end
it 'returns information about the subscribed issue' do
expect(@issue.project_id).to eq(3)
expect(@issue.assignee.name).to eq('Jack Smith')
end
end
describe '.unsubscribe_from_issue' do
before do
stub_post('/projects/3/issues/33/unsubscribe', 'issue')
@issue = Gitlab.unsubscribe_from_issue(3, 33)
end
it 'gets the correct resource' do
expect(a_post('/projects/3/issues/33/unsubscribe')).to have_been_made
end
it 'returns information about the unsubscribed issue' do
expect(@issue.project_id).to eq(3)
expect(@issue.assignee.name).to eq('Jack Smith')
end
end
describe '.delete_issue' do
before do
stub_delete('/projects/3/issues/33', 'issue')
@issue = Gitlab.delete_issue(3, 33)
end
it 'gets the correct resource' do
expect(a_delete('/projects/3/issues/33')).to have_been_made
end
it 'returns information about a deleted issue' do
expect(@issue.project_id).to eq(3)
expect(@issue.id).to eq(33)
end
end
describe '.move_issue' do
before do
stub_post('/projects/3/issues/33/move', 'issue')
@issue = Gitlab.move_issue(3, 33, to_project_id: '4')
end
it 'gets the correct resource' do
expect(a_post('/projects/3/issues/33/move')
.with(body: { to_project_id: '4' })).to have_been_made
end
it 'returns information about the moved issue' do
expect(@issue.project_id).to eq(3)
expect(@issue.assignee.name).to eq('Jack Smith')
end
end
describe '.estimate_time_of_issue' do
before do
stub_post('/projects/3/issues/33/time_estimate', 'issue')
@issue = Gitlab.estimate_time_of_issue(3, 33, '3h30m')
end
it 'gets the correct resource' do
expect(a_post('/projects/3/issues/33/time_estimate')
.with(body: { duration: '3h30m' })).to have_been_made
end
it 'returns information about the estimated issue' do
expect(@issue.project_id).to eq(3)
expect(@issue.assignee.name).to eq('Jack Smith')
end
end
describe '.reset_time_estimate_of_issue' do
before do
stub_post('/projects/3/issues/33/reset_time_estimate', 'issue')
@issue = Gitlab.reset_time_estimate_of_issue(3, 33)
end
it 'gets the correct resource' do
expect(a_post('/projects/3/issues/33/reset_time_estimate')).to have_been_made
end
it 'returns information about the estimated issue' do
expect(@issue.project_id).to eq(3)
expect(@issue.assignee.name).to eq('Jack Smith')
end
end
describe '.add_time_spent_on_issue' do
context 'with positive value' do
before do
stub_post('/projects/3/issues/33/add_spent_time', 'issue')
@issue = Gitlab.add_time_spent_on_issue(3, 33, '3h30m')
end
it 'gets the correct resource' do
expect(a_post('/projects/3/issues/33/add_spent_time')
.with(body: { duration: '3h30m' })).to have_been_made
end
it 'returns information about the estimated issue' do
expect(@issue.project_id).to eq(3)
expect(@issue.assignee.name).to eq('Jack Smith')
end
end
context 'with negative value' do
before do
stub_post('/projects/3/issues/33/add_spent_time', 'issue')
@issue = Gitlab.add_time_spent_on_issue(3, 33, '-30m')
end
it 'gets the correct resource' do
expect(a_post('/projects/3/issues/33/add_spent_time')
.with(body: { duration: '-30m' })).to have_been_made
end
it 'returns information about the estimated issue' do
expect(@issue.project_id).to eq(3)
expect(@issue.assignee.name).to eq('Jack Smith')
end
end
end
describe '.reset_time_spent_on_issue' do
before do
stub_post('/projects/3/issues/33/reset_spent_time', 'issue')
@issue = Gitlab.reset_time_spent_on_issue(3, 33)
end
it 'gets the correct resource' do
expect(a_post('/projects/3/issues/33/reset_spent_time')).to have_been_made
end
it 'returns information about the estimated issue' do
expect(@issue.project_id).to eq(3)
expect(@issue.assignee.name).to eq('Jack Smith')
end
end
describe '.time_stats_for_issue' do
before do
stub_get('/projects/3/issues/33/time_stats', 'issue')
@issue = Gitlab.time_stats_for_issue(3, 33)
end
it 'gets the correct resource' do
expect(a_get('/projects/3/issues/33/time_stats')).to have_been_made
end
it 'returns information about the issue' do
expect(@issue.project_id).to eq(3)
expect(@issue.assignee.name).to eq('Jack Smith')
end
end
describe '.participants_on_issue' do
before do
stub_get('/projects/3/issues/33/participants', 'participants_on_issue')
@participants = Gitlab.participants_on_issue(3, 33)
end
it 'gets the correct resource' do
expect(a_get('/projects/3/issues/33/participants')).to have_been_made
end
it 'returns information about the participants on issue' do
expect(@participants.first.name).to eq('John Doe1')
expect(@participants.size).to eq(2)
end
end
describe '.merge_requests_closing_issue_on_merge' do
before do
stub_get('/projects/3/issues/33/closed_by', 'merge_requests_closing_issue_on_merge')
@merge_requests = Gitlab.merge_requests_closing_issue_on_merge(3, 33)
end
it 'gets the correct resource' do
expect(a_get('/projects/3/issues/33/closed_by')).to have_been_made
end
it 'returns list of merge requests closing issue on merge' do
expect(@merge_requests.first.title).to eq('New feature')
expect(@merge_requests.size).to eq(2)
end
end
end