114 lines
3.9 KiB
Ruby
114 lines
3.9 KiB
Ruby
# frozen_string_literal: true
|
|
require 'spec_helper'
|
|
|
|
describe Gitlab::CycleAnalytics::GroupStageSummary do
|
|
let(:group) { create(:group) }
|
|
let(:project) { create(:project, :repository, namespace: group) }
|
|
let(:project_2) { create(:project, :repository, namespace: group) }
|
|
let(:from) { 1.day.ago }
|
|
let(:user) { create(:user, :admin) }
|
|
|
|
subject { described_class.new(group, options: { from: Time.now, current_user: user }).data }
|
|
|
|
describe "#new_issues" do
|
|
context 'with from date' do
|
|
before do
|
|
Timecop.freeze(5.days.ago) { create(:issue, project: project) }
|
|
Timecop.freeze(5.days.ago) { create(:issue, project: project_2) }
|
|
Timecop.freeze(5.days.from_now) { create(:issue, project: project) }
|
|
Timecop.freeze(5.days.from_now) { create(:issue, project: project_2) }
|
|
end
|
|
|
|
it "finds the number of issues created after it" do
|
|
expect(subject.first[:value]).to eq(2)
|
|
end
|
|
|
|
context 'with subgroups' do
|
|
before do
|
|
Timecop.freeze(5.days.from_now) { create(:issue, project: create(:project, namespace: create(:group, parent: group))) }
|
|
end
|
|
|
|
it "finds issues from them" do
|
|
expect(subject.first[:value]).to eq(3)
|
|
end
|
|
end
|
|
|
|
context 'with projects specified in options' do
|
|
before do
|
|
Timecop.freeze(5.days.from_now) { create(:issue, project: create(:project, namespace: group)) }
|
|
end
|
|
|
|
subject { described_class.new(group, options: { from: Time.now, current_user: user, projects: [project.id, project_2.id] }).data }
|
|
|
|
it 'finds issues from those projects' do
|
|
expect(subject.first[:value]).to eq(2)
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'with other projects' do
|
|
before do
|
|
Timecop.freeze(5.days.from_now) { create(:issue, project: create(:project, namespace: create(:group))) }
|
|
Timecop.freeze(5.days.from_now) { create(:issue, project: project) }
|
|
Timecop.freeze(5.days.from_now) { create(:issue, project: project_2) }
|
|
end
|
|
|
|
it "doesn't find issues from them" do
|
|
expect(subject.first[:value]).to eq(2)
|
|
end
|
|
end
|
|
end
|
|
|
|
describe "#deploys" do
|
|
context 'with from date' do
|
|
before do
|
|
Timecop.freeze(5.days.ago) { create(:deployment, :success, project: project) }
|
|
Timecop.freeze(5.days.from_now) { create(:deployment, :success, project: project) }
|
|
Timecop.freeze(5.days.ago) { create(:deployment, :success, project: project_2) }
|
|
Timecop.freeze(5.days.from_now) { create(:deployment, :success, project: project_2) }
|
|
end
|
|
|
|
it "finds the number of deploys made created after it" do
|
|
expect(subject.second[:value]).to eq(2)
|
|
end
|
|
|
|
context 'with subgroups' do
|
|
before do
|
|
Timecop.freeze(5.days.from_now) do
|
|
create(:deployment, :success, project: create(:project, :repository, namespace: create(:group, parent: group)))
|
|
end
|
|
end
|
|
|
|
it "finds deploys from them" do
|
|
expect(subject.second[:value]).to eq(3)
|
|
end
|
|
end
|
|
|
|
context 'with projects specified in options' do
|
|
before do
|
|
Timecop.freeze(5.days.from_now) do
|
|
create(:deployment, :success, project: create(:project, :repository, namespace: group, name: 'not_applicable'))
|
|
end
|
|
end
|
|
|
|
subject { described_class.new(group, options: { from: Time.now, current_user: user, projects: [project.id, project_2.id] }).data }
|
|
|
|
it 'shows deploys from those projects' do
|
|
expect(subject.second[:value]).to eq(2)
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'with other projects' do
|
|
before do
|
|
Timecop.freeze(5.days.from_now) do
|
|
create(:deployment, :success, project: create(:project, :repository, namespace: create(:group)))
|
|
end
|
|
end
|
|
|
|
it "doesn't find deploys from them" do
|
|
expect(subject.second[:value]).to eq(0)
|
|
end
|
|
end
|
|
end
|
|
end
|