debian-mirror-gitlab/spec/lib/gitlab/ci/charts_spec.rb

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

171 lines
4.9 KiB
Ruby
Raw Permalink Normal View History

2019-10-12 21:52:04 +05:30
# frozen_string_literal: true
2015-09-25 12:07:36 +05:30
require 'spec_helper'
2020-07-28 23:09:34 +05:30
RSpec.describe Gitlab::Ci::Charts do
2021-01-29 00:20:46 +05:30
context 'yearchart' do
2018-03-27 19:54:05 +05:30
let(:project) { create(:project) }
let(:chart) { Gitlab::Ci::Charts::YearChart.new(project) }
subject { chart.to }
2021-03-11 19:13:27 +05:30
before do
create(:ci_empty_pipeline, project: project, duration: 120)
end
2018-03-27 19:54:05 +05:30
it 'goes until the end of the current month (including the whole last day of the month)' do
is_expected.to eq(Date.today.end_of_month.end_of_day)
end
it 'starts at the beginning of the current year' do
expect(chart.from).to eq(chart.to.years_ago(1).beginning_of_month.beginning_of_day)
end
2021-01-29 00:20:46 +05:30
it 'uses %B %Y as labels format' do
expect(chart.labels).to include(chart.from.strftime('%B %Y'))
end
2021-03-11 19:13:27 +05:30
it 'returns count of pipelines run each day in the current year' do
expect(chart.total.sum).to eq(1)
end
2018-03-27 19:54:05 +05:30
end
2021-01-29 00:20:46 +05:30
context 'monthchart' do
2018-03-27 19:54:05 +05:30
let(:project) { create(:project) }
let(:chart) { Gitlab::Ci::Charts::MonthChart.new(project) }
subject { chart.to }
2021-03-11 19:13:27 +05:30
before do
create(:ci_empty_pipeline, project: project, duration: 120)
end
2018-03-27 19:54:05 +05:30
it 'includes the whole current day' do
is_expected.to eq(Date.today.end_of_day)
end
it 'starts one month ago' do
expect(chart.from).to eq(1.month.ago.beginning_of_day)
end
2021-01-29 00:20:46 +05:30
it 'uses %d %B as labels format' do
expect(chart.labels).to include(chart.from.strftime('%d %B'))
end
2021-03-11 19:13:27 +05:30
it 'returns count of pipelines run each day in the current month' do
expect(chart.total.sum).to eq(1)
end
2018-03-27 19:54:05 +05:30
end
2021-01-29 00:20:46 +05:30
context 'weekchart' do
2018-03-27 19:54:05 +05:30
let(:project) { create(:project) }
let(:chart) { Gitlab::Ci::Charts::WeekChart.new(project) }
subject { chart.to }
2021-03-11 19:13:27 +05:30
before do
create(:ci_empty_pipeline, project: project, duration: 120)
end
2018-03-27 19:54:05 +05:30
it 'includes the whole current day' do
is_expected.to eq(Date.today.end_of_day)
end
it 'starts one week ago' do
expect(chart.from).to eq(1.week.ago.beginning_of_day)
end
2021-01-29 00:20:46 +05:30
it 'uses %d %B as labels format' do
expect(chart.labels).to include(chart.from.strftime('%d %B'))
end
2021-03-11 19:13:27 +05:30
it 'returns count of pipelines run each day in the current week' do
expect(chart.total.sum).to eq(1)
end
end
context 'weekchart_utc' do
today = Date.today
end_of_today = Time.use_zone(Time.find_zone('UTC')) { today.end_of_day }
let(:project) { create(:project) }
let(:chart) do
allow(Date).to receive(:today).and_return(today)
allow(today).to receive(:end_of_day).and_return(end_of_today)
Gitlab::Ci::Charts::WeekChart.new(project)
end
subject { chart.total }
before do
2021-04-17 20:07:23 +05:30
# The created_at time used by the following execution
# can end up being after the creation of the 'today' time
# objects created above, and cause the queried counts to
# go to zero when the test executes close to midnight on the
# CI system, so we explicitly set it to a day earlier
create(:ci_empty_pipeline, project: project, duration: 120, created_at: today - 1.day)
2021-03-11 19:13:27 +05:30
end
it 'uses a utc time zone for range times' do
expect(chart.to.zone).to eq(end_of_today.zone)
expect(chart.from.zone).to eq(end_of_today.zone)
end
it 'returns count of pipelines run each day in the current week' do
expect(chart.total.sum).to eq(1)
end
end
context 'weekchart_non_utc' do
today = Date.today
end_of_today = Time.use_zone(Time.find_zone('Asia/Dubai')) { today.end_of_day }
let(:project) { create(:project) }
let(:chart) do
allow(Date).to receive(:today).and_return(today)
allow(today).to receive(:end_of_day).and_return(end_of_today)
Gitlab::Ci::Charts::WeekChart.new(project)
end
subject { chart.total }
before do
# The DB uses UTC always, so our use of a Time Zone in the application
# can cause the creation date of the pipeline to go unmatched depending
# on the offset. We can work around this by requesting the pipeline be
# created a with the `created_at` field set to a day ago in the same week.
create(:ci_empty_pipeline, project: project, duration: 120, created_at: today - 1.day)
end
it 'uses a non-utc time zone for range times' do
expect(chart.to.zone).to eq(end_of_today.zone)
expect(chart.from.zone).to eq(end_of_today.zone)
end
it 'returns count of pipelines run each day in the current week' do
expect(chart.total.sum).to eq(1)
end
2018-03-27 19:54:05 +05:30
end
2021-01-29 00:20:46 +05:30
context 'pipeline_times' do
2017-09-10 17:25:29 +05:30
let(:project) { create(:project) }
2018-03-17 18:26:18 +05:30
let(:chart) { Gitlab::Ci::Charts::PipelineTime.new(project) }
2016-09-13 17:45:13 +05:30
2017-09-10 17:25:29 +05:30
subject { chart.pipeline_times }
2016-09-13 17:45:13 +05:30
2015-09-25 12:07:36 +05:30
before do
2016-09-13 17:45:13 +05:30
create(:ci_empty_pipeline, project: project, duration: 120)
2015-09-25 12:07:36 +05:30
end
2017-09-10 17:25:29 +05:30
it 'returns pipeline times in minutes' do
2016-09-13 17:45:13 +05:30
is_expected.to contain_exactly(2)
2015-09-25 12:07:36 +05:30
end
2016-06-02 11:05:42 +05:30
2017-09-10 17:25:29 +05:30
it 'handles nil pipeline times' do
2016-09-13 17:45:13 +05:30
create(:ci_empty_pipeline, project: project, duration: nil)
2016-06-02 11:05:42 +05:30
2016-09-13 17:45:13 +05:30
is_expected.to contain_exactly(2, 0)
2016-06-02 11:05:42 +05:30
end
2015-09-25 12:07:36 +05:30
end
end