File: issuable_update_shared_examples.rb

package info (click to toggle)
gitlab 17.6.5-19
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 629,368 kB
  • sloc: ruby: 1,915,304; javascript: 557,307; sql: 60,639; xml: 6,509; sh: 4,567; makefile: 1,239; python: 406
file content (47 lines) | stat: -rw-r--r-- 1,636 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
# frozen_string_literal: true

RSpec.shared_examples 'issuable update endpoint' do
  let(:area) { entity.class.name.underscore.pluralize }

  describe 'PUT /projects/:id/issues/:issue_iid' do
    let(:url) { "/projects/#{project.id}/#{area}/#{entity.iid}" }

    it 'clears labels when labels param is nil' do
      put api(url, user), params: { labels: 'label1' }

      expect(response).to have_gitlab_http_status(:ok)
      expect(json_response['labels']).to contain_exactly('label1')

      put api(url, user), params: { labels: nil }

      expect(response).to have_gitlab_http_status(:ok)
      json_response = Gitlab::Json.parse(response.body)
      expect(json_response['labels']).to be_empty
    end

    it 'updates the issuable with labels param as array' do
      allow(Gitlab::QueryLimiting::Transaction).to receive(:threshold).and_return(110)

      params = { labels: ['label1', 'label2', 'foo, bar', '&,?'] }

      put api(url, user), params: params

      expect(response).to have_gitlab_http_status(:ok)
      expect(json_response['labels']).to include 'label1'
      expect(json_response['labels']).to include 'label2'
      expect(json_response['labels']).to include 'foo'
      expect(json_response['labels']).to include 'bar'
      expect(json_response['labels']).to include '&'
      expect(json_response['labels']).to include '?'
    end

    it 'clears milestone when milestone_id=0' do
      entity.update!(milestone: milestone)

      put api(url, user), params: { milestone_id: 0 }

      expect(response).to have_gitlab_http_status(:ok)
      expect(json_response['milestone']).to be_nil
    end
  end
end