diff options
author | Grzegorz Bizon <grzesiek.bizon@gmail.com> | 2016-06-21 11:43:32 +0200 |
---|---|---|
committer | Grzegorz Bizon <grzesiek.bizon@gmail.com> | 2016-06-21 11:43:32 +0200 |
commit | c91298d554a2535e0a579e6255fd5640d171e6cf (patch) | |
tree | c12b6df25d6b6640ce7d3fa727d67691cf841c78 /lib/gitlab/ci | |
parent | 9510d31b4dd5955af2941a20a09d2dff6a55249a (diff) | |
download | gitlab-ce-c91298d554a2535e0a579e6255fd5640d171e6cf.tar.gz |
Use generic type validator in new ci configuration
Diffstat (limited to 'lib/gitlab/ci')
-rw-r--r-- | lib/gitlab/ci/config/node/configurable.rb | 2 | ||||
-rw-r--r-- | lib/gitlab/ci/config/node/validators.rb | 9 |
2 files changed, 7 insertions, 4 deletions
diff --git a/lib/gitlab/ci/config/node/configurable.rb b/lib/gitlab/ci/config/node/configurable.rb index 374ff71d0f5..e691ab0c5cf 100644 --- a/lib/gitlab/ci/config/node/configurable.rb +++ b/lib/gitlab/ci/config/node/configurable.rb @@ -19,7 +19,7 @@ module Gitlab included do validations do - validates :config, hash: true + validates :config, type: Hash end end diff --git a/lib/gitlab/ci/config/node/validators.rb b/lib/gitlab/ci/config/node/validators.rb index dc9cdb9a220..a76f041c953 100644 --- a/lib/gitlab/ci/config/node/validators.rb +++ b/lib/gitlab/ci/config/node/validators.rb @@ -13,10 +13,13 @@ module Gitlab end end - class HashValidator < ActiveModel::EachValidator + class TypeValidator < ActiveModel::EachValidator def validate_each(record, attribute, value) - unless value.is_a?(Hash) - record.errors.add(attribute, 'should be a configuration entry hash') + type = options[:with] + raise unless type.is_a?(Class) + + unless value.is_a?(type) + record.errors.add(attribute, "should be a #{type.name}") end end end |