Commit fa1f20fe authored by mo khan's avatar mo khan Committed by James Lopez

Rename approval_status to classification

* Add a migration to rename the column
* Add a post migration to cleanup the migration
* Rename usages in backend code

https://docs.gitlab.com/ee/development/what_requires_downtime.html#renaming-columns
parent d2f99986
# frozen_string_literal: true
class RenameSoftwareLicensePoliciesApprovalStatusToClassification < ActiveRecord::Migration[5.2]
include Gitlab::Database::MigrationHelpers
DOWNTIME = false
disable_ddl_transaction!
def up
rename_column_concurrently :software_license_policies, :approval_status, :classification
end
def down
undo_rename_column_concurrently :software_license_policies, :approval_status, :classification
end
end
# frozen_string_literal: true
class CleanupSoftwareLicensePoliciesClassificationRename < ActiveRecord::Migration[5.2]
include Gitlab::Database::MigrationHelpers
DOWNTIME = false
disable_ddl_transaction!
def up
cleanup_concurrent_column_rename :software_license_policies, :approval_status, :classification
end
def down
undo_cleanup_concurrent_column_rename :software_license_policies, :approval_status, :classification
end
end
...@@ -3673,7 +3673,7 @@ ActiveRecord::Schema.define(version: 2019_12_02_031812) do ...@@ -3673,7 +3673,7 @@ ActiveRecord::Schema.define(version: 2019_12_02_031812) do
create_table "software_license_policies", id: :serial, force: :cascade do |t| create_table "software_license_policies", id: :serial, force: :cascade do |t|
t.integer "project_id", null: false t.integer "project_id", null: false
t.integer "software_license_id", null: false t.integer "software_license_id", null: false
t.integer "approval_status", default: 0, null: false t.integer "classification", default: 0, null: false
t.index ["project_id", "software_license_id"], name: "index_software_license_policies_unique_per_project", unique: true t.index ["project_id", "software_license_id"], name: "index_software_license_policies_unique_per_project", unique: true
t.index ["software_license_id"], name: "index_software_license_policies_on_software_license_id" t.index ["software_license_id"], name: "index_software_license_policies_on_software_license_id"
end end
......
...@@ -10,7 +10,7 @@ module SCA ...@@ -10,7 +10,7 @@ module SCA
@url = reported_license&.url @url = reported_license&.url
@dependencies = reported_license&.dependencies || [] @dependencies = reported_license&.dependencies || []
@spdx_identifier = software_policy&.spdx_identifier || reported_license&.id @spdx_identifier = software_policy&.spdx_identifier || reported_license&.id
@classification = software_policy&.approval_status || 'unclassified' @classification = software_policy&.classification || 'unclassified'
end end
end end
end end
...@@ -15,9 +15,9 @@ class SoftwareLicense < ApplicationRecord ...@@ -15,9 +15,9 @@ class SoftwareLicense < ApplicationRecord
scope :unknown, -> { where(spdx_identifier: nil) } scope :unknown, -> { where(spdx_identifier: nil) }
scope :grouped_by_name, -> { group(:name) } scope :grouped_by_name, -> { group(:name) }
def self.create_policy_for!(project:, name:, approval_status:) def self.create_policy_for!(project:, name:, classification:)
project.software_license_policies.create!( project.software_license_policies.create!(
approval_status: approval_status, classification: classification,
software_license: safe_find_or_create_by!(name: name) software_license: safe_find_or_create_by!(name: name)
) )
end end
......
...@@ -13,8 +13,7 @@ class SoftwareLicensePolicy < ApplicationRecord ...@@ -13,8 +13,7 @@ class SoftwareLicensePolicy < ApplicationRecord
belongs_to :software_license, -> { readonly } belongs_to :software_license, -> { readonly }
attr_readonly :software_license attr_readonly :software_license
# Licenses must be approved or blacklisted. enum classification: {
enum approval_status: {
blacklisted: 0, blacklisted: 0,
approved: 1 approved: 1
} }
...@@ -24,7 +23,7 @@ class SoftwareLicensePolicy < ApplicationRecord ...@@ -24,7 +23,7 @@ class SoftwareLicensePolicy < ApplicationRecord
validates_presence_of :software_license validates_presence_of :software_license
validates_presence_of :project validates_presence_of :project
validates :approval_status, presence: true validates :classification, presence: true
# A license is unique for its project since it can't be approved and blacklisted. # A license is unique for its project since it can't be approved and blacklisted.
validates :software_license, uniqueness: { scope: :project_id } validates :software_license, uniqueness: { scope: :project_id }
...@@ -46,6 +45,6 @@ class SoftwareLicensePolicy < ApplicationRecord ...@@ -46,6 +45,6 @@ class SoftwareLicensePolicy < ApplicationRecord
delegate :name, :spdx_identifier, to: :software_license delegate :name, :spdx_identifier, to: :software_license
def self.workaround_cache_key def self.workaround_cache_key
pluck(:id, :approval_status).flatten pluck(:id, :classification).flatten
end end
end end
...@@ -10,7 +10,7 @@ class LicenseScanningReportLicenseEntity < Grape::Entity ...@@ -10,7 +10,7 @@ class LicenseScanningReportLicenseEntity < Grape::Entity
expose :url expose :url
def classification def classification
default = { id: nil, name: value_for(:name), approval_status: 'unclassified' } default = { id: nil, name: value_for(:name), classification: 'unclassified' }
found = SoftwareLicensePoliciesFinder.new(request&.current_user, request&.project, name: value_for(:name)).find found = SoftwareLicensePoliciesFinder.new(request&.current_user, request&.project, name: value_for(:name)).find
ManagedLicenseEntity.represent(found || default) ManagedLicenseEntity.represent(found || default)
end end
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
class ManagedLicenseEntity < Grape::Entity class ManagedLicenseEntity < Grape::Entity
expose :id expose :id
expose :approval_status expose :classification, as: :approval_status
expose :software_license, merge: true do expose :software_license, merge: true do
expose :name expose :name
end end
......
...@@ -17,9 +17,9 @@ module Projects ...@@ -17,9 +17,9 @@ module Projects
end end
def create_policy(software_license, classification) def create_policy(software_license, classification)
raise error_for(:approval_status, :invalid) unless known?(classification) raise error_for(:classification, :invalid) unless known?(classification)
policy = project.software_license_policies.create!(software_license: software_license, approval_status: classification) policy = project.software_license_policies.create!(software_license: software_license, classification: classification)
RefreshLicenseComplianceChecksWorker.perform_async(project.id) RefreshLicenseComplianceChecksWorker.perform_async(project.id)
policy policy
end end
...@@ -29,7 +29,7 @@ module Projects ...@@ -29,7 +29,7 @@ module Projects
end end
def known?(classification) def known?(classification)
SoftwareLicensePolicy.approval_statuses.key?(classification) SoftwareLicensePolicy.classifications.key?(classification)
end end
def error_for(attribute, error) def error_for(attribute, error)
......
...@@ -32,12 +32,12 @@ module Projects ...@@ -32,12 +32,12 @@ module Projects
def classification_error def classification_error
errors = ActiveModel::Errors.new(SoftwareLicensePolicy.new) errors = ActiveModel::Errors.new(SoftwareLicensePolicy.new)
errors.add(:approval_status, :invalid) errors.add(:classification, :invalid)
error(errors, :unprocessable_entity) error(errors, :unprocessable_entity)
end end
def valid_classification? def valid_classification?
SoftwareLicensePolicy.approval_statuses.key?(params[:classification]) SoftwareLicensePolicy.classifications.key?(params[:classification])
end end
def blacklisted_classification? def blacklisted_classification?
......
...@@ -24,7 +24,7 @@ module SoftwareLicensePolicies ...@@ -24,7 +24,7 @@ module SoftwareLicensePolicies
policy = SoftwareLicense.create_policy_for!( policy = SoftwareLicense.create_policy_for!(
project: project, project: project,
name: params[:name], name: params[:name],
approval_status: params[:approval_status] classification: params[:approval_status]
) )
RefreshLicenseComplianceChecksWorker.perform_async(project.id) RefreshLicenseComplianceChecksWorker.perform_async(project.id)
policy policy
......
...@@ -7,14 +7,12 @@ module SoftwareLicensePolicies ...@@ -7,14 +7,12 @@ module SoftwareLicensePolicies
super(project, user, params.with_indifferent_access) super(project, user, params.with_indifferent_access)
end end
# returns the updated managed license
def execute(software_license_policy) def execute(software_license_policy)
return error("", 403) unless can?(@current_user, :admin_software_license_policy, @project) return error("", 403) unless can?(@current_user, :admin_software_license_policy, @project)
return success(software_license_policy: software_license_policy) unless params[:approval_status].present?
@params = @params.slice(*SoftwareLicensePolicy::FORM_EDITABLE)
begin begin
software_license_policy.update(params) software_license_policy.update(classification: params[:approval_status])
RefreshLicenseComplianceChecksWorker.perform_async(project.id) RefreshLicenseComplianceChecksWorker.perform_async(project.id)
rescue ArgumentError => ex rescue ArgumentError => ex
return error(ex.message, 400) return error(ex.message, 400)
......
---
title: Rename software_license_policies.approval_status to software_license_policies.classification
merge_request: 20414
author:
type: changed
...@@ -865,7 +865,8 @@ module EE ...@@ -865,7 +865,8 @@ module EE
end end
class ManagedLicense < Grape::Entity class ManagedLicense < Grape::Entity
expose :id, :name, :approval_status expose :id, :name
expose :classification, as: :approval_status
end end
class ProjectAlias < Grape::Entity class ProjectAlias < Grape::Entity
......
...@@ -345,7 +345,7 @@ describe Projects::Security::LicensesController do ...@@ -345,7 +345,7 @@ describe Projects::Security::LicensesController do
end end
it { expect(response).to have_http_status(:unprocessable_entity) } it { expect(response).to have_http_status(:unprocessable_entity) }
it { expect(json).to eq({ "errors" => { "approval_status" => ["is invalid"] } }) } it { expect(json).to eq({ "errors" => { "classification" => ["is invalid"] } }) }
end end
end end
end end
......
...@@ -31,7 +31,7 @@ module EE ...@@ -31,7 +31,7 @@ module EE
}.with_indifferent_access.freeze }.with_indifferent_access.freeze
IGNORED_LIMIT_ENUMS = { IGNORED_LIMIT_ENUMS = {
'SoftwareLicensePolicy' => %w[approval_status], 'SoftwareLicensePolicy' => %w[classification],
'User' => %w[group_view] 'User' => %w[group_view]
}.freeze }.freeze
end end
......
...@@ -2,20 +2,20 @@ ...@@ -2,20 +2,20 @@
FactoryBot.define do FactoryBot.define do
factory :software_license_policy, class: SoftwareLicensePolicy do factory :software_license_policy, class: SoftwareLicensePolicy do
approval_status { 1 } classification { :approved }
project project
software_license software_license
trait :blacklist do trait :blacklist do
approval_status { :blacklisted } classification { :blacklisted }
end end
trait :allowed do trait :allowed do
approval_status { :approved } classification { :approved }
end end
trait :denied do trait :denied do
approval_status { :blacklisted } classification { :blacklisted }
end end
end end
end end
...@@ -336,7 +336,7 @@ describe ApprovalMergeRequestRule do ...@@ -336,7 +336,7 @@ describe ApprovalMergeRequestRule do
let!(:project_approval_rule) { create(:approval_project_rule, :requires_approval, :license_management, project: project) } let!(:project_approval_rule) { create(:approval_project_rule, :requires_approval, :license_management, project: project) }
let(:project) { create(:project) } let(:project) { create(:project) }
let!(:open_pipeline) { create(:ee_ci_pipeline, :success, :with_license_management_report, project: project, merge_requests_as_head_pipeline: [open_merge_request]) } let!(:open_pipeline) { create(:ee_ci_pipeline, :success, :with_license_management_report, project: project, merge_requests_as_head_pipeline: [open_merge_request]) }
let!(:blacklist_policy) { create(:software_license_policy, project: project, software_license: license, approval_status: :blacklisted) } let!(:blacklist_policy) { create(:software_license_policy, project: project, software_license: license, classification: :blacklisted) }
before do before do
subject.refresh_required_approvals!(project_approval_rule) subject.refresh_required_approvals!(project_approval_rule)
......
...@@ -490,7 +490,7 @@ describe MergeRequest do ...@@ -490,7 +490,7 @@ describe MergeRequest do
expect_any_instance_of(Ci::CompareLicenseScanningReportsService) expect_any_instance_of(Ci::CompareLicenseScanningReportsService)
.to receive(:execute).with(base_pipeline, head_pipeline).and_call_original .to receive(:execute).with(base_pipeline, head_pipeline).and_call_original
expect(subject[:key]).to include(*[license_1.id, license_1.approval_status, license_2.id, license_2.approval_status]) expect(subject[:key]).to include(*[license_1.id, license_1.classification, license_2.id, license_2.classification])
end end
end end
......
...@@ -9,7 +9,7 @@ describe SoftwareLicensePolicy do ...@@ -9,7 +9,7 @@ describe SoftwareLicensePolicy do
it { is_expected.to include_module(Presentable) } it { is_expected.to include_module(Presentable) }
it { is_expected.to validate_presence_of(:software_license) } it { is_expected.to validate_presence_of(:software_license) }
it { is_expected.to validate_presence_of(:project) } it { is_expected.to validate_presence_of(:project) }
it { is_expected.to validate_presence_of(:approval_status) } it { is_expected.to validate_presence_of(:classification) }
it { is_expected.to validate_uniqueness_of(:software_license).scoped_to(:project_id).with_message(/has already been taken/) } it { is_expected.to validate_uniqueness_of(:software_license).scoped_to(:project_id).with_message(/has already been taken/) }
end end
......
...@@ -18,7 +18,7 @@ describe SoftwareLicense do ...@@ -18,7 +18,7 @@ describe SoftwareLicense do
context 'when a software license with a given name has already been created' do context 'when a software license with a given name has already been created' do
let(:mit_license) { create(:software_license, :mit) } let(:mit_license) { create(:software_license, :mit) }
let(:result) { subject.create_policy_for!(project: project, name: mit_license.name, approval_status: :approved) } let(:result) { subject.create_policy_for!(project: project, name: mit_license.name, classification: :approved) }
specify { expect(result).to be_persisted } specify { expect(result).to be_persisted }
specify { expect(result).to be_approved } specify { expect(result).to be_approved }
...@@ -27,7 +27,7 @@ describe SoftwareLicense do ...@@ -27,7 +27,7 @@ describe SoftwareLicense do
context 'when a software license with a given name has NOT been created' do context 'when a software license with a given name has NOT been created' do
let(:license_name) { SecureRandom.uuid } let(:license_name) { SecureRandom.uuid }
let(:result) { subject.create_policy_for!(project: project, name: license_name, approval_status: :blacklisted) } let(:result) { subject.create_policy_for!(project: project, name: license_name, classification: :blacklisted) }
specify { expect(result).to be_persisted } specify { expect(result).to be_persisted }
specify { expect(result).to be_blacklisted } specify { expect(result).to be_blacklisted }
......
...@@ -38,7 +38,7 @@ describe API::ManagedLicenses do ...@@ -38,7 +38,7 @@ describe API::ManagedLicenses do
expect(json_response).to be_a(Array) expect(json_response).to be_a(Array)
expect(json_response.first['id']).to eq(software_license_policy.id) expect(json_response.first['id']).to eq(software_license_policy.id)
expect(json_response.first['name']).to eq(software_license_policy.name) expect(json_response.first['name']).to eq(software_license_policy.name)
expect(json_response.first['approval_status']).to eq(software_license_policy.approval_status) expect(json_response.first['approval_status']).to eq(software_license_policy.classification)
end end
end end
...@@ -51,7 +51,7 @@ describe API::ManagedLicenses do ...@@ -51,7 +51,7 @@ describe API::ManagedLicenses do
expect(json_response).to be_a(Array) expect(json_response).to be_a(Array)
expect(json_response.first['id']).to eq(software_license_policy.id) expect(json_response.first['id']).to eq(software_license_policy.id)
expect(json_response.first['name']).to eq(software_license_policy.name) expect(json_response.first['name']).to eq(software_license_policy.name)
expect(json_response.first['approval_status']).to eq(software_license_policy.approval_status) expect(json_response.first['approval_status']).to eq(software_license_policy.classification)
end end
end end
...@@ -92,7 +92,7 @@ describe API::ManagedLicenses do ...@@ -92,7 +92,7 @@ describe API::ManagedLicenses do
expect(response).to match_response_schema('software_license_policy', dir: 'ee') expect(response).to match_response_schema('software_license_policy', dir: 'ee')
expect(json_response['id']).to eq(software_license_policy.id) expect(json_response['id']).to eq(software_license_policy.id)
expect(json_response['name']).to eq(software_license_policy.name) expect(json_response['name']).to eq(software_license_policy.name)
expect(json_response['approval_status']).to eq(software_license_policy.approval_status) expect(json_response['approval_status']).to eq(software_license_policy.classification)
end end
it 'returns project managed license details using the license name as key' do it 'returns project managed license details using the license name as key' do
...@@ -103,7 +103,7 @@ describe API::ManagedLicenses do ...@@ -103,7 +103,7 @@ describe API::ManagedLicenses do
expect(response).to match_response_schema('software_license_policy', dir: 'ee') expect(response).to match_response_schema('software_license_policy', dir: 'ee')
expect(json_response['id']).to eq(software_license_policy.id) expect(json_response['id']).to eq(software_license_policy.id)
expect(json_response['name']).to eq(software_license_policy.name) expect(json_response['name']).to eq(software_license_policy.name)
expect(json_response['approval_status']).to eq(software_license_policy.approval_status) expect(json_response['approval_status']).to eq(software_license_policy.classification)
end end
it 'responds with 404 Not Found if requesting non-existing managed license' do it 'responds with 404 Not Found if requesting non-existing managed license' do
...@@ -121,7 +121,7 @@ describe API::ManagedLicenses do ...@@ -121,7 +121,7 @@ describe API::ManagedLicenses do
expect(response).to match_response_schema('software_license_policy', dir: 'ee') expect(response).to match_response_schema('software_license_policy', dir: 'ee')
expect(json_response['id']).to eq(software_license_policy.id) expect(json_response['id']).to eq(software_license_policy.id)
expect(json_response['name']).to eq(software_license_policy.name) expect(json_response['name']).to eq(software_license_policy.name)
expect(json_response['approval_status']).to eq(software_license_policy.approval_status) expect(json_response['approval_status']).to eq(software_license_policy.classification)
end end
end end
...@@ -208,7 +208,7 @@ describe API::ManagedLicenses do ...@@ -208,7 +208,7 @@ describe API::ManagedLicenses do
initial_license = project.software_license_policies.first initial_license = project.software_license_policies.first
initial_id = initial_license.id initial_id = initial_license.id
initial_name = initial_license.name initial_name = initial_license.name
initial_approval_status = initial_license.approval_status initial_classification = initial_license.classification
patch api("/projects/#{project.id}/managed_licenses/#{software_license_policy.id}", maintainer_user), patch api("/projects/#{project.id}/managed_licenses/#{software_license_policy.id}", maintainer_user),
params: { approval_status: 'blacklisted' } params: { approval_status: 'blacklisted' }
...@@ -220,15 +220,15 @@ describe API::ManagedLicenses do ...@@ -220,15 +220,15 @@ describe API::ManagedLicenses do
# Check that response is equal to the updated object # Check that response is equal to the updated object
expect(json_response['id']).to eq(initial_id) expect(json_response['id']).to eq(initial_id)
expect(json_response['name']).to eq(updated_software_license_policy.name) expect(json_response['name']).to eq(updated_software_license_policy.name)
expect(json_response['approval_status']).to eq(updated_software_license_policy.approval_status) expect(json_response['approval_status']).to eq(updated_software_license_policy.classification)
# Check that the approval status was updated # Check that the approval status was updated
expect(updated_software_license_policy.approval_status).to eq('blacklisted') expect(updated_software_license_policy.classification).to eq('blacklisted')
# Check that response is equal to the old object except for the approval status # Check that response is equal to the old object except for the approval status
expect(initial_id).to eq(updated_software_license_policy.id) expect(initial_id).to eq(updated_software_license_policy.id)
expect(initial_name).to eq(updated_software_license_policy.name) expect(initial_name).to eq(updated_software_license_policy.name)
expect(initial_approval_status).not_to eq(updated_software_license_policy.approval_status) expect(initial_classification).not_to eq(updated_software_license_policy.classification)
end end
it 'responds with 404 Not Found if requesting non-existing managed license' do it 'responds with 404 Not Found if requesting non-existing managed license' do
......
...@@ -36,7 +36,7 @@ describe SoftwareLicensePolicies::CreateService do ...@@ -36,7 +36,7 @@ describe SoftwareLicensePolicies::CreateService do
software_license_policy = project.software_license_policies.last software_license_policy = project.software_license_policies.last
expect(software_license_policy).to be_persisted expect(software_license_policy).to be_persisted
expect(software_license_policy.name).to eq(params[:name]) expect(software_license_policy.name).to eq(params[:name])
expect(software_license_policy.approval_status).to eq('blacklisted') expect(software_license_policy.classification).to eq('blacklisted')
end end
context "when valid parameters are specified" do context "when valid parameters are specified" do
...@@ -51,7 +51,7 @@ describe SoftwareLicensePolicies::CreateService do ...@@ -51,7 +51,7 @@ describe SoftwareLicensePolicies::CreateService do
specify { expect(result[:software_license_policy]).to be_present } specify { expect(result[:software_license_policy]).to be_present }
specify { expect(result[:software_license_policy]).to be_persisted } specify { expect(result[:software_license_policy]).to be_persisted }
specify { expect(result[:software_license_policy].name).to eql(params[:name]) } specify { expect(result[:software_license_policy].name).to eql(params[:name]) }
specify { expect(result[:software_license_policy].approval_status).to eql('blacklisted') } specify { expect(result[:software_license_policy].classification).to eql('blacklisted') }
specify { expect(RefreshLicenseComplianceChecksWorker).to have_received(:perform_async).with(project.id) } specify { expect(RefreshLicenseComplianceChecksWorker).to have_received(:perform_async).with(project.id) }
end end
......
...@@ -15,7 +15,7 @@ describe SoftwareLicensePolicies::UpdateService do ...@@ -15,7 +15,7 @@ describe SoftwareLicensePolicies::UpdateService do
create( create(
:software_license_policy, :software_license_policy,
software_license: create(:software_license, name: 'ExamplePL/2.1'), software_license: create(:software_license, name: 'ExamplePL/2.1'),
approval_status: 'blacklisted' classification: 'blacklisted'
) )
end end
...@@ -42,7 +42,7 @@ describe SoftwareLicensePolicies::UpdateService do ...@@ -42,7 +42,7 @@ describe SoftwareLicensePolicies::UpdateService do
update_software_license_policy(opts) update_software_license_policy(opts)
expect(software_license_policy).to be_valid expect(software_license_policy).to be_valid
expect(software_license_policy.approval_status).not_to eq(opts[:approval_status]) expect(software_license_policy.classification).not_to eq(opts[:approval_status])
end end
end end
...@@ -52,7 +52,7 @@ describe SoftwareLicensePolicies::UpdateService do ...@@ -52,7 +52,7 @@ describe SoftwareLicensePolicies::UpdateService do
update_software_license_policy(opts) update_software_license_policy(opts)
expect(software_license_policy).to be_valid expect(software_license_policy).to be_valid
expect(software_license_policy.approval_status).to eq(opts[:approval_status]) expect(software_license_policy.classification).to eq(opts[:approval_status])
expect(RefreshLicenseComplianceChecksWorker).to have_received(:perform_async).with(project.id) expect(RefreshLicenseComplianceChecksWorker).to have_received(:perform_async).with(project.id)
end end
end end
...@@ -64,7 +64,7 @@ describe SoftwareLicensePolicies::UpdateService do ...@@ -64,7 +64,7 @@ describe SoftwareLicensePolicies::UpdateService do
update_software_license_policy(opts) update_software_license_policy(opts)
expect(software_license_policy).to be_valid expect(software_license_policy).to be_valid
expect(software_license_policy.approval_status).not_to eq(opts[:approval_status]) expect(software_license_policy.classification).not_to eq(opts[:classification])
end end
end end
end end
......
...@@ -24,7 +24,7 @@ describe RefreshLicenseComplianceChecksWorker do ...@@ -24,7 +24,7 @@ describe RefreshLicenseComplianceChecksWorker do
context "when a license is blacklisted, that appears in some of the license management reports" do context "when a license is blacklisted, that appears in some of the license management reports" do
let!(:open_pipeline) { create(:ee_ci_pipeline, :success, :with_license_management_report, project: project, merge_requests_as_head_pipeline: [open_merge_request]) } let!(:open_pipeline) { create(:ee_ci_pipeline, :success, :with_license_management_report, project: project, merge_requests_as_head_pipeline: [open_merge_request]) }
let!(:closed_pipeline) { create(:ee_ci_pipeline, :success, :with_license_management_report, project: project, merge_requests_as_head_pipeline: [closed_merge_request]) } let!(:closed_pipeline) { create(:ee_ci_pipeline, :success, :with_license_management_report, project: project, merge_requests_as_head_pipeline: [closed_merge_request]) }
let!(:blacklist_policy) { create(:software_license_policy, project: project, software_license: license, approval_status: :blacklisted) } let!(:blacklist_policy) { create(:software_license_policy, project: project, software_license: license, classification: :blacklisted) }
let(:license) { create(:software_license, name: license_report.license_names[0]) } let(:license) { create(:software_license, name: license_report.license_names[0]) }
let(:license_report) { open_pipeline.license_scanning_report } let(:license_report) { open_pipeline.license_scanning_report }
...@@ -39,7 +39,7 @@ describe RefreshLicenseComplianceChecksWorker do ...@@ -39,7 +39,7 @@ describe RefreshLicenseComplianceChecksWorker do
context "when none of the blacklisted licenses appear in the most recent license management reports" do context "when none of the blacklisted licenses appear in the most recent license management reports" do
let!(:open_pipeline) { create(:ee_ci_pipeline, :success, :with_license_management_report, project: project, merge_requests_as_head_pipeline: [open_merge_request]) } let!(:open_pipeline) { create(:ee_ci_pipeline, :success, :with_license_management_report, project: project, merge_requests_as_head_pipeline: [open_merge_request]) }
let!(:closed_pipeline) { create(:ee_ci_pipeline, :success, :with_license_management_report, project: project, merge_requests_as_head_pipeline: [closed_merge_request]) } let!(:closed_pipeline) { create(:ee_ci_pipeline, :success, :with_license_management_report, project: project, merge_requests_as_head_pipeline: [closed_merge_request]) }
let!(:blacklist_policy) { create(:software_license_policy, project: project, software_license: license, approval_status: :blacklisted) } let!(:blacklist_policy) { create(:software_license_policy, project: project, software_license: license, classification: :blacklisted) }
let(:license) { create(:software_license, name: SecureRandom.uuid) } let(:license) { create(:software_license, name: SecureRandom.uuid) }
before do before do
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment