Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'spec/services/ml/create_model_version_service_spec.rb')
-rw-r--r--spec/services/ml/create_model_version_service_spec.rb55
1 files changed, 55 insertions, 0 deletions
diff --git a/spec/services/ml/create_model_version_service_spec.rb b/spec/services/ml/create_model_version_service_spec.rb
index b3aead4a92c..be2bfc86b54 100644
--- a/spec/services/ml/create_model_version_service_spec.rb
+++ b/spec/services/ml/create_model_version_service_spec.rb
@@ -75,5 +75,60 @@ RSpec.describe ::Ml::CreateModelVersionService, feature_category: :mlops do
expect(model.reload.latest_version.package.name).to eq(model.name)
expect(model.latest_version.package.version).to eq(model.latest_version.version)
end
+
+ context 'when metadata are supplied, add them as metadata' do
+ let(:metadata) { [{ key: 'key1', value: 'value1' }, { key: 'key2', value: 'value2' }] }
+ let(:params) { { metadata: metadata } }
+
+ it 'creates metadata records', :aggregate_failures do
+ expect { service }.to change { Ml::ModelVersion.count }.by(1)
+
+ expect(service.metadata.count).to be 2
+ end
+ end
+
+ # TODO: Ensure consisted error responses https://gitlab.com/gitlab-org/gitlab/-/issues/429731
+ context 'for metadata with duplicate keys, it does not create duplicate records' do
+ let(:metadata) { [{ key: 'key1', value: 'value1' }, { key: 'key1', value: 'value2' }] }
+ let(:params) { { metadata: metadata } }
+
+ it 'raises an error', :aggregate_failures do
+ expect { service }.to raise_error(ActiveRecord::RecordInvalid)
+ end
+ end
+
+ # # TODO: Ensure consisted error responses https://gitlab.com/gitlab-org/gitlab/-/issues/429731
+ context 'for metadata with invalid keys, it does not create invalid records' do
+ let(:metadata) { [{ key: 'key1', value: 'value1' }, { key: '', value: 'value2' }] }
+ let(:params) { { metadata: metadata } }
+
+ it 'raises an error', :aggregate_failures do
+ expect { service }.to raise_error(ActiveRecord::RecordInvalid)
+ end
+ end
+ end
+
+ context 'when a version string is supplied during creation' do
+ let(:params) { { version: '1.2.3' } }
+
+ it 'creates a package' do
+ expect { service }.to change { Ml::ModelVersion.count }.by(1).and change {
+ Packages::MlModel::Package.count
+ }.by(1)
+ expect(model.reload.latest_version.version).to eq('1.2.3')
+ expect(model.latest_version.package.version).to eq('1.2.3')
+ end
+ end
+
+ context 'when a nil version string is supplied during creation' do
+ let(:params) { { version: nil } }
+
+ it 'creates a package' do
+ expect { service }.to change { Ml::ModelVersion.count }.by(1).and change {
+ Packages::MlModel::Package.count
+ }.by(1)
+ expect(model.reload.latest_version.version).to eq('1.0.0')
+ expect(model.latest_version.package.version).to eq('1.0.0')
+ end
end
end