1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60
|
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe Ml::DestroyModelVersionService, feature_category: :mlops do
let_it_be(:project) { create(:project) }
let_it_be(:model) { create(:ml_models, project: project) }
let(:user) { project.owner }
let(:audit_event) do
{
name: 'ml_model_version_destroyed',
author: user,
scope: project,
message: "MlModelVersion #{model_version.name}/#{model_version.version} destroyed",
target: model_version
}
end
subject(:execute_service) { described_class.new(model_version, user).execute }
before do
allow(Gitlab::Audit::Auditor).to receive(:audit).and_call_original
end
describe '#execute', :aggregate_failures do
context 'when model version exists' do
let(:model_version) { create(:ml_model_versions, :with_package, model: model) }
it 'deletes the model version' do
expect(execute_service).to be_success
expect(execute_service.payload[:model_version]).to eq(model_version)
expect(Ml::ModelVersion.find_by(id: model_version.id)).to be_nil
expect(Gitlab::Audit::Auditor).to have_received(:audit).with(audit_event)
end
end
context 'when model version has no package' do
let(:model_version) { create(:ml_model_versions, model: model) }
it 'does not trigger destroy package service' do
expect(Packages::MarkPackageForDestructionService).not_to receive(:new)
expect(execute_service).to be_success
expect(Gitlab::Audit::Auditor).to have_received(:audit).with(audit_event)
end
end
context 'when package cannot be marked for destruction' do
let(:model_version) { create(:ml_model_versions, :with_package, model: model) }
let(:user) { nil }
it 'does not delete the model version' do
is_expected.to be_error.and have_attributes(message: "You don't have access to this package")
expect(Ml::ModelVersion.find_by(id: model_version.id)).to eq(model_version)
expect(Gitlab::Audit::Auditor).not_to have_received(:audit)
end
end
end
end
|