debian-mirror-gitlab/spec/models/label_spec.rb

159 lines
4.7 KiB
Ruby
Raw Normal View History

2014-09-02 18:07:02 +05:30
require 'spec_helper'
2017-09-10 17:25:29 +05:30
describe Label do
2016-11-03 12:29:30 +05:30
describe 'modules' do
it { is_expected.to include_module(Referable) }
it { is_expected.to include_module(Subscribable) }
end
2014-09-02 18:07:02 +05:30
2015-09-11 14:41:01 +05:30
describe 'associations' do
it { is_expected.to have_many(:issues).through(:label_links).source(:target) }
2016-11-03 12:29:30 +05:30
it { is_expected.to have_many(:label_links).dependent(:destroy) }
2016-09-13 17:45:13 +05:30
it { is_expected.to have_many(:lists).dependent(:destroy) }
2016-11-03 12:29:30 +05:30
it { is_expected.to have_many(:priorities).class_name('LabelPriority') }
2015-09-11 14:41:01 +05:30
end
describe 'validation' do
2016-11-03 12:29:30 +05:30
it { is_expected.to validate_uniqueness_of(:title).scoped_to([:group_id, :project_id]) }
2014-09-02 18:07:02 +05:30
2016-09-13 17:45:13 +05:30
it 'validates color code' do
2016-11-03 12:29:30 +05:30
is_expected.not_to allow_value('G-ITLAB').for(:color)
is_expected.not_to allow_value('AABBCC').for(:color)
is_expected.not_to allow_value('#AABBCCEE').for(:color)
is_expected.not_to allow_value('GGHHII').for(:color)
is_expected.not_to allow_value('#').for(:color)
is_expected.not_to allow_value('').for(:color)
is_expected.to allow_value('#AABBCC').for(:color)
is_expected.to allow_value('#abcdef').for(:color)
2014-09-02 18:07:02 +05:30
end
2016-09-13 17:45:13 +05:30
it 'validates title' do
2016-11-03 12:29:30 +05:30
is_expected.not_to allow_value('G,ITLAB').for(:title)
is_expected.not_to allow_value('').for(:title)
2017-08-17 22:00:37 +05:30
is_expected.not_to allow_value('s' * 256).for(:title)
2016-11-03 12:29:30 +05:30
is_expected.to allow_value('GITLAB').for(:title)
is_expected.to allow_value('gitlab').for(:title)
is_expected.to allow_value('G?ITLAB').for(:title)
is_expected.to allow_value('G&ITLAB').for(:title)
is_expected.to allow_value("customer's request").for(:title)
2017-08-17 22:00:37 +05:30
is_expected.to allow_value('s' * 255).for(:title)
end
end
describe '#color' do
it 'strips color' do
label = described_class.new(color: ' #abcdef ')
label.valid?
expect(label.color).to eq('#abcdef')
end
it 'uses default color if color is missing' do
label = described_class.new(color: nil)
expect(label.color).to be(Label::DEFAULT_COLOR)
end
end
describe '#text_color' do
it 'uses default color if color is missing' do
2017-09-10 17:25:29 +05:30
expect(LabelsHelper).to receive(:text_color_for_bg).with(Label::DEFAULT_COLOR)
.and_return(spy)
2017-08-17 22:00:37 +05:30
label = described_class.new(color: nil)
label.text_color
2015-09-11 14:41:01 +05:30
end
end
2016-08-24 12:49:21 +05:30
describe '#title' do
it 'sanitizes title' do
label = described_class.new(title: '<b>foo & bar?</b>')
expect(label.title).to eq('foo & bar?')
2016-06-02 11:05:42 +05:30
end
2017-08-17 22:00:37 +05:30
it 'strips title' do
label = described_class.new(title: ' label ')
label.valid?
expect(label.title).to eq('label')
end
2016-06-02 11:05:42 +05:30
end
2016-11-03 12:29:30 +05:30
describe 'priorization' do
subject(:label) { create(:label) }
2015-09-11 14:41:01 +05:30
2016-11-03 12:29:30 +05:30
let(:project) { label.project }
describe '#prioritize!' do
context 'when label is not prioritized' do
it 'creates a label priority' do
expect { label.prioritize!(project, 1) }.to change(label.priorities, :count).by(1)
end
it 'sets label priority' do
label.prioritize!(project, 1)
expect(label.priorities.first.priority).to eq 1
end
2015-09-11 14:41:01 +05:30
end
2014-09-02 18:07:02 +05:30
2016-11-03 12:29:30 +05:30
context 'when label is prioritized' do
let!(:priority) { create(:label_priority, project: project, label: label, priority: 0) }
it 'does not create a label priority' do
expect { label.prioritize!(project, 1) }.not_to change(label.priorities, :count)
end
it 'updates label priority' do
label.prioritize!(project, 1)
expect(priority.reload.priority).to eq 1
end
2016-06-02 11:05:42 +05:30
end
end
2016-11-03 12:29:30 +05:30
describe '#unprioritize!' do
it 'removes label priority' do
create(:label_priority, project: project, label: label, priority: 0)
expect { label.unprioritize!(project) }.to change(label.priorities, :count).by(-1)
2016-06-02 11:05:42 +05:30
end
end
2016-11-03 12:29:30 +05:30
describe '#priority' do
context 'when label is not prioritized' do
it 'returns nil' do
expect(label.priority(project)).to be_nil
2016-06-02 11:05:42 +05:30
end
end
2016-11-03 12:29:30 +05:30
context 'when label is prioritized' do
it 'returns label priority' do
create(:label_priority, project: project, label: label, priority: 1)
expect(label.priority(project)).to eq 1
2016-06-02 11:05:42 +05:30
end
2015-09-11 14:41:01 +05:30
end
2014-09-02 18:07:02 +05:30
end
end
2018-11-18 11:00:15 +05:30
describe '.search' do
let(:label) { create(:label, title: 'bug', description: 'incorrect behavior') }
it 'returns labels with a partially matching title' do
expect(described_class.search(label.title[0..2])).to eq([label])
end
it 'returns labels with a partially matching description' do
expect(described_class.search(label.description[0..5])).to eq([label])
end
it 'returns nothing' do
expect(described_class.search('feature')).to be_empty
end
end
2014-09-02 18:07:02 +05:30
end