debian-mirror-gitlab/spec/lib/gitlab/cycle_analytics/usage_data_spec.rb

96 lines
2.7 KiB
Ruby
Raw Normal View History

2019-10-12 21:52:04 +05:30
# frozen_string_literal: true
2018-03-27 19:54:05 +05:30
require 'spec_helper'
describe Gitlab::CycleAnalytics::UsageData do
describe '#to_json' do
before do
2018-11-08 19:23:39 +05:30
# Since git commits only have second precision, round up to the
# nearest second to ensure we have accurate median and standard
# deviation calculations.
current_time = Time.at(Time.now.to_i)
Timecop.freeze(current_time) do
2018-03-27 19:54:05 +05:30
user = create(:user, :admin)
projects = create_list(:project, 2, :repository)
projects.each_with_index do |project, time|
issue = create(:issue, project: project, created_at: (time + 1).hour.ago)
2020-01-01 13:55:28 +05:30
allow_next_instance_of(Gitlab::ReferenceExtractor) do |instance|
allow(instance).to receive(:issues).and_return([issue])
end
2018-03-27 19:54:05 +05:30
milestone = create(:milestone, project: project)
mr = create_merge_request_closing_issue(user, project, issue, commit_message: "References #{issue.to_reference}")
pipeline = create(:ci_empty_pipeline, status: 'created', project: project, ref: mr.source_branch, sha: mr.source_branch_sha, head_pipeline_of: mr)
create_cycle(user, project, issue, mr, milestone, pipeline)
deploy_master(user, project, environment: 'staging')
deploy_master(user, project)
end
end
end
2019-10-12 21:52:04 +05:30
context 'a valid usage data result' do
2018-03-27 19:54:05 +05:30
let(:expect_values_per_stage) do
{
issue: {
average: 5400,
sd: 2545,
missing: 0
},
plan: {
2018-11-08 19:23:39 +05:30
average: 1,
sd: 0,
2018-03-27 19:54:05 +05:30
missing: 0
},
code: {
average: nil,
sd: 0,
missing: 2
},
test: {
average: nil,
sd: 0,
missing: 2
},
review: {
average: 0,
sd: 0,
missing: 0
},
staging: {
average: 0,
sd: 0,
missing: 0
},
production: {
average: 5400,
sd: 2545,
missing: 0
}
}
end
2019-12-26 22:10:19 +05:30
it 'returns the aggregated usage data of every selected project', :sidekiq_might_not_need_inline do
2019-10-12 21:52:04 +05:30
result = subject.to_json
2018-03-27 19:54:05 +05:30
2019-10-12 21:52:04 +05:30
expect(result).to have_key(:avg_cycle_analytics)
CycleAnalytics::LevelBase::STAGES.each do |stage|
expect(result[:avg_cycle_analytics]).to have_key(stage)
2018-03-27 19:54:05 +05:30
2019-10-12 21:52:04 +05:30
stage_values = result[:avg_cycle_analytics][stage]
expected_values = expect_values_per_stage[stage]
expected_values.each_pair do |op, value|
expect(stage_values).to have_key(op)
expect(stage_values[op]).to eq(value)
end
end
end
2018-03-27 19:54:05 +05:30
end
end
end