141 lines
3.6 KiB
Ruby
141 lines
3.6 KiB
Ruby
|
require 'spec_helper'
|
||
|
|
||
|
describe Gitlab::CycleAnalytics::UsageData do
|
||
|
describe '#to_json' do
|
||
|
before do
|
||
|
Timecop.freeze do
|
||
|
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)
|
||
|
|
||
|
allow_any_instance_of(Gitlab::ReferenceExtractor).to receive(:issues).and_return([issue])
|
||
|
|
||
|
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
|
||
|
|
||
|
shared_examples 'a valid usage data result' do
|
||
|
it 'returns the aggregated usage data of every selected project' do
|
||
|
result = subject.to_json
|
||
|
|
||
|
expect(result).to have_key(:avg_cycle_analytics)
|
||
|
|
||
|
CycleAnalytics::STAGES.each do |stage|
|
||
|
expect(result[:avg_cycle_analytics]).to have_key(stage)
|
||
|
|
||
|
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)
|
||
|
|
||
|
if op == :missing
|
||
|
expect(stage_values[op]).to eq(value)
|
||
|
else
|
||
|
# delta is used because of git timings that Timecop does not stub
|
||
|
expect(stage_values[op].to_i).to be_within(5).of(value.to_i)
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context 'when using postgresql', :postgresql do
|
||
|
let(:expect_values_per_stage) do
|
||
|
{
|
||
|
issue: {
|
||
|
average: 5400,
|
||
|
sd: 2545,
|
||
|
missing: 0
|
||
|
},
|
||
|
plan: {
|
||
|
average: 2,
|
||
|
sd: 2,
|
||
|
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
|
||
|
|
||
|
it_behaves_like 'a valid usage data result'
|
||
|
end
|
||
|
|
||
|
context 'when using mysql', :mysql do
|
||
|
let(:expect_values_per_stage) do
|
||
|
{
|
||
|
issue: {
|
||
|
average: nil,
|
||
|
sd: 0,
|
||
|
missing: 2
|
||
|
},
|
||
|
plan: {
|
||
|
average: nil,
|
||
|
sd: 0,
|
||
|
missing: 2
|
||
|
},
|
||
|
code: {
|
||
|
average: nil,
|
||
|
sd: 0,
|
||
|
missing: 2
|
||
|
},
|
||
|
test: {
|
||
|
average: nil,
|
||
|
sd: 0,
|
||
|
missing: 2
|
||
|
},
|
||
|
review: {
|
||
|
average: nil,
|
||
|
sd: 0,
|
||
|
missing: 2
|
||
|
},
|
||
|
staging: {
|
||
|
average: nil,
|
||
|
sd: 0,
|
||
|
missing: 2
|
||
|
},
|
||
|
production: {
|
||
|
average: nil,
|
||
|
sd: 0,
|
||
|
missing: 2
|
||
|
}
|
||
|
}
|
||
|
end
|
||
|
|
||
|
it_behaves_like 'a valid usage data result'
|
||
|
end
|
||
|
end
|
||
|
end
|