summaryrefslogtreecommitdiff
path: root/spec/controllers/projects
diff options
context:
space:
mode:
authorDouglas Barbosa Alexandre <dbalexandre@gmail.com>2016-09-20 11:03:41 -0300
committerDouglas Barbosa Alexandre <dbalexandre@gmail.com>2016-10-19 14:58:24 -0200
commitbaf47a0bd0e0563cbc99b3ae4b1336b8b3b4380a (patch)
tree267498617c4b8a33d3ae5b7d350f49d73152a061 /spec/controllers/projects
parentcf14482a5aceb62c178c19cc70e9354dc23dd9e1 (diff)
downloadgitlab-ce-baf47a0bd0e0563cbc99b3ae4b1336b8b3b4380a.tar.gz
Remove project_labels from Projects::ApplicationController
Diffstat (limited to 'spec/controllers/projects')
-rw-r--r--spec/controllers/projects/labels_controller_spec.rb80
1 files changed, 60 insertions, 20 deletions
diff --git a/spec/controllers/projects/labels_controller_spec.rb b/spec/controllers/projects/labels_controller_spec.rb
index 3492b6ffbbb..2b39f9cf0d1 100644
--- a/spec/controllers/projects/labels_controller_spec.rb
+++ b/spec/controllers/projects/labels_controller_spec.rb
@@ -1,52 +1,92 @@
require 'spec_helper'
describe Projects::LabelsController do
- let(:project) { create(:project) }
+ let(:group) { create(:group) }
+ let(:project) { create(:project, namespace: group) }
let(:user) { create(:user) }
before do
project.team << [user, :master]
+
sign_in(user)
end
describe 'GET #index' do
- def create_label(attributes)
- create(:label, attributes.merge(project: project))
- end
+ let!(:label_1) { create(:label, project: project, priority: 1, title: 'Label 1') }
+ let!(:label_2) { create(:label, project: project, priority: 3, title: 'Label 2') }
+ let!(:label_3) { create(:label, project: project, priority: 1, title: 'Label 3') }
+ let!(:label_4) { create(:label, project: project, priority: nil, title: 'Label 4') }
+ let!(:label_5) { create(:label, project: project, priority: nil, title: 'Label 5') }
- before do
- 15.times { |i| create_label(priority: (i % 3) + 1, title: "label #{15 - i}") }
- 5.times { |i| create_label(title: "label #{100 - i}") }
-
- get :index, namespace_id: project.namespace.to_param, project_id: project.to_param
- end
+ let!(:group_label_1) { create(:group_label, group: group, priority: 3, title: 'Group Label 1') }
+ let!(:group_label_2) { create(:group_label, group: group, priority: 1, title: 'Group Label 2') }
+ let!(:group_label_3) { create(:group_label, group: group, priority: nil, title: 'Group Label 3') }
+ let!(:group_label_4) { create(:group_label, group: group, priority: nil, title: 'Group Label 4') }
context '@prioritized_labels' do
- let(:prioritized_labels) { assigns(:prioritized_labels) }
+ before do
+ list_labels
+ end
it 'contains only prioritized labels' do
- expect(prioritized_labels).to all(have_attributes(priority: a_value > 0))
+ expect(assigns(:prioritized_labels)).to all(have_attributes(priority: a_value > 0))
end
it 'is sorted by priority, then label title' do
- priorities_and_titles = prioritized_labels.pluck(:priority, :title)
-
- expect(priorities_and_titles.sort).to eq(priorities_and_titles)
+ expect(assigns(:prioritized_labels)).to match_array [group_label_2, label_1, label_3, group_label_1, label_2]
end
end
- context '@labels' do
- let(:labels) { assigns(:labels) }
+ context '@group_labels' do
+ it 'contains only group labels' do
+ list_labels
+
+ expect(assigns(:group_labels)).to all(have_attributes(group_id: a_value > 0))
+ end
it 'contains only unprioritized labels' do
- expect(labels).to all(have_attributes(priority: nil))
+ list_labels
+
+ expect(assigns(:group_labels)).to all(have_attributes(priority: nil))
end
it 'is sorted by label title' do
- titles = labels.pluck(:title)
+ list_labels
- expect(titles.sort).to eq(titles)
+ expect(assigns(:group_labels)).to match_array [group_label_3, group_label_4]
end
+
+ it 'is nil when project does not belong to a group' do
+ project.update(namespace: create(:namespace))
+
+ list_labels
+
+ expect(assigns(:group_labels)).to be_nil
+ end
+ end
+
+ context '@project_labels' do
+ before do
+ list_labels
+ end
+
+ it 'contains only project labels' do
+ list_labels
+
+ expect(assigns(:project_labels)).to all(have_attributes(project_id: a_value > 0))
+ end
+
+ it 'contains only unprioritized labels' do
+ expect(assigns(:project_labels)).to all(have_attributes(priority: nil))
+ end
+
+ it 'is sorted by label title' do
+ expect(assigns(:project_labels)).to match_array [label_4, label_5]
+ end
+ end
+
+ def list_labels
+ get :index, namespace_id: project.namespace.to_param, project_id: project.to_param
end
end
end