chef 12.16.42-universal-mingw32 → 12.17.44-universal-mingw32

Sign up to get free protection for your applications and to get access to all the features.
Files changed (147) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile +2 -1
  3. data/README.md +20 -5
  4. data/Rakefile +17 -0
  5. data/VERSION +1 -1
  6. data/acceptance/Gemfile.lock +32 -23
  7. data/distro/common/markdown/man1/knife-configure.mkd +3 -2
  8. data/lib-backcompat/chef/chef_fs/file_system/already_exists_error.rb +1 -1
  9. data/lib-backcompat/chef/chef_fs/file_system/cookbook_frozen_error.rb +1 -1
  10. data/lib-backcompat/chef/chef_fs/file_system/default_environment_cannot_be_modified_error.rb +1 -1
  11. data/lib-backcompat/chef/chef_fs/file_system/file_system_error.rb +1 -1
  12. data/lib-backcompat/chef/chef_fs/file_system/must_delete_recursively_error.rb +1 -1
  13. data/lib-backcompat/chef/chef_fs/file_system/not_found_error.rb +1 -1
  14. data/lib-backcompat/chef/chef_fs/file_system/operation_failed_error.rb +1 -1
  15. data/lib-backcompat/chef/chef_fs/file_system/operation_not_allowed_error.rb +1 -1
  16. data/lib-backcompat/chef/chef_fs/file_system/repository/chef_repository_file_system_entry.rb +1 -1
  17. data/lib-backcompat/chef/chef_fs/file_system/repository/file_system_root_dir.rb +1 -1
  18. data/lib/chef/api_client.rb +1 -1
  19. data/lib/chef/application.rb +1 -1
  20. data/lib/chef/application/exit_code.rb +3 -3
  21. data/lib/chef/chef_class.rb +15 -5
  22. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_root_dir.rb +12 -1
  23. data/lib/chef/chef_fs/file_system/repository/nodes_dir.rb +19 -0
  24. data/lib/chef/client.rb +1 -0
  25. data/lib/chef/cookbook/metadata.rb +2 -2
  26. data/lib/chef/cookbook_version.rb +4 -4
  27. data/lib/chef/data_bag.rb +1 -1
  28. data/lib/chef/data_bag_item.rb +1 -1
  29. data/lib/chef/data_collector.rb +20 -13
  30. data/lib/chef/data_collector/messages.rb +0 -1
  31. data/lib/chef/data_collector/messages/helpers.rb +2 -2
  32. data/lib/chef/decorator/unchain.rb +2 -2
  33. data/lib/chef/deprecated.rb +190 -0
  34. data/lib/chef/deprecation/provider/remote_directory.rb +1 -1
  35. data/lib/chef/deprecation/warnings.rb +3 -4
  36. data/lib/chef/dsl/method_missing.rb +2 -2
  37. data/lib/chef/dsl/resources.rb +2 -2
  38. data/lib/chef/environment.rb +1 -1
  39. data/lib/chef/exceptions.rb +1 -1
  40. data/lib/chef/formatters/base.rb +11 -1
  41. data/lib/chef/formatters/doc.rb +13 -4
  42. data/lib/chef/key.rb +1 -1
  43. data/lib/chef/knife/client_delete.rb +12 -9
  44. data/lib/chef/knife/configure.rb +1 -1
  45. data/lib/chef/knife/core/bootstrap_context.rb +25 -1
  46. data/lib/chef/knife/core/subcommand_loader.rb +3 -3
  47. data/lib/chef/knife/core/ui.rb +1 -1
  48. data/lib/chef/knife/node_delete.rb +6 -6
  49. data/lib/chef/log.rb +1 -1
  50. data/lib/chef/mixin/deprecation.rb +4 -10
  51. data/lib/chef/mixin/powershell_type_coercions.rb +19 -19
  52. data/lib/chef/mixin/shell_out.rb +1 -1
  53. data/lib/chef/node.rb +2 -2
  54. data/lib/chef/node/attribute.rb +3 -4
  55. data/lib/chef/node/common_api.rb +1 -1
  56. data/lib/chef/node/mixin/state_tracking.rb +5 -2
  57. data/lib/chef/node_map.rb +2 -2
  58. data/lib/chef/org.rb +1 -1
  59. data/lib/chef/platform/rebooter.rb +3 -1
  60. data/lib/chef/policy_builder/expand_node_object.rb +1 -1
  61. data/lib/chef/property.rb +5 -5
  62. data/lib/chef/provider.rb +4 -4
  63. data/lib/chef/provider/launchd.rb +1 -1
  64. data/lib/chef/provider/link.rb +6 -0
  65. data/lib/chef/provider/mount.rb +2 -0
  66. data/lib/chef/provider/mount/mount.rb +1 -1
  67. data/lib/chef/provider/ohai.rb +5 -3
  68. data/lib/chef/provider/package/cab.rb +1 -1
  69. data/lib/chef/provider/package/chocolatey.rb +2 -2
  70. data/lib/chef/provider/package/easy_install.rb +2 -2
  71. data/lib/chef/provider/package/msu.rb +162 -0
  72. data/lib/chef/provider/package/powershell.rb +114 -0
  73. data/lib/chef/provider/package/yum.rb +1 -1
  74. data/lib/chef/provider/yum_repository.rb +6 -7
  75. data/lib/chef/provider_resolver.rb +2 -2
  76. data/lib/chef/providers.rb +2 -0
  77. data/lib/chef/resource.rb +3 -5
  78. data/lib/chef/resource/apt_update.rb +1 -1
  79. data/lib/chef/resource/chef_gem.rb +2 -3
  80. data/lib/chef/resource/file/verification.rb +1 -1
  81. data/lib/chef/resource/launchd.rb +48 -8
  82. data/lib/chef/resource/mount.rb +1 -1
  83. data/lib/chef/resource/msu_package.rb +47 -0
  84. data/lib/chef/resource/ohai.rb +5 -25
  85. data/lib/chef/resource/powershell_package.rb +41 -0
  86. data/lib/chef/resource/reboot.rb +1 -1
  87. data/lib/chef/resource/user.rb +2 -2
  88. data/lib/chef/resource_builder.rb +4 -4
  89. data/lib/chef/resource_resolver.rb +2 -3
  90. data/lib/chef/resources.rb +2 -0
  91. data/lib/chef/rest.rb +1 -1
  92. data/lib/chef/role.rb +1 -1
  93. data/lib/chef/run_context.rb +3 -3
  94. data/lib/chef/shell/ext.rb +2 -2
  95. data/lib/chef/user.rb +3 -3
  96. data/lib/chef/user_v1.rb +1 -1
  97. data/lib/chef/version.rb +1 -1
  98. data/lib/chef/win32/api/security.rb +12 -12
  99. data/spec/data/sample_msu1.xml +10 -0
  100. data/spec/data/sample_msu2.xml +14 -0
  101. data/spec/data/sample_msu3.xml +16 -0
  102. data/spec/functional/rebooter_spec.rb +3 -3
  103. data/spec/functional/resource/link_spec.rb +62 -1
  104. data/spec/functional/resource/msu_package_spec.rb +84 -0
  105. data/spec/functional/resource/registry_spec.rb +3 -3
  106. data/spec/functional/resource/rpm_spec.rb +7 -10
  107. data/spec/integration/solo/solo_spec.rb +50 -0
  108. data/spec/spec_helper.rb +3 -0
  109. data/spec/support/platform_helpers.rb +16 -8
  110. data/spec/unit/application/exit_code_spec.rb +3 -15
  111. data/spec/unit/data_collector_spec.rb +6 -16
  112. data/spec/unit/deprecated_spec.rb +59 -0
  113. data/spec/unit/deprecation_spec.rb +1 -8
  114. data/spec/unit/handler_spec.rb +2 -2
  115. data/spec/unit/knife/client_delete_spec.rb +16 -0
  116. data/spec/unit/knife/configure_spec.rb +1 -1
  117. data/spec/unit/knife/cookbook_metadata_spec.rb +116 -113
  118. data/spec/unit/knife/core/bootstrap_context_spec.rb +55 -5
  119. data/spec/unit/knife/node_delete_spec.rb +19 -10
  120. data/spec/unit/mixin/shell_out_spec.rb +0 -1
  121. data/spec/unit/node/immutable_collections_spec.rb +5 -0
  122. data/spec/unit/node/vivid_mash_spec.rb +11 -0
  123. data/spec/unit/node_spec.rb +2 -2
  124. data/spec/unit/provider/launchd_spec.rb +81 -3
  125. data/spec/unit/provider/mount/mount_spec.rb +1 -1
  126. data/spec/unit/provider/mount_spec.rb +7 -0
  127. data/spec/unit/provider/package/chocolatey_spec.rb +5 -5
  128. data/spec/unit/provider/package/easy_install_spec.rb +6 -6
  129. data/spec/unit/provider/package/msu_spec.rb +283 -0
  130. data/spec/unit/provider/package/powershell_spec.rb +337 -0
  131. data/spec/unit/provider/service/macosx_spec.rb +1 -1
  132. data/spec/unit/provider/subversion_spec.rb +9 -0
  133. data/spec/unit/provider/user/linux_spec.rb +7 -1
  134. data/spec/unit/recipe_spec.rb +43 -11
  135. data/spec/unit/resource/apt_update_spec.rb +17 -25
  136. data/spec/unit/resource/file/verification_spec.rb +1 -1
  137. data/spec/unit/resource/mount_spec.rb +2 -1
  138. data/spec/unit/resource/msu_package_spec.rb +49 -0
  139. data/spec/unit/resource/ohai_spec.rb +1 -1
  140. data/spec/unit/resource/powershell_package_spec.rb +68 -0
  141. data/spec/unit/resource_reporter_spec.rb +4 -4
  142. data/spec/unit/run_status_spec.rb +1 -1
  143. data/tasks/announce.rb +58 -0
  144. data/tasks/changelog.rb +26 -6
  145. data/tasks/templates/prerelease.md.erb +35 -0
  146. data/tasks/templates/release.md.erb +34 -0
  147. metadata +21 -4
@@ -20,6 +20,7 @@
20
20
  require "chef/chef_fs/file_system/repository/node"
21
21
  require "chef/chef_fs/file_system/repository/directory"
22
22
  require "chef/chef_fs/file_system/exceptions"
23
+ require "chef/win32/security" if Chef::Platform.windows?
23
24
 
24
25
  class Chef
25
26
  module ChefFS
@@ -30,6 +31,24 @@ class Chef
30
31
  def make_child_entry(child_name)
31
32
  Node.new(child_name, self)
32
33
  end
34
+
35
+ def create_child(child_name, file_contents = nil)
36
+ child = super
37
+ File.chmod(0600, child.file_path)
38
+ if Chef::Platform.windows?
39
+ read_mask = Chef::ReservedNames::Win32::API::Security::GENERIC_READ
40
+ write_mask = Chef::ReservedNames::Win32::API::Security::GENERIC_WRITE
41
+ owner = Chef::ReservedNames::Win32::Security::SID.current_user
42
+ dacl = Chef::ReservedNames::Win32::Security::ACL.create([
43
+ Chef::ReservedNames::Win32::Security::ACE.access_allowed(owner, read_mask),
44
+ Chef::ReservedNames::Win32::Security::ACE.access_allowed(owner, write_mask),
45
+ ])
46
+ so = Chef::ReservedNames::Win32::Security::SecurableObject.new(child.file_path)
47
+ so.owner = owner
48
+ so.set_dacl(dacl, false)
49
+ end
50
+ child
51
+ end
33
52
  end
34
53
  end
35
54
  end
@@ -22,6 +22,7 @@ require "chef/config"
22
22
  require "chef/mixin/params_validate"
23
23
  require "chef/mixin/path_sanity"
24
24
  require "chef/log"
25
+ require "chef/deprecated"
25
26
  require "chef/server_api"
26
27
  require "chef/api_client"
27
28
  require "chef/api_client/registration"
@@ -641,8 +641,8 @@ class Chef
641
641
  VERSION_CONSTRAINTS.each do |dependency_type, hash_key|
642
642
  if dependency_group = o[hash_key]
643
643
  dependency_group.each do |cb_name, constraints|
644
- if metadata.respond_to?(method_name)
645
- metadata.public_send(method_name, cb_name, *Array(constraints))
644
+ if metadata.respond_to?(dependency_type)
645
+ metadata.public_send(dependency_type, cb_name, *Array(constraints))
646
646
  end
647
647
  end
648
648
  end
@@ -54,12 +54,12 @@ class Chef
54
54
  attr_accessor :metadata_filenames
55
55
 
56
56
  def status=(new_status)
57
- Chef.log_deprecation("Deprecated method `status' called. This method will be removed.")
57
+ Chef.deprecated(:internal_api, "Deprecated method `status' called. This method will be removed.")
58
58
  @status = new_status
59
59
  end
60
60
 
61
61
  def status
62
- Chef.log_deprecation("Deprecated method `status' called. This method will be removed.")
62
+ Chef.deprecated(:internal_api, "Deprecated method `status' called. This method will be removed.")
63
63
  @status
64
64
  end
65
65
 
@@ -485,7 +485,7 @@ class Chef
485
485
  end
486
486
 
487
487
  def self.json_create(o)
488
- Chef.log_deprecation("Auto inflation of JSON data is deprecated. Please use Chef::CookbookVersion#from_hash")
488
+ Chef.deprecated(:json_auto_inflate, "Auto inflation of JSON data is deprecated. Please use Chef::CookbookVersion#from_hash")
489
489
  from_hash(o)
490
490
  end
491
491
 
@@ -496,7 +496,7 @@ class Chef
496
496
  # @deprecated This method was used by the Ruby Chef Server and is no longer
497
497
  # needed. There is no replacement.
498
498
  def generate_manifest_with_urls
499
- Chef.log_deprecation("Deprecated method #generate_manifest_with_urls.")
499
+ Chef.deprecated(:internal_api, "Deprecated method #generate_manifest_with_urls.")
500
500
 
501
501
  rendered_manifest = manifest.dup
502
502
  COOKBOOK_SEGMENTS.each do |segment|
@@ -80,7 +80,7 @@ class Chef
80
80
 
81
81
  # Create a Chef::Role from JSON
82
82
  def self.json_create(o)
83
- Chef.log_deprecation("Auto inflation of JSON data is deprecated. Please use Chef::DataBag#from_hash")
83
+ Chef.deprecated(:json_auto_inflate, "Auto inflation of JSON data is deprecated. Please use Chef::DataBag#from_hash")
84
84
  from_hash(o)
85
85
  end
86
86
 
@@ -141,7 +141,7 @@ class Chef
141
141
 
142
142
  # Create a Chef::DataBagItem from JSON
143
143
  def self.json_create(o)
144
- Chef.log_deprecation("Auto inflation of JSON data is deprecated. Please use Chef::DataBagItem#from_hash")
144
+ Chef.deprecated(:json_auto_inflate, "Auto inflation of JSON data is deprecated. Please use Chef::DataBagItem#from_hash")
145
145
  from_hash(o)
146
146
  end
147
147
 
@@ -174,12 +174,13 @@ class Chef
174
174
  # resource, and we only care about tracking top-level resources.
175
175
  def resource_current_state_loaded(new_resource, action, current_resource)
176
176
  return if nested_resource?(new_resource)
177
- update_current_resource_report(create_resource_report(new_resource, action, current_resource))
177
+ initialize_resource_report_if_needed(new_resource, action, current_resource)
178
178
  end
179
179
 
180
180
  # see EventDispatch::Base#resource_up_to_date
181
181
  # Mark our ResourceReport status accordingly
182
182
  def resource_up_to_date(new_resource, action)
183
+ initialize_resource_report_if_needed(new_resource, action)
183
184
  current_resource_report.up_to_date unless nested_resource?(new_resource)
184
185
  end
185
186
 
@@ -190,15 +191,15 @@ class Chef
190
191
  def resource_skipped(new_resource, action, conditional)
191
192
  return if nested_resource?(new_resource)
192
193
 
193
- resource_report = create_resource_report(new_resource, action)
194
- resource_report.skipped(conditional)
195
- update_current_resource_report(resource_report)
194
+ initialize_resource_report_if_needed(new_resource, action)
195
+ current_resource_report.skipped(conditional)
196
196
  end
197
197
 
198
198
  # see EventDispatch::Base#resource_updated
199
199
  # Flag the current ResourceReport instance as updated (as long as it's
200
200
  # a top-level resource).
201
201
  def resource_updated(new_resource, action)
202
+ initialize_resource_report_if_needed(new_resource, action)
202
203
  current_resource_report.updated unless nested_resource?(new_resource)
203
204
  end
204
205
 
@@ -207,6 +208,7 @@ class Chef
207
208
  # long as it's a top-level resource, and update the run error text
208
209
  # with the proper Formatter.
209
210
  def resource_failed(new_resource, action, exception)
211
+ initialize_resource_report_if_needed(new_resource, action)
210
212
  current_resource_report.failed(exception) unless nested_resource?(new_resource)
211
213
  update_error_description(
212
214
  Formatters::ErrorMapper.resource_failed(
@@ -224,7 +226,7 @@ class Chef
224
226
  if current_resource_report && !nested_resource?(new_resource)
225
227
  current_resource_report.finish
226
228
  add_resource_report(current_resource_report)
227
- update_current_resource_report(nil)
229
+ clear_current_resource_report
228
230
  end
229
231
  end
230
232
 
@@ -274,7 +276,7 @@ class Chef
274
276
  # see EventDispatch::Base#deprecation
275
277
  # Append a received deprecation to the list of deprecations
276
278
  def deprecation(message, location = caller(2..2)[0])
277
- add_deprecation(message, location)
279
+ add_deprecation(message.message, message.url, location)
278
280
  end
279
281
 
280
282
  private
@@ -331,7 +333,7 @@ class Chef
331
333
  def send_to_data_collector(message)
332
334
  return unless data_collector_accessible?
333
335
 
334
- Chef::Log.debug("data_collector_reporter: POSTing the following message to #{data_collector_server_url}: #{message}")
336
+ Chef::Log.debug("data_collector_reporter: POSTing the following message to #{data_collector_server_url}: #{Chef::JSONCompat.to_json(message)}")
335
337
  http.post(nil, message, headers)
336
338
  end
337
339
 
@@ -402,16 +404,17 @@ class Chef
402
404
  @run_status = run_status
403
405
  end
404
406
 
405
- def update_current_resource_report(resource_report)
406
- @current_resource_report = resource_report
407
- end
408
-
409
407
  def update_error_description(discription_hash)
410
408
  @error_descriptions = discription_hash
411
409
  end
412
410
 
413
- def add_deprecation(message, location)
414
- @deprecations << { message: message, location: location }
411
+ def add_deprecation(message, url, location)
412
+ @deprecations << { message: message, url: url, location: location }
413
+ end
414
+
415
+ def initialize_resource_report_if_needed(new_resource, action, current_resource = nil)
416
+ return unless current_resource_report.nil?
417
+ @current_resource_report = create_resource_report(new_resource, action, current_resource)
415
418
  end
416
419
 
417
420
  def create_resource_report(new_resource, action, current_resource = nil)
@@ -422,6 +425,10 @@ class Chef
422
425
  )
423
426
  end
424
427
 
428
+ def clear_current_resource_report
429
+ @current_resource_report = nil
430
+ end
431
+
425
432
  def detect_unprocessed_resources
426
433
  # create a Set containing all resource+action combinations from
427
434
  # the Resource Collection
@@ -18,7 +18,6 @@
18
18
  # limitations under the License.
19
19
  #
20
20
 
21
- require "json"
22
21
  require "securerandom"
23
22
  require_relative "messages/helpers"
24
23
 
@@ -142,14 +142,14 @@ class Chef
142
142
  # @return [Hash] DataCollector metadata for this node
143
143
  #
144
144
  def metadata
145
- JSON.load(Chef::FileCache.load(metadata_filename))
145
+ Chef::JSONCompat.parse(Chef::FileCache.load(metadata_filename))
146
146
  rescue Chef::Exceptions::FileNotFound
147
147
  {}
148
148
  end
149
149
 
150
150
  def update_metadata(key, value)
151
151
  updated_metadata = metadata.tap { |x| x[key] = value }
152
- Chef::FileCache.store(metadata_filename, updated_metadata.to_json, 0644)
152
+ Chef::FileCache.store(metadata_filename, Chef::JSONCompat.to_json(updated_metadata), 0644)
153
153
  end
154
154
 
155
155
  def metadata_filename
@@ -44,10 +44,10 @@ class Chef
44
44
  if symbol == :to_ary
45
45
  merged_attributes.send(symbol, *args)
46
46
  elsif args.empty?
47
- Chef.log_deprecation %q{method access to node attributes (node.foo.bar) is deprecated and will be removed in Chef 13, please use bracket syntax (node["foo"]["bar"])}
47
+ Chef.deprecated :attributes, %q{method access to node attributes (node.foo.bar) is deprecated and will be removed in Chef 13, please use bracket syntax (node["foo"]["bar"])}
48
48
  self[symbol]
49
49
  elsif symbol.to_s =~ /=$/
50
- Chef.log_deprecation %q{method setting of node attributes (node.foo="bar") is deprecated and will be removed in Chef 13, please use bracket syntax (node["foo"]="bar")}
50
+ Chef.deprecated :attributes, %q{method setting of node attributes (node.foo="bar") is deprecated and will be removed in Chef 13, please use bracket syntax (node["foo"]="bar")}
51
51
  key_to_set = symbol.to_s[/^(.+)=$/, 1]
52
52
  self[key_to_set] = (args.length == 1 ? args[0] : args)
53
53
  else
@@ -0,0 +1,190 @@
1
+ #--
2
+ # Copyright:: Copyright 2016 Chef Software, Inc.
3
+ # License:: Apache License, Version 2.0
4
+ #
5
+ # Licensed under the Apache License, Version 2.0 (the "License");
6
+ # you may not use this file except in compliance with the License.
7
+ # You may obtain a copy of the License at
8
+ #
9
+ # http://www.apache.org/licenses/LICENSE-2.0
10
+ #
11
+ # Unless required by applicable law or agreed to in writing, software
12
+ # distributed under the License is distributed on an "AS IS" BASIS,
13
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ # See the License for the specific language governing permissions and
15
+ # limitations under the License.
16
+ #
17
+
18
+ require "chef/mixin/convert_to_class_name"
19
+
20
+ # Structured deprecations have a unique URL associated with them, which must exist before the deprecation is merged.
21
+ class Chef
22
+ class Deprecated
23
+
24
+ class << self
25
+ include Chef::Mixin::ConvertToClassName
26
+
27
+ def create(type, message = nil, location = nil)
28
+ Chef::Deprecated.const_get(convert_to_class_name(type.to_s)).send(:new, message, location)
29
+ end
30
+ end
31
+
32
+ class Base
33
+ BASE_URL = "https://docs.chef.io/deprecations_"
34
+
35
+ attr_accessor :message, :location
36
+
37
+ def initialize(msg = nil, location = nil)
38
+ @message = msg if msg
39
+ @location = location if location
40
+ end
41
+
42
+ def link
43
+ "Please see #{url} for further details and information on how to correct this problem."
44
+ end
45
+
46
+ def url
47
+ "#{BASE_URL}#{target}"
48
+ end
49
+
50
+ # We know that the only time this gets called is by Chef::Log.deprecation,
51
+ # so special case
52
+ def <<(location)
53
+ @location = location
54
+ end
55
+
56
+ def inspect
57
+ "#{message} (CHEF-#{id})#{location}.\n#{link}"
58
+ end
59
+
60
+ def id
61
+ raise NotImplementedError, "subclasses of Chef::Deprecated::Base should define #id with a unique number"
62
+ end
63
+
64
+ def target
65
+ raise NotImplementedError, "subclasses of Chef::Deprecated::Base should define #target"
66
+ end
67
+ end
68
+
69
+ class JsonAutoInflate < Base
70
+ def id
71
+ 1
72
+ end
73
+
74
+ def target
75
+ "json_auto_inflate.html"
76
+ end
77
+ end
78
+
79
+ class ExitCode < Base
80
+ def id
81
+ 2
82
+ end
83
+
84
+ def target
85
+ "exit_code.html"
86
+ end
87
+ end
88
+
89
+ class ChefGemCompileTime < Base
90
+ def id
91
+ 3
92
+ end
93
+
94
+ def target
95
+ "chef_gem_compile_time.html"
96
+ end
97
+ end
98
+
99
+ class Attributes < Base
100
+ def id
101
+ 4
102
+ end
103
+
104
+ def target
105
+ "attributes.html"
106
+ end
107
+ end
108
+
109
+ class CustomResource < Base
110
+ def id
111
+ 5
112
+ end
113
+
114
+ def target
115
+ "custom_resource_cleanups.html"
116
+ end
117
+ end
118
+
119
+ class EasyInstall < Base
120
+ def id
121
+ 6
122
+ end
123
+
124
+ def target
125
+ "easy_install.html"
126
+ end
127
+ end
128
+
129
+ class VerifyFile < Base
130
+ def id
131
+ 7
132
+ end
133
+
134
+ def target
135
+ "verify_file.html"
136
+ end
137
+ end
138
+
139
+ class SupportsProperty < Base
140
+ def id
141
+ 8
142
+ end
143
+
144
+ def target
145
+ "supports_property.html"
146
+ end
147
+ end
148
+
149
+ class ChefRest < Base
150
+ def id
151
+ 9
152
+ end
153
+
154
+ def target
155
+ "chef_rest.html"
156
+ end
157
+ end
158
+
159
+ class ResourceCloning < Base
160
+ def id
161
+ 3694
162
+ end
163
+
164
+ def target
165
+ "resource_cloning.html"
166
+ end
167
+ end
168
+
169
+ class InternalApi < Base
170
+ def id
171
+ 0
172
+ end
173
+
174
+ def target
175
+ "internal_api.html"
176
+ end
177
+ end
178
+
179
+ class Generic < Base
180
+ def url
181
+ "https://docs.chef.io/chef_deprecations_client.html"
182
+ end
183
+
184
+ def inspect
185
+ "#{message}\nThis is a generic error message and should be updated to have a proper deprecation class. #{location}\nPlease see #{url} for an overview of Chef deprecations."
186
+ end
187
+ end
188
+
189
+ end
190
+ end
@@ -22,7 +22,7 @@ class Chef
22
22
  module RemoteDirectory
23
23
 
24
24
  def directory_root_in_cookbook_cache
25
- Chef.log_deprecation "the Chef::Provider::RemoteDirectory#directory_root_in_cookbook_cache method is deprecated"
25
+ Chef.deprecated :internal_api, "the Chef::Provider::RemoteDirectory#directory_root_in_cookbook_cache method is deprecated"
26
26
 
27
27
  @directory_root_in_cookbook_cache ||=
28
28
  begin
@@ -23,10 +23,9 @@ class Chef
23
23
  def add_deprecation_warnings_for(method_names)
24
24
  method_names.each do |name|
25
25
  define_method(name) do |*args|
26
- message = []
27
- message << "Method '#{name}' of '#{self.class}' is deprecated. It will be removed in Chef 13."
28
- message << "Please update your cookbooks accordingly."
29
- Chef.log_deprecation(message)
26
+ message = "Method '#{name}' of '#{self.class}' is deprecated. It will be removed in Chef 13."
27
+ message << " Please update your cookbooks accordingly."
28
+ Chef.deprecated(:internal_api, message)
30
29
  super(*args)
31
30
  end
32
31
  end