From ac1a76a72c1dddc52fdb09a1c33610083a19cc6b Mon Sep 17 00:00:00 2001 From: david22swan Date: Wed, 25 Sep 2024 14:13:38 +0100 Subject: [PATCH] (CAT-2061) Fix empty string nullification Reinstating reverted change by Clebam with additional fix suggested by original author. Original Fix: https://github.com/puppetlabs/ruby-pwsh/pull/292 Revert: https://github.com/puppetlabs/ruby-pwsh/pull/342 Reason for revert: https://github.com/puppetlabs/ruby-pwsh/issues/340 --- .../provider/dsc_base_provider/dsc_base_provider.rb | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/lib/puppet/provider/dsc_base_provider/dsc_base_provider.rb b/lib/puppet/provider/dsc_base_provider/dsc_base_provider.rb index 92281f72..f5f5f206 100644 --- a/lib/puppet/provider/dsc_base_provider/dsc_base_provider.rb +++ b/lib/puppet/provider/dsc_base_provider/dsc_base_provider.rb @@ -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' end data end