Codebase list ruby-gitlab / 3625f30 spec / gitlab / client / issues_spec.rb
3625f30

Tree @3625f30 (Download .tar.gz)

issues_spec.rb @3625f30raw · history · blame

# 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