summaryrefslogtreecommitdiff
path: root/lib/gitlab/ci
diff options
context:
space:
mode:
authorGrzegorz Bizon <grzesiek.bizon@gmail.com>2016-06-21 11:43:32 +0200
committerGrzegorz Bizon <grzesiek.bizon@gmail.com>2016-06-21 11:43:32 +0200
commitc91298d554a2535e0a579e6255fd5640d171e6cf (patch)
treec12b6df25d6b6640ce7d3fa727d67691cf841c78 /lib/gitlab/ci
parent9510d31b4dd5955af2941a20a09d2dff6a55249a (diff)
downloadgitlab-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.rb2
-rw-r--r--lib/gitlab/ci/config/node/validators.rb9
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