Skip to content

Commit

Permalink
Merge pull request #15513 from djberg96/validate_blacklist
Browse files Browse the repository at this point in the history
Add validate_blacklist method for VM pre-provisioning
  • Loading branch information
gmcculloug authored Jul 10, 2017
2 parents 35e4d83 + b9c9a7b commit 34cab60
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 0 deletions.
8 changes: 8 additions & 0 deletions app/models/miq_request_workflow/dialog_field_validation.rb
Original file line number Diff line number Diff line change
Expand Up @@ -37,4 +37,12 @@ def validate_regex(_field, _values, dlg, fld, value)
error
end
end

def validate_blacklist(_field, _values, dlg, fld, value)
blacklist = fld[:blacklist]
return _("%{name} is required") % {:name => required_description(dlg, fld)} if value.blank?
if blacklist && blacklist.include?(value)
_("%{name} may not contain blacklisted value") % {:name => required_description(dlg, fld)}
end
end
end
16 changes: 16 additions & 0 deletions spec/models/miq_request_workflow_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -358,6 +358,22 @@
end
end

context "#validate_blacklist" do
let(:blacklist) { {:blacklist => ['foo', 'bar']} }

it "returns nil if the value is not blacklisted" do
expect(workflow.validate_blacklist(nil, {}, {}, blacklist, 'test')).to be_nil
end

it "returns a formatted message when the value is blacklisted" do
expect(workflow.validate_blacklist(nil, {}, {}, blacklist, 'foo')).to eq("'/' may not contain blacklisted value")
end

it "returns an error when no value exists" do
expect(workflow.validate_blacklist(nil, {}, {}, blacklist, '')).to eq "'/' is required"
end
end

context "#validate regex" do
let(:regex) { {:required_regex => "^[email protected]$"} }
let(:regex_two) { {:required_regex => "^n$"} }
Expand Down

0 comments on commit 34cab60

Please sign in to comment.