diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2021-07-30 09:10:05 +0000 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2021-07-30 09:10:05 +0000 |
commit | a16109b67fdee47ff1ccf4c0c831a0b47a17ab34 (patch) | |
tree | 9199632ee66c3076dfeea279e42e91b2827b5ece /spec/validators | |
parent | 52c7972910b960f37ae9792cb4d17876244d4bcf (diff) | |
download | gitlab-ce-a16109b67fdee47ff1ccf4c0c831a0b47a17ab34.tar.gz |
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'spec/validators')
-rw-r--r-- | spec/validators/any_field_validator_spec.rb | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/spec/validators/any_field_validator_spec.rb b/spec/validators/any_field_validator_spec.rb new file mode 100644 index 00000000000..bede006abf6 --- /dev/null +++ b/spec/validators/any_field_validator_spec.rb @@ -0,0 +1,44 @@ +# frozen_string_literal: true + +require 'spec_helper' + +RSpec.describe AnyFieldValidator do + context 'when validation is instantiated correctly' do + let(:validated_class) do + Class.new(ApplicationRecord) do + self.table_name = 'vulnerabilities' + + validates_with AnyFieldValidator, fields: %w(title description) + end + end + + it 'raises an error if no fields are defined' do + validated_object = validated_class.new + + expect(validated_object.valid?).to be_falsey + expect(validated_object.errors.messages) + .to eq(base: ["At least one field of %{one_of_required_fields} must be present" % + { one_of_required_fields: %w(title description) }]) + end + + it 'validates if only one field is present' do + validated_object = validated_class.new(title: 'Vulnerability title') + + expect(validated_object.valid?).to be_truthy + end + end + + context 'when validation is missing the fields parameter' do + let(:invalid_class) do + Class.new(ApplicationRecord) do + self.table_name = 'vulnerabilities' + + validates_with AnyFieldValidator + end + end + + it 'raises an error' do + expect { invalid_class.new }.to raise_error(RuntimeError) + end + end +end |