Skip to content

Commit

Permalink
(CAT-2061) Fix empty string nullification
Browse files Browse the repository at this point in the history
Reinstating reverted change by Clebam with additional fix suggested by original author.

Original Fix: #292
Revert: #342
Reason for revert: #340
  • Loading branch information
david22swan committed Sep 25, 2024
1 parent 78c3f26 commit ac1a76a
Showing 1 changed file with 6 additions and 6 deletions.
12 changes: 6 additions & 6 deletions lib/puppet/provider/dsc_base_provider/dsc_base_provider.rb
Original file line number Diff line number Diff line change
Expand Up @@ -682,16 +682,16 @@ def mandatory_set_attributes(context)
context.type.attributes.select { |_attribute, properties| properties[:mandatory_for_set] }.keys
end

# Parses the DSC resource type definition to retrieve the names of any attributes which are specifed as required strings
# This is used to ensure that any nil values are converted to empty strings to match puppets expecetd value
# Parses the DSC resource type definition to retrieve the names of any attributes which are specified as required strings
# This is used to ensure that any nil values are converted to empty strings to match puppets expeceted value
# @param context [Object] the Puppet runtime context to operate in and send feedback to
# @param data [Hash] the hash of properties returned from the DSC resource
# @return [Hash] returns a data hash with any nil values converted to empty strings
def stringify_nil_attributes(context, data)
nil_strings = data.select { |_name, value| value.nil? }.keys
string_attrs = context.type.attributes.select { |_name, properties| properties[:type] == 'String' }.keys
string_attrs.each do |attribute|
data[attribute] = '' if nil_strings.include?(attribute)
nil_attributes = data.select { |_name, value| value.nil? }.keys
nil_attributes.each do |nil_attr|
attribute_type = context.type.attributes[nil_attr][:type]
data[nil_attr] = '' if (attribute_type.start_with?('Optional[Enum[', 'Enum[')) && enum_values(context, nil_attr).include?('')) || attribute_type == 'String'

Check failure on line 694 in lib/puppet/provider/dsc_base_provider/dsc_base_provider.rb

View workflow job for this annotation

GitHub Actions / spec (ruby 2.7 | puppet ~> 7.0) / spec

Lint/Syntax: unexpected token tRPAREN (Using Ruby 2.7 parser; configure using `TargetRubyVersion` parameter, under `AllCops`)

Check failure on line 694 in lib/puppet/provider/dsc_base_provider/dsc_base_provider.rb

View workflow job for this annotation

GitHub Actions / spec (ruby 3.2 | puppet ~> 8.0) / spec

Lint/Syntax: unexpected token tRPAREN (Using Ruby 2.7 parser; configure using `TargetRubyVersion` parameter, under `AllCops`)
end
data
end
Expand Down

0 comments on commit ac1a76a

Please sign in to comment.