Commit 6fbc7c11 authored by Markus Koller's avatar Markus Koller

Clean up uniqueness validations for service type

- Remove `on: :create` for project services, this can now always be
  validated after we've removed all duplicates.

- Unify the validation syntax for all service types.
parent 10b9090f
...@@ -54,11 +54,11 @@ class Service < ApplicationRecord ...@@ -54,11 +54,11 @@ class Service < ApplicationRecord
validates :project_id, presence: true, unless: -> { template? || instance? || group_id } validates :project_id, presence: true, unless: -> { template? || instance? || group_id }
validates :group_id, presence: true, unless: -> { template? || instance? || project_id } validates :group_id, presence: true, unless: -> { template? || instance? || project_id }
validates :project_id, :group_id, absence: true, if: -> { template? || instance? } validates :project_id, :group_id, absence: true, if: -> { template? || instance? }
validates :type, uniqueness: { scope: :project_id }, unless: -> { template? || instance? || group_id }, on: :create
validates :type, uniqueness: { scope: :group_id }, unless: -> { template? || instance? || project_id }
validates :type, presence: true validates :type, presence: true
validates :template, uniqueness: { scope: :type }, if: -> { template? } validates :type, uniqueness: { scope: :template }, if: :template?
validates :instance, uniqueness: { scope: :type }, if: -> { instance? } validates :type, uniqueness: { scope: :instance }, if: :instance?
validates :type, uniqueness: { scope: :project_id }, if: :project_id?
validates :type, uniqueness: { scope: :group_id }, if: :group_id?
validate :validate_is_instance_or_template validate :validate_is_instance_or_template
validate :validate_belongs_to_project_or_group validate :validate_belongs_to_project_or_group
......
---
title: Clean up uniqueness validations for service type
merge_request: 52565
author:
type: changed
...@@ -39,35 +39,29 @@ RSpec.describe Service do ...@@ -39,35 +39,29 @@ RSpec.describe Service do
end end
end end
context 'with an existing service template' do context 'with existing services' do
before do before_all do
create(:service, :template) create(:service, :template)
create(:service, :instance)
create(:service, project: project)
create(:service, group: group, project: nil)
end end
it 'validates only one service template per type' do it 'allows only one service template per type' do
expect(build(:service, :template)).to be_invalid expect(build(:service, :template)).to be_invalid
end end
end
context 'with an existing instance service' do it 'allows only one instance service per type' do
before do
create(:service, :instance)
end
it 'validates only one service instance per type' do
expect(build(:service, :instance)).to be_invalid expect(build(:service, :instance)).to be_invalid
end end
end
it 'validates uniqueness of type and project_id on create' do it 'allows only one project service per type' do
expect(create(:service, project: project, type: 'Service')).to be_valid expect(build(:service, project: project)).to be_invalid
expect(build(:service, project: project, type: 'Service').valid?(:create)).to eq(false)
expect(build(:service, project: project, type: 'Service').valid?(:update)).to eq(true)
end end
it 'validates uniqueness of type and group_id' do it 'allows only one group service per type' do
expect(create(:service, group_id: group.id, project_id: nil, type: 'Service')).to be_valid expect(build(:service, group: group, project: nil)).to be_invalid
expect(build(:service, group_id: group.id, project_id: nil, type: 'Service')).to be_invalid end
end end
end end
......
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