summaryrefslogtreecommitdiff
path: root/spec/features/projects/labels/update_prioritization_spec.rb
blob: 8550d279d09728e94f4c45ed9b5d129b6c396dc0 (plain)
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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
require 'spec_helper'

feature 'Prioritize labels', feature: true do
  include WaitForAjax

  context 'when project belongs to user' do
    let(:user)    { create(:user) }
    let(:project) { create(:project, name: 'test', namespace: user.namespace) }

    scenario 'user can prioritize a label', js: true do
      bug     = create(:label, title: 'bug')
      wontfix = create(:label, title: 'wontfix')

      project.labels << bug
      project.labels << wontfix

      login_as user
      visit namespace_project_labels_path(project.namespace, project)

      expect(page).to have_content('No prioritized labels yet')

      page.within('.other-labels') do
        first('.js-toggle-priority').click
        wait_for_ajax
        expect(page).not_to have_content('bug')
      end

      page.within('.prioritized-labels') do
        expect(page).not_to have_content('No prioritized labels yet')
        expect(page).to have_content('bug')
      end
    end

    scenario 'user can unprioritize a label', js: true do
      bug     = create(:label, title: 'bug', priority: 1)
      wontfix = create(:label, title: 'wontfix')

      project.labels << bug
      project.labels << wontfix

      login_as user
      visit namespace_project_labels_path(project.namespace, project)

      expect(page).to have_content('bug')

      page.within('.prioritized-labels') do
        first('.js-toggle-priority').click
        wait_for_ajax
        expect(page).not_to have_content('bug')
      end

      page.within('.other-labels') do
        expect(page).to have_content('bug')
        expect(page).to have_content('wontfix')
      end
    end

    scenario 'user can sort prioritized labels and persist across reloads', js: true do
      bug     = create(:label, title: 'bug', priority: 1)
      wontfix = create(:label, title: 'wontfix', priority: 2)

      project.labels << bug
      project.labels << wontfix

      login_as user
      visit namespace_project_labels_path(project.namespace, project)

      expect(page).to have_content 'bug'
      expect(page).to have_content 'wontfix'

      # Sort labels
      find("#label_#{bug.id}").drag_to find("#label_#{wontfix.id}")

      page.within('.prioritized-labels') do
        expect(first('li')).to have_content('wontfix')
        expect(page.all('li').last).to have_content('bug')
      end

      visit current_url

      page.within('.prioritized-labels') do
        expect(first('li')).to have_content('wontfix')
        expect(page.all('li').last).to have_content('bug')
      end
    end
  end

  context 'as a guest' do
    it 'can not prioritize labels' do
      user = create(:user)
      guest = create(:user)
      project = create(:project, name: 'test', namespace: user.namespace)

      create(:label, title: 'bug')

      login_as guest
      visit namespace_project_labels_path(project.namespace, project)

      expect(page).not_to have_css('.prioritized-labels')
    end
  end

  context 'as a non signed in user' do
    it 'can not prioritize labels' do
      user = create(:user)
      project = create(:project, name: 'test', namespace: user.namespace)

      create(:label, title: 'bug')

      visit namespace_project_labels_path(project.namespace, project)

      expect(page).not_to have_css('.prioritized-labels')
    end
  end
end