summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTim Smith <tsmith84@gmail.com>2020-04-22 16:09:51 -0700
committerTim Smith <tsmith84@gmail.com>2020-04-22 21:55:48 -0700
commit6ed90220893285f80513c6155620ebd0d2fbda1e (patch)
treebc80135e28c495d8353820ef7ea7a372c77c1bf5
parent27b54f893cb1c48250dcc4e008bc602e8f819dd5 (diff)
downloadchef-6ed90220893285f80513c6155620ebd0d2fbda1e.tar.gz
Make sure all the non-multipackage packge resources can't take arrayspackage
Right now these resources inherit package_name, versions, and options from the package resource which allows arrays. The problem is the actual providers for these package resources don't know what to do with arrays and they explode. They explode in ways that are really unfriendly to users. With this change they'll get a nice input validation error and they'll have a lot more of an idea of how to go about resolving the problem. This also means that our automatically generated documentation for the package resources will be correct since right now it documents everything as accepting an array. Signed-off-by: Tim Smith <tsmith@chef.io>
-rw-r--r--lib/chef/resource/bff_package.rb7
-rw-r--r--lib/chef/resource/cab_package.rb7
-rw-r--r--lib/chef/resource/chef_gem.rb7
-rw-r--r--lib/chef/resource/gem_package.rb7
-rw-r--r--lib/chef/resource/ips_package.rb7
-rw-r--r--lib/chef/resource/macports_package.rb9
-rw-r--r--lib/chef/resource/msu_package.rb7
-rw-r--r--lib/chef/resource/openbsd_package.rb7
-rw-r--r--lib/chef/resource/paludis_package.rb7
-rw-r--r--lib/chef/resource/portage_package.rb7
-rw-r--r--lib/chef/resource/rpm_package.rb6
-rw-r--r--lib/chef/resource/smartos_package.rb7
-rw-r--r--lib/chef/resource/solaris_package.rb7
-rw-r--r--lib/chef/resource/windows_package.rb7
14 files changed, 98 insertions, 1 deletions
diff --git a/lib/chef/resource/bff_package.rb b/lib/chef/resource/bff_package.rb
index 297cdb93a4..625d48626e 100644
--- a/lib/chef/resource/bff_package.rb
+++ b/lib/chef/resource/bff_package.rb
@@ -27,6 +27,13 @@ class Chef
description "Use the bff_package resource to manage packages for the AIX platform using the installp utility. When a package is installed from a local file, it must be added to the node using the remote_file or cookbook_file resources."
introduced "12.0"
+
+ property :package_name, String,
+ description: "An optional property to set the package name if it differs from the resource block's name.",
+ identity: true
+
+ property :version, String,
+ description: "The version of a package to be installed or upgraded."
end
end
end
diff --git a/lib/chef/resource/cab_package.rb b/lib/chef/resource/cab_package.rb
index 37a8e32548..f0a6063477 100644
--- a/lib/chef/resource/cab_package.rb
+++ b/lib/chef/resource/cab_package.rb
@@ -32,6 +32,13 @@ class Chef
allowed_actions :install, :remove
+ property :package_name, String,
+ description: "An optional property to set the package name if it differs from the resource block's name.",
+ identity: true
+
+ property :version, String,
+ description: "The version of a package to be installed or upgraded."
+
property :source, String,
description: "The local file path or URL for the CAB package.",
coerce: (proc do |s|
diff --git a/lib/chef/resource/chef_gem.rb b/lib/chef/resource/chef_gem.rb
index 2d6613b771..bee7c265b0 100644
--- a/lib/chef/resource/chef_gem.rb
+++ b/lib/chef/resource/chef_gem.rb
@@ -38,6 +38,13 @@ class Chef
unified_mode true
provides :chef_gem
+ property :package_name, String,
+ description: "An optional property to set the package name if it differs from the resource block's name.",
+ identity: true
+
+ property :version, String,
+ description: "The version of a package to be installed or upgraded."
+
property :gem_binary, default: "#{RbConfig::CONFIG["bindir"]}/gem", default_description: "Chef's built-in gem binary.",
description: "The path of a gem binary to use for the installation. By default, the same version of Ruby that is used by the #{Chef::Dist::CLIENT} will be installed.",
callbacks: {
diff --git a/lib/chef/resource/gem_package.rb b/lib/chef/resource/gem_package.rb
index 18ba96624d..eda415526e 100644
--- a/lib/chef/resource/gem_package.rb
+++ b/lib/chef/resource/gem_package.rb
@@ -27,6 +27,13 @@ class Chef
description "Use the gem_package resource to manage gem packages that are only included in recipes. When a package is installed from a local file, it must be added to the node using the remote_file or cookbook_file resources."
+ property :package_name, String,
+ description: "An optional property to set the package name if it differs from the resource block's name.",
+ identity: true
+
+ property :version, String,
+ description: "The version of a package to be installed or upgraded."
+
# the source can either be a path to a package source like:
# source /var/tmp/mygem-1.2.3.4.gem
# or it can be a url rubygems source like:
diff --git a/lib/chef/resource/ips_package.rb b/lib/chef/resource/ips_package.rb
index fd8e1617b5..4a6c745b8c 100644
--- a/lib/chef/resource/ips_package.rb
+++ b/lib/chef/resource/ips_package.rb
@@ -31,6 +31,13 @@ class Chef
allowed_actions :install, :remove, :upgrade
+ property :package_name, String,
+ description: "An optional property to set the package name if it differs from the resource block's name.",
+ identity: true
+
+ property :version, String,
+ description: "The version of a package to be installed or upgraded."
+
property :accept_license, [TrueClass, FalseClass],
default: false, desired_state: false,
description: "Accept an end-user license agreement, automatically."
diff --git a/lib/chef/resource/macports_package.rb b/lib/chef/resource/macports_package.rb
index 96d9dceabf..acc10900f4 100644
--- a/lib/chef/resource/macports_package.rb
+++ b/lib/chef/resource/macports_package.rb
@@ -24,7 +24,14 @@ class Chef
unified_mode true
provides :macports_package
- description "Use the macports_package resource to manage packages for the macOS platform."
+ description "Use the macports_package resource to manage packages for the macOS platform using the MacPorts package management system."
+
+ property :package_name, String,
+ description: "An optional property to set the package name if it differs from the resource block's name.",
+ identity: true
+
+ property :version, String,
+ description: "The version of a package to be installed or upgraded."
end
end
end
diff --git a/lib/chef/resource/msu_package.rb b/lib/chef/resource/msu_package.rb
index d07d7893a3..29a9538995 100644
--- a/lib/chef/resource/msu_package.rb
+++ b/lib/chef/resource/msu_package.rb
@@ -33,6 +33,13 @@ class Chef
allowed_actions :install, :remove
default_action :install
+ property :package_name, String,
+ description: "An optional property to set the package name if it differs from the resource block's name.",
+ identity: true
+
+ property :version, String,
+ description: "The version of a package to be installed or upgraded."
+
property :source, String,
description: "The local file path or URL for the MSU package.",
coerce: (proc do |s|
diff --git a/lib/chef/resource/openbsd_package.rb b/lib/chef/resource/openbsd_package.rb
index ce4b1fc0ce..645aea12c8 100644
--- a/lib/chef/resource/openbsd_package.rb
+++ b/lib/chef/resource/openbsd_package.rb
@@ -31,6 +31,13 @@ class Chef
description "Use the openbsd_package resource to manage packages for the OpenBSD platform."
introduced "12.1"
+
+ property :package_name, String,
+ description: "An optional property to set the package name if it differs from the resource block's name.",
+ identity: true
+
+ property :version, String,
+ description: "The version of a package to be installed or upgraded."
end
end
end
diff --git a/lib/chef/resource/paludis_package.rb b/lib/chef/resource/paludis_package.rb
index 49ad2cc96c..1d3fb0f44c 100644
--- a/lib/chef/resource/paludis_package.rb
+++ b/lib/chef/resource/paludis_package.rb
@@ -31,6 +31,13 @@ class Chef
allowed_actions :install, :remove, :upgrade
+ property :package_name, String,
+ description: "An optional property to set the package name if it differs from the resource block's name.",
+ identity: true
+
+ property :version, String,
+ description: "The version of a package to be installed or upgraded."
+
property :timeout, [String, Integer],
description: "The amount of time (in seconds) to wait before timing out.",
default: 3600,
diff --git a/lib/chef/resource/portage_package.rb b/lib/chef/resource/portage_package.rb
index 9da03b4221..28fa1d6217 100644
--- a/lib/chef/resource/portage_package.rb
+++ b/lib/chef/resource/portage_package.rb
@@ -27,6 +27,13 @@ class Chef
description "Use the portage_package resource to manage packages for the Gentoo platform."
+ property :package_name, String,
+ description: "An optional property to set the package name if it differs from the resource block's name.",
+ identity: true
+
+ property :version, String,
+ description: "The version of a package to be installed or upgraded."
+
property :timeout, [String, Integer],
default: 3600,
description: "The amount of time (in seconds) to wait before timing out.",
diff --git a/lib/chef/resource/rpm_package.rb b/lib/chef/resource/rpm_package.rb
index 3661ca1daa..76887a079e 100644
--- a/lib/chef/resource/rpm_package.rb
+++ b/lib/chef/resource/rpm_package.rb
@@ -29,6 +29,12 @@ class Chef
property :allow_downgrade, [ true, false ], default: true, desired_state: false
+ property :package_name, String,
+ description: "An optional property to set the package name if it differs from the resource block's name.",
+ identity: true
+
+ property :version, String,
+ description: "The version of a package to be installed or upgraded."
end
end
end
diff --git a/lib/chef/resource/smartos_package.rb b/lib/chef/resource/smartos_package.rb
index a11b642d56..eb37b804d5 100644
--- a/lib/chef/resource/smartos_package.rb
+++ b/lib/chef/resource/smartos_package.rb
@@ -27,6 +27,13 @@ class Chef
provides :package, platform_family: "smartos"
description "Use the smartos_package resource to manage packages for the SmartOS platform."
+
+ property :package_name, String,
+ description: "An optional property to set the package name if it differs from the resource block's name.",
+ identity: true
+
+ property :version, String,
+ description: "The version of a package to be installed or upgraded."
end
end
end
diff --git a/lib/chef/resource/solaris_package.rb b/lib/chef/resource/solaris_package.rb
index 46550386c7..6a07cede40 100644
--- a/lib/chef/resource/solaris_package.rb
+++ b/lib/chef/resource/solaris_package.rb
@@ -29,6 +29,13 @@ class Chef
provides :package, os: "solaris2", platform_family: "solaris2", platform_version: "<= 5.10"
description "The solaris_package resource is used to manage packages for the Solaris platform."
+
+ property :package_name, String,
+ description: "An optional property to set the package name if it differs from the resource block's name.",
+ identity: true
+
+ property :version, String,
+ description: "The version of a package to be installed or upgraded."
end
end
end
diff --git a/lib/chef/resource/windows_package.rb b/lib/chef/resource/windows_package.rb
index 0d9a5f39fa..ccedd654bd 100644
--- a/lib/chef/resource/windows_package.rb
+++ b/lib/chef/resource/windows_package.rb
@@ -40,6 +40,13 @@ class Chef
@source ||= source(@package_name) if @package_name.downcase.end_with?(".msi")
end
+ property :package_name, String,
+ description: "An optional property to set the package name if it differs from the resource block's name.",
+ identity: true
+
+ property :version, String,
+ description: "The version of a package to be installed or upgraded."
+
# windows can't take array options yet
property :options, String,
description: "One (or more) additional options that are passed to the command."