# frozen_string_literal: true require 'spec_helper' RSpec.describe 'CycleAnalytics#staging' do extend CycleAnalyticsHelpers::TestGeneration let_it_be(:project) { create(:project, :repository) } let_it_be(:from_date) { 10.days.ago } let_it_be(:user) { project.owner } let_it_be(:project_level) { CycleAnalytics::ProjectLevel.new(project, options: { from: from_date, current_user: user }) } subject { project_level } generate_cycle_analytics_spec( phase: :staging, data_fn: lambda do |context| issue = context.create(:issue, project: context.project) { issue: issue, merge_request: context.create_merge_request_closing_issue(context.user, context.project, issue) } end, start_time_conditions: [["merge request that closes issue is merged", -> (context, data) do context.merge_merge_requests_closing_issue(context.user, context.project, data[:issue]) end]], end_time_conditions: [["merge request that closes issue is deployed to production", -> (context, data) do context.deploy_master(context.user, context.project) end], ["production deploy happens after merge request is merged (along with other changes)", lambda do |context, data| # Make other changes on master context.project.repository.commit("this_sha_apparently_does_not_matter") context.deploy_master(context.user, context.project) end]]) context "when a regular merge request (that doesn't close the issue) is merged and deployed" do it "returns nil" do merge_request = create(:merge_request) MergeRequests::MergeService.new(project, user).execute(merge_request) deploy_master(user, project) expect(subject[:staging].project_median).to be_nil end end context "when the deployment happens to a non-production environment" do it "returns nil" do issue = create(:issue, project: project) merge_request = create_merge_request_closing_issue(user, project, issue) MergeRequests::MergeService.new(project, user).execute(merge_request) deploy_master(user, project, environment: 'staging') expect(subject[:staging].project_median).to be_nil end end end