chef-dk 1.2.22 → 1.3.40

Sign up to get free protection for your applications and to get access to all the features.
Files changed (232) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile +8 -12
  3. data/Gemfile.lock +120 -116
  4. data/README.md +4 -3
  5. data/Rakefile +54 -0
  6. data/acceptance/Gemfile.lock +36 -47
  7. data/bin/chef +1 -1
  8. data/chef-dk.gemspec +9 -9
  9. data/lib/chef-dk/authenticated_http.rb +6 -7
  10. data/lib/chef-dk/builtin_commands.rb +3 -4
  11. data/lib/chef-dk/chef_runner.rb +7 -8
  12. data/lib/chef-dk/cli.rb +11 -11
  13. data/lib/chef-dk/command/base.rb +4 -4
  14. data/lib/chef-dk/command/clean_policy_cookbooks.rb +4 -5
  15. data/lib/chef-dk/command/clean_policy_revisions.rb +4 -6
  16. data/lib/chef-dk/command/delete_policy.rb +4 -6
  17. data/lib/chef-dk/command/delete_policy_group.rb +6 -8
  18. data/lib/chef-dk/command/diff.rb +9 -10
  19. data/lib/chef-dk/command/env.rb +26 -27
  20. data/lib/chef-dk/command/exec.rb +5 -6
  21. data/lib/chef-dk/command/export.rb +8 -10
  22. data/lib/chef-dk/command/gem.rb +5 -5
  23. data/lib/chef-dk/command/generate.rb +19 -19
  24. data/lib/chef-dk/command/generator_commands.rb +8 -8
  25. data/lib/chef-dk/command/generator_commands/app.rb +2 -3
  26. data/lib/chef-dk/command/generator_commands/attribute.rb +2 -3
  27. data/lib/chef-dk/command/generator_commands/base.rb +13 -13
  28. data/lib/chef-dk/command/generator_commands/build_cookbook.rb +2 -2
  29. data/lib/chef-dk/command/generator_commands/chef_exts/generator_desc_resource.rb +2 -2
  30. data/lib/chef-dk/command/generator_commands/chef_exts/quieter_doc_formatter.rb +1 -2
  31. data/lib/chef-dk/command/generator_commands/chef_exts/recipe_dsl_ext.rb +1 -2
  32. data/lib/chef-dk/command/generator_commands/cookbook.rb +2 -2
  33. data/lib/chef-dk/command/generator_commands/cookbook_code_file.rb +3 -3
  34. data/lib/chef-dk/command/generator_commands/cookbook_file.rb +2 -2
  35. data/lib/chef-dk/command/generator_commands/generator_generator.rb +4 -7
  36. data/lib/chef-dk/command/generator_commands/lwrp.rb +2 -2
  37. data/lib/chef-dk/command/generator_commands/policyfile.rb +2 -3
  38. data/lib/chef-dk/command/generator_commands/recipe.rb +2 -2
  39. data/lib/chef-dk/command/generator_commands/repo.rb +1 -3
  40. data/lib/chef-dk/command/generator_commands/template.rb +2 -2
  41. data/lib/chef-dk/command/install.rb +4 -5
  42. data/lib/chef-dk/command/provision.rb +12 -14
  43. data/lib/chef-dk/command/push.rb +5 -6
  44. data/lib/chef-dk/command/push_archive.rb +4 -5
  45. data/lib/chef-dk/command/shell_init.rb +15 -16
  46. data/lib/chef-dk/command/show_policy.rb +5 -7
  47. data/lib/chef-dk/command/undelete.rb +6 -7
  48. data/lib/chef-dk/command/update.rb +5 -6
  49. data/lib/chef-dk/command/verify.rb +30 -31
  50. data/lib/chef-dk/commands_map.rb +1 -3
  51. data/lib/chef-dk/component_test.rb +13 -13
  52. data/lib/chef-dk/configurable.rb +2 -2
  53. data/lib/chef-dk/cookbook_metadata.rb +2 -2
  54. data/lib/chef-dk/cookbook_omnifetch.rb +7 -8
  55. data/lib/chef-dk/cookbook_profiler/git.rb +8 -8
  56. data/lib/chef-dk/cookbook_profiler/identifiers.rb +7 -7
  57. data/lib/chef-dk/cookbook_profiler/null_scm.rb +0 -1
  58. data/lib/chef-dk/exceptions.rb +1 -1
  59. data/lib/chef-dk/generator.rb +9 -7
  60. data/lib/chef-dk/helpers.rb +15 -15
  61. data/lib/chef-dk/pager.rb +2 -3
  62. data/lib/chef-dk/policyfile/chef_repo_cookbook_source.rb +4 -4
  63. data/lib/chef-dk/policyfile/chef_server_cookbook_source.rb +6 -6
  64. data/lib/chef-dk/policyfile/community_cookbook_source.rb +4 -5
  65. data/lib/chef-dk/policyfile/comparison_base.rb +3 -4
  66. data/lib/chef-dk/policyfile/cookbook_location_specification.rb +6 -6
  67. data/lib/chef-dk/policyfile/cookbook_locks.rb +11 -11
  68. data/lib/chef-dk/policyfile/cookbook_sources.rb +5 -5
  69. data/lib/chef-dk/policyfile/delivery_supermarket_source.rb +8 -9
  70. data/lib/chef-dk/policyfile/differ.rb +7 -10
  71. data/lib/chef-dk/policyfile/dsl.rb +10 -11
  72. data/lib/chef-dk/policyfile/lister.rb +3 -6
  73. data/lib/chef-dk/policyfile/null_cookbook_source.rb +3 -3
  74. data/lib/chef-dk/policyfile/read_cookbook_for_compat_mode_upload.rb +3 -3
  75. data/lib/chef-dk/policyfile/reports/install.rb +3 -4
  76. data/lib/chef-dk/policyfile/reports/table_printer.rb +0 -1
  77. data/lib/chef-dk/policyfile/reports/upload.rb +4 -4
  78. data/lib/chef-dk/policyfile/solution_dependencies.rb +22 -22
  79. data/lib/chef-dk/policyfile/source_uri.rb +2 -2
  80. data/lib/chef-dk/policyfile/storage_config.rb +4 -5
  81. data/lib/chef-dk/policyfile/undo_record.rb +6 -9
  82. data/lib/chef-dk/policyfile/undo_stack.rb +5 -7
  83. data/lib/chef-dk/policyfile/uploader.rb +8 -8
  84. data/lib/chef-dk/policyfile_compiler.rb +16 -20
  85. data/lib/chef-dk/policyfile_lock.rb +10 -11
  86. data/lib/chef-dk/policyfile_services/clean_policies.rb +3 -3
  87. data/lib/chef-dk/policyfile_services/clean_policy_cookbooks.rb +3 -5
  88. data/lib/chef-dk/policyfile_services/export_repo.rb +13 -14
  89. data/lib/chef-dk/policyfile_services/install.rb +6 -6
  90. data/lib/chef-dk/policyfile_services/push.rb +6 -8
  91. data/lib/chef-dk/policyfile_services/push_archive.rb +6 -10
  92. data/lib/chef-dk/policyfile_services/rm_policy.rb +4 -5
  93. data/lib/chef-dk/policyfile_services/rm_policy_group.rb +4 -5
  94. data/lib/chef-dk/policyfile_services/show_policy.rb +5 -6
  95. data/lib/chef-dk/policyfile_services/undelete.rb +3 -3
  96. data/lib/chef-dk/policyfile_services/update_attributes.rb +4 -6
  97. data/lib/chef-dk/service_exception_inspectors.rb +2 -3
  98. data/lib/chef-dk/service_exception_inspectors/base.rb +0 -1
  99. data/lib/chef-dk/service_exception_inspectors/http.rb +1 -3
  100. data/lib/chef-dk/service_exceptions.rb +1 -2
  101. data/lib/chef-dk/shell_out.rb +1 -1
  102. data/lib/chef-dk/skeletons/code_generator/files/default/build_cookbook/.kitchen.yml +2 -2
  103. data/lib/chef-dk/skeletons/code_generator/files/default/build_cookbook/README.md +2 -2
  104. data/lib/chef-dk/skeletons/code_generator/files/default/build_cookbook/test-fixture-recipe.rb +1 -0
  105. data/lib/chef-dk/skeletons/code_generator/files/default/repo/cookbooks/example/attributes/default.rb +1 -1
  106. data/lib/chef-dk/skeletons/code_generator/files/default/repo/cookbooks/example/recipes/default.rb +1 -1
  107. data/lib/chef-dk/skeletons/code_generator/metadata.rb +0 -1
  108. data/lib/chef-dk/skeletons/code_generator/recipes/app.rb +6 -6
  109. data/lib/chef-dk/skeletons/code_generator/recipes/attribute.rb +3 -3
  110. data/lib/chef-dk/skeletons/code_generator/recipes/build_cookbook.rb +43 -39
  111. data/lib/chef-dk/skeletons/code_generator/recipes/cookbook.rb +31 -22
  112. data/lib/chef-dk/skeletons/code_generator/recipes/cookbook_file.rb +5 -5
  113. data/lib/chef-dk/skeletons/code_generator/recipes/lwrp.rb +4 -4
  114. data/lib/chef-dk/skeletons/code_generator/recipes/policyfile.rb +1 -1
  115. data/lib/chef-dk/skeletons/code_generator/recipes/recipe.rb +8 -8
  116. data/lib/chef-dk/skeletons/code_generator/recipes/repo.rb +15 -15
  117. data/lib/chef-dk/skeletons/code_generator/recipes/template.rb +6 -6
  118. data/lib/chef-dk/skeletons/code_generator/templates/default/build_cookbook/Berksfile.erb +0 -2
  119. data/lib/chef-dk/skeletons/code_generator/templates/default/build_cookbook/metadata.rb.erb +1 -0
  120. data/lib/chef-dk/skeletons/code_generator/templates/default/inspec_default_test.rb.erb +4 -4
  121. data/lib/chef-dk/skeletons/code_generator/templates/default/kitchen.yml.erb +1 -1
  122. data/lib/chef-dk/skeletons/code_generator/templates/default/kitchen_policyfile.yml.erb +1 -1
  123. data/lib/chef-dk/skeletons/code_generator/templates/default/metadata.rb.erb +4 -3
  124. data/lib/chef-dk/skeletons/code_generator/templates/default/recipe_spec.rb.erb +4 -2
  125. data/lib/chef-dk/ui.rb +0 -1
  126. data/lib/chef-dk/version.rb +1 -1
  127. data/lib/kitchen/provisioner/policyfile_zero.rb +7 -7
  128. data/omnibus_overrides.rb +3 -3
  129. data/spec/shared/a_file_generator.rb +3 -3
  130. data/spec/shared/custom_generator_cookbook.rb +6 -6
  131. data/spec/shared/fixture_cookbook_checksums.rb +2 -3
  132. data/spec/shared/setup_git_committer_config.rb +1 -1
  133. data/spec/shared/setup_git_cookbooks.rb +2 -2
  134. data/spec/spec_helper.rb +5 -5
  135. data/spec/test_helpers.rb +2 -2
  136. data/spec/unit/chef_runner_spec.rb +5 -7
  137. data/spec/unit/cli_spec.rb +36 -37
  138. data/spec/unit/command/base_spec.rb +4 -5
  139. data/spec/unit/command/clean_policy_cookbooks_spec.rb +8 -9
  140. data/spec/unit/command/clean_policy_revisions_spec.rb +8 -9
  141. data/spec/unit/command/delete_policy_group_spec.rb +11 -12
  142. data/spec/unit/command/delete_policy_spec.rb +11 -12
  143. data/spec/unit/command/diff_spec.rb +5 -6
  144. data/spec/unit/command/env_spec.rb +5 -5
  145. data/spec/unit/command/exec_spec.rb +18 -19
  146. data/spec/unit/command/export_spec.rb +5 -6
  147. data/spec/unit/command/generate_spec.rb +10 -10
  148. data/spec/unit/command/generator_commands/app_spec.rb +6 -6
  149. data/spec/unit/command/generator_commands/attribute_spec.rb +3 -4
  150. data/spec/unit/command/generator_commands/base_spec.rb +46 -46
  151. data/spec/unit/command/generator_commands/build_cookbook_spec.rb +50 -16
  152. data/spec/unit/command/generator_commands/chef_exts/generator_desc_resource_spec.rb +9 -9
  153. data/spec/unit/command/generator_commands/chef_exts/recipe_dsl_ext_spec.rb +16 -16
  154. data/spec/unit/command/generator_commands/cookbook_file_spec.rb +3 -4
  155. data/spec/unit/command/generator_commands/cookbook_spec.rb +23 -26
  156. data/spec/unit/command/generator_commands/generator_generator_spec.rb +4 -6
  157. data/spec/unit/command/generator_commands/lwrp_spec.rb +3 -4
  158. data/spec/unit/command/generator_commands/policyfile_spec.rb +3 -5
  159. data/spec/unit/command/generator_commands/recipe_spec.rb +4 -4
  160. data/spec/unit/command/generator_commands/repo_spec.rb +11 -11
  161. data/spec/unit/command/generator_commands/template_spec.rb +3 -4
  162. data/spec/unit/command/install_spec.rb +6 -6
  163. data/spec/unit/command/provision_spec.rb +27 -30
  164. data/spec/unit/command/push_archive_spec.rb +3 -3
  165. data/spec/unit/command/push_spec.rb +5 -6
  166. data/spec/unit/command/shell_init_spec.rb +17 -19
  167. data/spec/unit/command/show_policy_spec.rb +11 -12
  168. data/spec/unit/command/undelete_spec.rb +12 -14
  169. data/spec/unit/command/update_spec.rb +8 -8
  170. data/spec/unit/command/verify_spec.rb +10 -10
  171. data/spec/unit/commands_map_spec.rb +4 -4
  172. data/spec/unit/component_test_spec.rb +3 -3
  173. data/spec/unit/configurable_spec.rb +7 -7
  174. data/spec/unit/cookbook_metadata_spec.rb +5 -7
  175. data/spec/unit/cookbook_profiler/git_spec.rb +6 -7
  176. data/spec/unit/cookbook_profiler/identifiers_spec.rb +5 -7
  177. data/spec/unit/fixtures/command/cli_test_command.rb +2 -2
  178. data/spec/unit/fixtures/configurable/test_configurable.rb +1 -1
  179. data/spec/unit/fixtures/cookbooks_api/update_fixtures.rb +13 -16
  180. data/spec/unit/fixtures/eg_omnibus_dir/valid/embedded/apps/berkshelf/verify_me +1 -1
  181. data/spec/unit/gemfile_util_spec.rb +4 -4
  182. data/spec/unit/generator_spec.rb +10 -10
  183. data/spec/unit/helpers_spec.rb +31 -31
  184. data/spec/unit/pager_spec.rb +5 -7
  185. data/spec/unit/policyfile/chef_repo_cookbook_source_spec.rb +11 -11
  186. data/spec/unit/policyfile/chef_server_cookbook_source_spec.rb +13 -13
  187. data/spec/unit/policyfile/community_cookbook_source_spec.rb +3 -4
  188. data/spec/unit/policyfile/comparison_base_spec.rb +3 -6
  189. data/spec/unit/policyfile/cookbook_location_specification_spec.rb +3 -3
  190. data/spec/unit/policyfile/cookbook_locks_spec.rb +7 -9
  191. data/spec/unit/policyfile/delivery_supermarket_source_spec.rb +16 -17
  192. data/spec/unit/policyfile/differ_spec.rb +4 -5
  193. data/spec/unit/policyfile/lister_spec.rb +31 -35
  194. data/spec/unit/policyfile/null_cookbook_source_spec.rb +2 -3
  195. data/spec/unit/policyfile/read_cookbook_for_compat_mode_upload_spec.rb +3 -3
  196. data/spec/unit/policyfile/reports/install_spec.rb +4 -5
  197. data/spec/unit/policyfile/reports/upload_spec.rb +4 -6
  198. data/spec/unit/policyfile/solution_dependencies_spec.rb +13 -13
  199. data/spec/unit/policyfile/source_uri_spec.rb +5 -5
  200. data/spec/unit/policyfile/storage_config_spec.rb +3 -7
  201. data/spec/unit/policyfile/undo_record_spec.rb +21 -23
  202. data/spec/unit/policyfile/undo_stack_spec.rb +5 -6
  203. data/spec/unit/policyfile/uploader_spec.rb +73 -75
  204. data/spec/unit/policyfile_demands_spec.rb +93 -99
  205. data/spec/unit/policyfile_evaluation_spec.rb +14 -14
  206. data/spec/unit/policyfile_lock_build_spec.rb +64 -65
  207. data/spec/unit/policyfile_lock_install_spec.rb +5 -6
  208. data/spec/unit/policyfile_lock_serialization_spec.rb +14 -15
  209. data/spec/unit/policyfile_lock_validation_spec.rb +17 -20
  210. data/spec/unit/policyfile_services/clean_policies_spec.rb +16 -16
  211. data/spec/unit/policyfile_services/clean_policy_cookbooks_spec.rb +26 -29
  212. data/spec/unit/policyfile_services/export_repo_spec.rb +3 -6
  213. data/spec/unit/policyfile_services/install_spec.rb +5 -7
  214. data/spec/unit/policyfile_services/push_archive_spec.rb +4 -8
  215. data/spec/unit/policyfile_services/push_spec.rb +3 -3
  216. data/spec/unit/policyfile_services/rm_policy_group_spec.rb +16 -20
  217. data/spec/unit/policyfile_services/rm_policy_spec.rb +14 -17
  218. data/spec/unit/policyfile_services/show_policy_spec.rb +78 -80
  219. data/spec/unit/policyfile_services/undelete_spec.rb +5 -7
  220. data/spec/unit/policyfile_services/update_attributes_spec.rb +34 -35
  221. data/spec/unit/service_exception_inspectors/base_spec.rb +2 -4
  222. data/spec/unit/service_exception_inspectors/http_spec.rb +9 -11
  223. data/spec/unit/shell_out_spec.rb +2 -2
  224. data/spec/unit/tasks/helpers_spec.rb +2 -2
  225. data/tasks/bin/bundle-platform +1 -1
  226. data/tasks/bundle_util.rb +1 -1
  227. data/tasks/dependencies.rb +21 -7
  228. data/tasks/gemfile_util.rb +1 -1
  229. data/tasks/helpers.rb +2 -2
  230. data/tasks/version.rb +26 -1
  231. data/version_policy.rb +6 -6
  232. metadata +3 -3
@@ -15,8 +15,8 @@
15
15
  # limitations under the License.
16
16
  #
17
17
 
18
- require 'addressable/uri'
19
- require 'chef-dk/exceptions'
18
+ require "addressable/uri"
19
+ require "chef-dk/exceptions"
20
20
 
21
21
  module ChefDK
22
22
  module Policyfile
@@ -15,8 +15,8 @@
15
15
  # limitations under the License.
16
16
  #
17
17
 
18
- require 'chef-dk/cookbook_omnifetch'
19
- require 'chef-dk/exceptions'
18
+ require "chef-dk/cookbook_omnifetch"
19
+ require "chef-dk/exceptions"
20
20
 
21
21
  module ChefDK
22
22
  module Policyfile
@@ -45,14 +45,14 @@ module ChefDK
45
45
  raise InvalidPolicyfileFilename, "Policyfile filenames must end with `.rb' extension (you gave: `#{policyfile_filename}')"
46
46
  end
47
47
  @policyfile_filename = policyfile_filename
48
- @policyfile_lock_filename = policyfile_filename.sub(/\.rb\Z/, '.lock.json')
48
+ @policyfile_lock_filename = policyfile_filename.sub(/\.rb\Z/, ".lock.json")
49
49
  @relative_paths_root = File.dirname(policyfile_filename)
50
50
  self
51
51
  end
52
52
 
53
53
  def use_policyfile_lock(policyfile_lock_filename)
54
54
  @policyfile_lock_filename = policyfile_lock_filename
55
- @policyfile_filename = policyfile_lock_filename.sub(/\.lock\.json\Z/, '.rb')
55
+ @policyfile_filename = policyfile_lock_filename.sub(/\.lock\.json\Z/, ".rb")
56
56
  @relative_paths_root = File.dirname(policyfile_lock_filename)
57
57
  self
58
58
  end
@@ -100,4 +100,3 @@ module ChefDK
100
100
 
101
101
  end
102
102
  end
103
-
@@ -15,7 +15,7 @@
15
15
  # limitations under the License.
16
16
  #
17
17
 
18
- require 'chef-dk/exceptions'
18
+ require "chef-dk/exceptions"
19
19
 
20
20
  module ChefDK
21
21
  module Policyfile
@@ -35,7 +35,7 @@ module ChefDK
35
35
  {
36
36
  "policy_name" => policy_name,
37
37
  "policy_group" => policy_group,
38
- "data" => data
38
+ "data" => data,
39
39
  }
40
40
  end
41
41
 
@@ -71,7 +71,7 @@ module ChefDK
71
71
  unless data.kind_of?(Hash)
72
72
  raise InvalidUndoRecord, "Undo data is incorrectly formatted. Must be a Hash, got '#{data}'."
73
73
  end
74
- missing_fields = %w[ format_version description backup_data ].select { |key| !data.key?(key) }
74
+ missing_fields = %w{ format_version description backup_data }.select { |key| !data.key?(key) }
75
75
  unless missing_fields.empty?
76
76
  raise InvalidUndoRecord, "Undo data is missing mandatory field(s) #{missing_fields.join(', ')}. Undo data: '#{data}'"
77
77
  end
@@ -82,7 +82,7 @@ module ChefDK
82
82
  unless policy_data.kind_of?(Hash)
83
83
  raise InvalidUndoRecord, "'backup_data' in the undo record is incorrectly formatted. Must be a Hash, got '#{policy_data}'"
84
84
  end
85
- missing_policy_data_fields = %w[ policy_groups policy_revisions ].select { |key| !policy_data.key?(key) }
85
+ missing_policy_data_fields = %w{ policy_groups policy_revisions }.select { |key| !policy_data.key?(key) }
86
86
  unless missing_policy_data_fields.empty?
87
87
  raise InvalidUndoRecord,
88
88
  "'backup_data' in the undo record is missing mandatory field(s) #{missing_policy_data_fields.join(', ')}. Backup data: #{policy_data}"
@@ -121,8 +121,8 @@ module ChefDK
121
121
  "description" => description,
122
122
  "backup_data" => {
123
123
  "policy_groups" => policy_groups,
124
- "policy_revisions" => policy_revisions.map(&:for_serialization)
125
- }
124
+ "policy_revisions" => policy_revisions.map(&:for_serialization),
125
+ },
126
126
  }
127
127
  end
128
128
 
@@ -137,6 +137,3 @@ module ChefDK
137
137
  end
138
138
  end
139
139
  end
140
-
141
-
142
-
@@ -15,12 +15,12 @@
15
15
  # limitations under the License.
16
16
  #
17
17
 
18
- require 'fileutils'
18
+ require "fileutils"
19
19
 
20
- require 'ffi_yajl'
20
+ require "ffi_yajl"
21
21
 
22
- require 'chef-dk/helpers'
23
- require 'chef-dk/policyfile/undo_record'
22
+ require "chef-dk/helpers"
23
+ require "chef-dk/policyfile/undo_record"
24
24
 
25
25
  module ChefDK
26
26
  module Policyfile
@@ -114,17 +114,15 @@ module ChefDK
114
114
  end
115
115
 
116
116
  def undo_record_files
117
- Dir[File.join(undo_dir, '*')].sort
117
+ Dir[File.join(undo_dir, "*")].sort
118
118
  end
119
119
 
120
120
  def ensure_undo_dir_exists
121
121
  return false if File.directory?(undo_dir)
122
122
 
123
-
124
123
  FileUtils.mkdir_p(undo_dir)
125
124
  end
126
125
  end
127
126
 
128
127
  end
129
128
  end
130
-
@@ -15,11 +15,11 @@
15
15
  # limitations under the License.
16
16
  #
17
17
 
18
- require 'chef/cookbook_uploader'
19
- require 'chef-dk/policyfile/read_cookbook_for_compat_mode_upload'
18
+ require "chef/cookbook_uploader"
19
+ require "chef-dk/policyfile/read_cookbook_for_compat_mode_upload"
20
20
 
21
- require 'chef-dk/ui'
22
- require 'chef-dk/policyfile/reports/upload'
21
+ require "chef-dk/ui"
22
+ require "chef-dk/policyfile/reports/upload"
23
23
 
24
24
  module ChefDK
25
25
  module Policyfile
@@ -77,7 +77,7 @@ DRAGONS
77
77
  end
78
78
 
79
79
  def data_bag_create
80
- http_client.post("data", {"name" => COMPAT_MODE_DATA_BAG_NAME})
80
+ http_client.post("data", { "name" => COMPAT_MODE_DATA_BAG_NAME })
81
81
  rescue Net::HTTPServerException => e
82
82
  raise e unless e.response.code == "409"
83
83
  end
@@ -95,7 +95,7 @@ DRAGONS
95
95
  "raw_data" => lock_data,
96
96
  # we'd prefer to leave this out, but the "compatibility mode"
97
97
  # implementation in chef-client relies on magical class inflation
98
- "json_class" => "Chef::DataBagItem"
98
+ "json_class" => "Chef::DataBagItem",
99
99
  }
100
100
 
101
101
  upload_lockfile_as_data_bag_item(policy_id, data_item)
@@ -182,9 +182,9 @@ DRAGONS
182
182
 
183
183
  def list_cookbooks_url
184
184
  if using_policy_document_native_api?
185
- 'cookbook_artifacts?num_versions=all'
185
+ "cookbook_artifacts?num_versions=all"
186
186
  else
187
- 'cookbooks?num_versions=all'
187
+ "cookbooks?num_versions=all"
188
188
  end
189
189
  end
190
190
 
@@ -15,17 +15,17 @@
15
15
  # limitations under the License.
16
16
  #
17
17
 
18
- require 'set'
19
- require 'forwardable'
18
+ require "set"
19
+ require "forwardable"
20
20
 
21
- require 'solve'
22
- require 'chef/run_list'
21
+ require "solve"
22
+ require "chef/run_list"
23
23
 
24
- require 'chef-dk/policyfile/dsl'
25
- require 'chef-dk/policyfile_lock'
26
- require 'chef-dk/ui'
27
- require 'chef-dk/policyfile/reports/install'
28
- require 'chef-dk/exceptions'
24
+ require "chef-dk/policyfile/dsl"
25
+ require "chef-dk/policyfile_lock"
26
+ require "chef-dk/ui"
27
+ require "chef-dk/policyfile/reports/install"
28
+ require "chef-dk/exceptions"
29
29
 
30
30
  module ChefDK
31
31
 
@@ -33,7 +33,7 @@ module ChefDK
33
33
 
34
34
  extend Forwardable
35
35
 
36
- DEFAULT_DEMAND_CONSTRAINT = '>= 0.0.0'.freeze
36
+ DEFAULT_DEMAND_CONSTRAINT = ">= 0.0.0".freeze
37
37
 
38
38
  # Cookbooks from these sources lock that cookbook to exactly one version
39
39
  SOURCE_TYPES_WITH_FIXED_VERSIONS = [:git, :path].freeze
@@ -95,7 +95,7 @@ module ChefDK
95
95
  end
96
96
 
97
97
  def normalized_named_run_lists
98
- expanded_named_run_lists.inject({}) do |normalized,(name, run_list)|
98
+ expanded_named_run_lists.inject({}) do |normalized, (name, run_list)|
99
99
  normalized[name] = run_list.map { |i| normalize_recipe(i) }
100
100
  normalized
101
101
  end
@@ -126,14 +126,14 @@ module ChefDK
126
126
 
127
127
  graph_solution.each do |cookbook_name, version|
128
128
  spec = cookbook_location_spec_for(cookbook_name)
129
- if spec.nil? or !spec.version_fixed?
129
+ if spec.nil? || !spec.version_fixed?
130
130
  spec = create_spec_for_cookbook(cookbook_name, version)
131
131
  install_report.installing_cookbook(spec)
132
132
  spec.ensure_cached
133
133
  end
134
134
 
135
135
  required_recipes = cookbook_and_recipe_list.select { |cb_name, _recipe| cb_name == spec.name }
136
- missing_recipes = required_recipes.select {|_cb_name, recipe| !spec.cookbook_has_recipe?(recipe) }
136
+ missing_recipes = required_recipes.select { |_cb_name, recipe| !spec.cookbook_has_recipe?(recipe) }
137
137
 
138
138
  unless missing_recipes.empty?
139
139
  missing_recipes_by_cb_spec[spec] = missing_recipes
@@ -143,7 +143,7 @@ module ChefDK
143
143
  unless missing_recipes_by_cb_spec.empty?
144
144
  message = "The installed cookbooks do not contain all the recipes required by your run list(s):\n"
145
145
  missing_recipes_by_cb_spec.each do |spec, missing_items|
146
- message << "#{spec.to_s}\nis missing the following required recipes:\n"
146
+ message << "#{spec}\nis missing the following required recipes:\n"
147
147
  missing_items.each { |_cb, recipe| message << "* #{recipe}\n" }
148
148
  end
149
149
 
@@ -152,8 +152,6 @@ module ChefDK
152
152
 
153
153
  raise CookbookDoesNotContainRequiredRecipe, message
154
154
  end
155
-
156
-
157
155
  end
158
156
 
159
157
  def create_spec_for_cookbook(cookbook_name, version)
@@ -265,7 +263,7 @@ module ChefDK
265
263
  end
266
264
 
267
265
  def version_constraint_for(cookbook_name)
268
- if (cookbook_location_spec = cookbook_location_spec_for(cookbook_name)) and cookbook_location_spec.version_fixed?
266
+ if (cookbook_location_spec = cookbook_location_spec_for(cookbook_name)) && cookbook_location_spec.version_fixed?
269
267
  version = cookbook_location_spec.version
270
268
  "= #{version}"
271
269
  else
@@ -282,7 +280,7 @@ module ChefDK
282
280
  end
283
281
 
284
282
  def cookbooks_in_run_list
285
- recipes = combined_run_lists.map {|recipe| recipe.name }
283
+ recipes = combined_run_lists.map { |recipe| recipe.name }
286
284
  recipes.map { |r| r[/^([^:]+)/, 1] }
287
285
  end
288
286
 
@@ -298,7 +296,6 @@ module ChefDK
298
296
  end
299
297
  end
300
298
 
301
-
302
299
  def build
303
300
  yield @dsl
304
301
  self
@@ -358,7 +355,6 @@ module ChefDK
358
355
  end
359
356
  end
360
357
 
361
-
362
358
  def preferred_source_for_cookbook(conflicting_cb_name)
363
359
  default_source.find { |s| s.preferred_source_for?(conflicting_cb_name) }
364
360
  end
@@ -16,12 +16,12 @@
16
16
  # limitations under the License.
17
17
  #
18
18
 
19
- require 'digest/sha2'
19
+ require "digest/sha2"
20
20
 
21
- require 'chef-dk/policyfile/storage_config'
22
- require 'chef-dk/policyfile/cookbook_locks'
23
- require 'chef-dk/policyfile/solution_dependencies'
24
- require 'chef-dk/ui'
21
+ require "chef-dk/policyfile/storage_config"
22
+ require "chef-dk/policyfile/cookbook_locks"
23
+ require "chef-dk/policyfile/solution_dependencies"
24
+ require "chef-dk/ui"
25
25
 
26
26
  module ChefDK
27
27
 
@@ -65,7 +65,7 @@ module ChefDK
65
65
  end
66
66
  end
67
67
 
68
- RUN_LIST_ITEM_FORMAT = /\Arecipe\[[^\s]+::[^\s]+\]\Z/.freeze
68
+ RUN_LIST_ITEM_FORMAT = /\Arecipe\[[^\s]+::[^\s]+\]\Z/
69
69
 
70
70
  def self.build(storage_config)
71
71
  lock = new(storage_config)
@@ -319,7 +319,7 @@ module ChefDK
319
319
  # keys to UTF-8 first so that the sort order uses the UTF-8 strings.
320
320
  item_with_normalized_keys = item.inject({}) do |normalized_item, (key, value)|
321
321
  validate_attr_key(key)
322
- normalized_item[key.encode('utf-8')] = value
322
+ normalized_item[key.encode("utf-8")] = value
323
323
  normalized_item
324
324
  end
325
325
  elements = item_with_normalized_keys.keys.sort.map do |key|
@@ -327,12 +327,12 @@ module ChefDK
327
327
  v = canonicalize_elements(item_with_normalized_keys[key])
328
328
  k << v
329
329
  end
330
- "{" << elements.join(',') << "}"
330
+ "{" << elements.join(",") << "}"
331
331
  when String
332
- '"' << item.encode('utf-8') << '"'
332
+ '"' << item.encode("utf-8") << '"'
333
333
  when Array
334
334
  elements = item.map { |i| canonicalize_elements(i) }
335
- '[' << elements.join(',') << ']'
335
+ "[" << elements.join(",") << "]"
336
336
  when Integer
337
337
  item.to_s
338
338
  when Float
@@ -396,7 +396,6 @@ module ChefDK
396
396
  end
397
397
 
398
398
  @name = name_attribute
399
-
400
399
  end
401
400
 
402
401
  def set_run_list_from_lock_data(lock_data)
@@ -15,9 +15,9 @@
15
15
  # limitations under the License.
16
16
  #
17
17
 
18
- require 'chef-dk/exceptions'
19
- require 'chef-dk/service_exceptions'
20
- require 'chef-dk/policyfile/lister'
18
+ require "chef-dk/exceptions"
19
+ require "chef-dk/service_exceptions"
20
+ require "chef-dk/policyfile/lister"
21
21
 
22
22
  module ChefDK
23
23
  module PolicyfileServices
@@ -15,10 +15,10 @@
15
15
  # limitations under the License.
16
16
  #
17
17
 
18
- require 'set'
18
+ require "set"
19
19
 
20
- require 'chef-dk/authenticated_http'
21
- require 'chef-dk/service_exceptions'
20
+ require "chef-dk/authenticated_http"
21
+ require "chef-dk/service_exceptions"
22
22
 
23
23
  module ChefDK
24
24
  module PolicyfileServices
@@ -59,7 +59,6 @@ module ChefDK
59
59
  end
60
60
  end
61
61
 
62
-
63
62
  def all_cookbooks
64
63
  cookbook_list = http_client.get("/cookbook_artifacts")
65
64
  cookbook_list.inject({}) do |cb_map, (name, cb_info)|
@@ -122,4 +121,3 @@ module ChefDK
122
121
  end
123
122
  end
124
123
  end
125
-
@@ -15,18 +15,18 @@
15
15
  # limitations under the License.
16
16
  #
17
17
 
18
- require 'pathname'
19
- require 'fileutils'
20
- require 'tmpdir'
21
- require 'zlib'
18
+ require "pathname"
19
+ require "fileutils"
20
+ require "tmpdir"
21
+ require "zlib"
22
22
 
23
- require 'archive/tar/minitar'
23
+ require "archive/tar/minitar"
24
24
 
25
- require 'chef/cookbook/chefignore'
25
+ require "chef/cookbook/chefignore"
26
26
 
27
- require 'chef-dk/service_exceptions'
28
- require 'chef-dk/policyfile_lock'
29
- require 'chef-dk/policyfile/storage_config'
27
+ require "chef-dk/service_exceptions"
28
+ require "chef-dk/policyfile_lock"
29
+ require "chef-dk/policyfile/storage_config"
30
30
 
31
31
  module ChefDK
32
32
  module PolicyfileServices
@@ -37,7 +37,7 @@ module ChefDK
37
37
  # have multiple active iterations of a policy at once, but we don't need
38
38
  # this when serving a single exported policy via Chef Zero, so hardcode
39
39
  # it to a "well known" value:
40
- POLICY_GROUP = 'local'.freeze
40
+ POLICY_GROUP = "local".freeze
41
41
 
42
42
  include Policyfile::StorageConfigDelegation
43
43
 
@@ -211,9 +211,9 @@ module ChefDK
211
211
  data = {
212
212
  "policies" => {
213
213
  policyfile_lock.name => {
214
- "revision_id" => policyfile_lock.revision_id
215
- }
216
- }
214
+ "revision_id" => policyfile_lock.revision_id,
215
+ },
216
+ },
217
217
  }
218
218
 
219
219
  File.open(policy_group_repo_item_path, "wb+") do |f|
@@ -418,4 +418,3 @@ README
418
418
 
419
419
  end
420
420
  end
421
-
@@ -15,13 +15,13 @@
15
15
  # limitations under the License.
16
16
  #
17
17
 
18
- require 'ffi_yajl'
18
+ require "ffi_yajl"
19
19
 
20
- require 'chef-dk/helpers'
21
- require 'chef-dk/service_exceptions'
22
- require 'chef-dk/policyfile_compiler'
23
- require 'chef-dk/policyfile/storage_config'
24
- require 'chef-dk/policyfile_lock'
20
+ require "chef-dk/helpers"
21
+ require "chef-dk/service_exceptions"
22
+ require "chef-dk/policyfile_compiler"
23
+ require "chef-dk/policyfile/storage_config"
24
+ require "chef-dk/policyfile_lock"
25
25
 
26
26
  module ChefDK
27
27
  module PolicyfileServices