debian-mirror-gitlab/spec/helpers/timeboxes_helper_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

100 lines
3.7 KiB
Ruby
Raw Normal View History

2019-12-21 20:55:43 +05:30
# frozen_string_literal: true
2016-11-03 12:29:30 +05:30
require 'spec_helper'
2023-03-17 16:20:25 +05:30
RSpec.describe TimeboxesHelper, feature_category: :team_planning do
using RSpec::Parameterized::TableSyntax
let_it_be(:milestone_expired) { build(:milestone, due_date: Date.today.prev_month) }
let_it_be(:milestone_closed) { build(:milestone, :closed) }
let_it_be(:milestone_upcoming) { build(:milestone, start_date: Date.today.next_month) }
let_it_be(:milestone_open) { build(:milestone) }
let_it_be(:milestone_closed_and_expired) { build(:milestone, :closed, due_date: Date.today.prev_month) }
describe '#timebox_date_range' do
2017-08-17 22:00:37 +05:30
let(:yesterday) { Date.yesterday }
let(:tomorrow) { yesterday + 2 }
let(:format) { '%b %-d, %Y' }
let(:yesterday_formatted) { yesterday.strftime(format) }
let(:tomorrow_formatted) { tomorrow.strftime(format) }
2020-06-23 00:09:42 +05:30
context 'milestone' do
def result_for(*args)
timebox_date_range(build(:milestone, *args))
end
it { expect(result_for(due_date: nil, start_date: nil)).to be_nil }
it { expect(result_for(due_date: tomorrow)).to eq("expires on #{tomorrow_formatted}") }
it { expect(result_for(due_date: yesterday)).to eq("expired on #{yesterday_formatted}") }
it { expect(result_for(start_date: tomorrow)).to eq("starts on #{tomorrow_formatted}") }
it { expect(result_for(start_date: yesterday)).to eq("started on #{yesterday_formatted}") }
it { expect(result_for(start_date: yesterday, due_date: tomorrow)).to eq("#{yesterday_formatted}#{tomorrow_formatted}") }
end
2017-08-17 22:00:37 +05:30
end
2023-03-17 16:20:25 +05:30
describe '#group_milestone_route' do
2020-05-24 23:13:21 +05:30
let(:group) { build_stubbed(:group) }
2023-03-17 16:20:25 +05:30
let(:subgroup) { build_stubbed(:group, parent: group, name: 'Test Subgrp') }
2020-05-24 23:13:21 +05:30
2023-03-17 16:20:25 +05:30
context 'when in subgroup' do
2020-05-24 23:13:21 +05:30
let(:milestone) { build_stubbed(:group_milestone, group: subgroup) }
it 'generates correct url despite assigned @group' do
assign(:group, group)
milestone_path = "/groups/#{subgroup.full_path}/-/milestones/#{milestone.iid}"
expect(helper.group_milestone_route(milestone)).to eq(milestone_path)
end
end
end
2022-07-01 11:34:44 +05:30
2023-03-17 16:20:25 +05:30
describe '#recent_releases_with_counts' do
let_it_be(:project) { milestone_open.project }
2022-07-01 11:34:44 +05:30
let_it_be(:user) { create(:user) }
2023-03-17 16:20:25 +05:30
subject { helper.recent_releases_with_counts(milestone_open, user) }
2022-07-01 11:34:44 +05:30
before do
project.add_developer(user)
end
2023-03-17 16:20:25 +05:30
it 'returns releases with counts' do
_old_releases = create_list(:release, 2, project: project, milestones: [milestone_open])
recent_public_releases = create_list(:release, 3, project: project, milestones: [milestone_open], released_at: '2022-01-01T18:00:00Z')
2022-07-01 11:34:44 +05:30
is_expected.to match([match_array(recent_public_releases), 5, 2])
end
end
2023-03-17 16:20:25 +05:30
describe '#milestone_status_string' do
where(:milestone, :status) do
lazy { milestone_expired } | 'Expired'
lazy { milestone_closed } | 'Closed'
lazy { milestone_closed_and_expired } | 'Closed'
lazy { milestone_upcoming } | 'Upcoming'
lazy { milestone_open } | 'Open'
end
with_them do
it 'returns status string' do
expect(helper.milestone_status_string(milestone)).to eq(status)
end
end
end
describe '#milestone_badge_variant' do
where(:milestone, :variant) do
lazy { milestone_expired } | :warning
lazy { milestone_closed } | :danger
lazy { milestone_closed_and_expired } | :danger
lazy { milestone_upcoming } | :neutral
lazy { milestone_open } | :success
end
with_them do
it 'returns badge variant' do
expect(helper.milestone_badge_variant(milestone)).to eq(variant)
end
end
end
2016-11-03 12:29:30 +05:30
end