diff options
Diffstat (limited to 'spec/models/concerns')
-rw-r--r-- | spec/models/concerns/relative_positioning_spec.rb | 132 |
1 files changed, 132 insertions, 0 deletions
diff --git a/spec/models/concerns/relative_positioning_spec.rb b/spec/models/concerns/relative_positioning_spec.rb new file mode 100644 index 00000000000..989f46f1442 --- /dev/null +++ b/spec/models/concerns/relative_positioning_spec.rb @@ -0,0 +1,132 @@ +require 'spec_helper' + +describe Issue, 'RelativePositioning' do + let(:project) { create(:empty_project) } + let(:issue) { create(:issue, project: project) } + let(:issue1) { create(:issue, project: project) } + + before do + [issue, issue1].each do |issue| + issue.move_to_end && issue.save + end + end + + describe '#min_relative_position' do + it 'returns minimum position' do + expect(issue1.min_relative_position).to eq issue.relative_position + end + end + + describe '#man_relative_position' do + it 'returns maximum position' do + expect(issue.max_relative_position).to eq issue1.relative_position + end + end + + describe '#prev_relative_position' do + it 'returns previous position if there is an issue above' do + expect(issue1.prev_relative_position).to eq issue.relative_position + end + + it 'returns minimum position if there is no issue above' do + expect(issue.prev_relative_position).to eq RelativePositioning::MIN_POSITION + end + end + + describe '#next_relative_position' do + it 'returns next position if there is an issue below' do + expect(issue.next_relative_position).to eq issue1.relative_position + end + + it 'returns next position if there is no issue below' do + expect(issue1.next_relative_position).to eq RelativePositioning::MAX_POSITION + end + end + + describe '#move_before' do + it 'moves issue before' do + issue1.move_before(issue) + + expect(issue1.relative_position).to be < issue.relative_position + end + + it 'moves unpositioned issue before' do + issue.update_attribute(:relative_position, nil) + + issue1.move_before(issue) + + expect(issue1.relative_position).to be < issue.relative_position + end + end + + describe '#move_after' do + it 'moves issue after' do + issue.move_before(issue1) + + expect(issue.relative_position).to be < issue1.relative_position + end + + it 'moves unpositioned issue after' do + issue1.update_attribute(:relative_position, nil) + + issue.move_before(issue1) + + expect(issue.relative_position).to be < issue1.relative_position + end + end + + describe '#move_to_end' do + it 'moves issue to the end' do + new_issue = create :issue, project: project + + new_issue.move_to_end + + expect(new_issue.relative_position).to be > issue1.relative_position + end + end + + describe '#move_between' do + it 'positions issue between two other' do + new_issue = create :issue, project: project + + new_issue.move_between(issue, issue1) + + expect(new_issue.relative_position).to be > issue.relative_position + expect(new_issue.relative_position).to be < issue1.relative_position + end + + it 'positions issue between two other if position of last one is nil' do + new_issue = create :issue, project: project + issue1.relative_position = nil + issue1.save + + new_issue.move_between(issue, issue1) + + expect(new_issue.relative_position).to be > issue.relative_position + expect(new_issue.relative_position).to be < issue1.relative_position + end + + it 'positions issue between two other if position of first one is nil' do + new_issue = create :issue, project: project + issue.relative_position = nil + issue.save + + new_issue.move_between(issue, issue1) + + expect(new_issue.relative_position).to be > issue.relative_position + expect(new_issue.relative_position).to be < issue1.relative_position + end + + it 'calls move_after if after is nil' do + expect(issue).to receive(:move_after) + + issue.move_between(issue1, nil) + end + + it 'calls move_before if before is nil' do + expect(issue).to receive(:move_before) + + issue.move_between(nil, issue1) + end + end +end |