6d37fe952b
Fix missing access checks on issue lookup using IssuableFinder Split from !2024 to partially solve https://gitlab.com/gitlab-org/gitlab-ce/issues/23867 ⚠️ - Potentially untested 💣 - No test coverage 🚥 - Test coverage of some sort exists (a test failed when error raised) 🚦 - Test coverage of return value (a test failed when nil used) ✅ - Permissions check tested - [x] ✅ app/controllers/projects/branches_controller.rb:39 - `before_action :authorize_push_code!` helpes limit/prevent exploitation. Always checks for reporter access so fine with confidential issues, issues only visible to team, etc. - [x] 🚥 app/models/cycle_analytics/summary.rb:9 [`.count`] - [x] ✅ app/controllers/projects/todos_controller.rb:19 - [x] Potential double render in app/controllers/projects/todos_controller.rb - https://dev.gitlab.org/gitlab/gitlabhq/merge_requests/2024/diffs#cedccb227af9bfdf88802767cb58d43c2b977439_24_24 See merge request !2030
54 lines
2 KiB
Ruby
54 lines
2 KiB
Ruby
require 'spec_helper'
|
|
|
|
describe 'CycleAnalytics#production', feature: true do
|
|
extend CycleAnalyticsHelpers::TestGeneration
|
|
|
|
let(:project) { create(:project) }
|
|
let(:from_date) { 10.days.ago }
|
|
let(:user) { create(:user, :admin) }
|
|
subject { CycleAnalytics.new(project, user, from: from_date) }
|
|
|
|
generate_cycle_analytics_spec(
|
|
phase: :production,
|
|
data_fn: -> (context) { { issue: context.build(:issue, project: context.project) } },
|
|
start_time_conditions: [["issue is created", -> (context, data) { data[:issue].save }]],
|
|
before_end_fn: lambda do |context, data|
|
|
context.create_merge_request_closing_issue(data[:issue])
|
|
context.merge_merge_requests_closing_issue(data[:issue])
|
|
end,
|
|
end_time_conditions:
|
|
[["merge request that closes issue is deployed to production", -> (context, data) { context.deploy_master }],
|
|
["production deploy happens after merge request is merged (along with other changes)",
|
|
lambda do |context, data|
|
|
# Make other changes on master
|
|
sha = context.project.repository.commit_file(context.user, context.random_git_name, "content", "commit message", 'master', false)
|
|
context.project.repository.commit(sha)
|
|
|
|
context.deploy_master
|
|
end]])
|
|
|
|
context "when a regular merge request (that doesn't close the issue) is merged and deployed" do
|
|
it "returns nil" do
|
|
5.times do
|
|
merge_request = create(:merge_request)
|
|
MergeRequests::MergeService.new(project, user).execute(merge_request)
|
|
deploy_master
|
|
end
|
|
|
|
expect(subject.production).to be_nil
|
|
end
|
|
end
|
|
|
|
context "when the deployment happens to a non-production environment" do
|
|
it "returns nil" do
|
|
5.times do
|
|
issue = create(:issue, project: project)
|
|
merge_request = create_merge_request_closing_issue(issue)
|
|
MergeRequests::MergeService.new(project, user).execute(merge_request)
|
|
deploy_master(environment: 'staging')
|
|
end
|
|
|
|
expect(subject.production).to be_nil
|
|
end
|
|
end
|
|
end
|