diff options
author | Tim Smith <tsmith@chef.io> | 2018-09-07 07:34:45 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-09-07 07:34:45 -0700 |
commit | 7fd86be02c7408fd790f54512f8abeae86ae536f (patch) | |
tree | 2eaed29fcc8fbf93b54d4cdca7773b30a327db13 /lib/chef/resource/yum_package.rb | |
parent | f16adbaa17ea1a6664e3e9514fd9e9e3e4bf4157 (diff) | |
parent | 82af69f30b70aa66bac9b60f066c773a100d8cc3 (diff) | |
download | chef-7fd86be02c7408fd790f54512f8abeae86ae536f.tar.gz |
Merge pull request #7627 from chef/introduced
Add introduced versions for properties and more descriptions
Diffstat (limited to 'lib/chef/resource/yum_package.rb')
-rw-r--r-- | lib/chef/resource/yum_package.rb | 50 |
1 files changed, 30 insertions, 20 deletions
diff --git a/lib/chef/resource/yum_package.rb b/lib/chef/resource/yum_package.rb index 905cacc477..f0ea7dbf50 100644 --- a/lib/chef/resource/yum_package.rb +++ b/lib/chef/resource/yum_package.rb @@ -38,28 +38,38 @@ class Chef # its own arguments as unintended side-effects (and why functional languages that don't allow modifcations # of variables eliminate entire classes of bugs). # </lecture> - property :package_name, [ String, Array ], identity: true, coerce: proc { |x| x.is_a?(Array) ? x.to_a : x } - property :version, [ String, Array ], coerce: proc { |x| x.is_a?(Array) ? x.to_a : x } - property :arch, [ String, Array ], coerce: proc { |x| x.is_a?(Array) ? x.to_a : x } + property :package_name, [ String, Array ], + description: "One of the following: the name of a package, the name of a package and its architecture, the name of a dependency.", + identity: true, coerce: proc { |x| x.is_a?(Array) ? x.to_a : x } - property :flush_cache, - Hash, - default: { before: false, after: false }, - coerce: proc { |v| - if v.is_a?(Hash) - v - elsif v.is_a?(Array) - v.each_with_object({}) { |arg, obj| obj[arg] = true } - elsif v.is_a?(TrueClass) || v.is_a?(FalseClass) - { before: v, after: v } - elsif v == :before - { before: true, after: false } - elsif v == :after - { after: true, before: false } - end - } + property :version, [ String, Array ], + description: "The version of a package to be installed or upgraded. This property is ignored when using the ':upgrade' action.", + coerce: proc { |x| x.is_a?(Array) ? x.to_a : x } - property :allow_downgrade, [ true, false ], default: false + property :arch, [ String, Array ], + description: "The architecture of the package to be installed or upgraded. This value can also be passed as part of the package name.", + coerce: proc { |x| x.is_a?(Array) ? x.to_a : x } + + property :flush_cache, Hash, + description: "Flush the in-memory cache before or after a Yum operation that installs, upgrades, or removes a package. Accepts a Hash in the form: { :before => true/false, :after => true/false } or an Array in the form [ :before, :after ].\nYum automatically synchronizes remote metadata to a local cache. The chef-client creates a copy of the local cache, and then stores it in-memory during the chef-client run. The in-memory cache allows packages to be installed during the chef-client run without the need to continue synchronizing the remote metadata to the local cache while the chef-client run is in-progress.", + default: { before: false, after: false }, + coerce: proc { |v| + if v.is_a?(Hash) + v + elsif v.is_a?(Array) + v.each_with_object({}) { |arg, obj| obj[arg] = true } + elsif v.is_a?(TrueClass) || v.is_a?(FalseClass) + { before: v, after: v } + elsif v == :before + { before: true, after: false } + elsif v == :after + { after: true, before: false } + end + } + + property :allow_downgrade, [ true, false ], + description: "Downgrade a package to satisfy requested version requirements.", + default: false property :yum_binary, String end |