Commit 60d15699 authored by Krasimir Angelov's avatar Krasimir Angelov

Use build_stubbed to remove unnecessary DB calls in packages validations

Related to https://gitlab.com/gitlab-org/plan/-/issues/145.
parent e77d0d12
...@@ -84,7 +84,7 @@ RSpec.describe Packages::Package, type: :model do ...@@ -84,7 +84,7 @@ RSpec.describe Packages::Package, type: :model do
end end
describe 'validations' do describe 'validations' do
subject { create(:package) } subject { build(:package) }
it { is_expected.to validate_presence_of(:project) } it { is_expected.to validate_presence_of(:project) }
it { is_expected.to validate_uniqueness_of(:name).scoped_to(:project_id, :version, :package_type) } it { is_expected.to validate_uniqueness_of(:name).scoped_to(:project_id, :version, :package_type) }
...@@ -95,7 +95,7 @@ RSpec.describe Packages::Package, type: :model do ...@@ -95,7 +95,7 @@ RSpec.describe Packages::Package, type: :model do
it { is_expected.not_to allow_value("my(dom$$$ain)com.my-app").for(:name) } it { is_expected.not_to allow_value("my(dom$$$ain)com.my-app").for(:name) }
context 'conan package' do context 'conan package' do
subject { create(:conan_package) } subject { build_stubbed(:conan_package) }
let(:fifty_one_characters) {'f_b' * 17} let(:fifty_one_characters) {'f_b' * 17}
...@@ -112,7 +112,7 @@ RSpec.describe Packages::Package, type: :model do ...@@ -112,7 +112,7 @@ RSpec.describe Packages::Package, type: :model do
describe '#version' do describe '#version' do
RSpec.shared_examples 'validating version to be SemVer compliant for' do |factory_name| RSpec.shared_examples 'validating version to be SemVer compliant for' do |factory_name|
context "for #{factory_name}" do context "for #{factory_name}" do
subject { create(factory_name) } subject { build_stubbed(factory_name) }
it { is_expected.to allow_value('1.2.3').for(:version) } it { is_expected.to allow_value('1.2.3').for(:version) }
it { is_expected.to allow_value('1.2.3-beta').for(:version) } it { is_expected.to allow_value('1.2.3-beta').for(:version) }
...@@ -126,7 +126,7 @@ RSpec.describe Packages::Package, type: :model do ...@@ -126,7 +126,7 @@ RSpec.describe Packages::Package, type: :model do
end end
context 'conan package' do context 'conan package' do
subject { create(:conan_package) } subject { build_stubbed(:conan_package) }
let(:fifty_one_characters) {'1.2' * 17} let(:fifty_one_characters) {'1.2' * 17}
...@@ -142,7 +142,7 @@ RSpec.describe Packages::Package, type: :model do ...@@ -142,7 +142,7 @@ RSpec.describe Packages::Package, type: :model do
end end
context 'maven package' do context 'maven package' do
subject { create(:maven_package) } subject { build_stubbed(:maven_package) }
it { is_expected.to allow_value('0').for(:version) } it { is_expected.to allow_value('0').for(:version) }
it { is_expected.to allow_value('1').for(:version) } it { is_expected.to allow_value('1').for(:version) }
......
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