chef 16.5.64 → 16.8.14
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Gemfile +6 -14
- data/README.md +1 -1
- data/Rakefile +21 -14
- data/chef-universal-mingw32.gemspec +1 -1
- data/chef.gemspec +3 -2
- data/lib/chef/application.rb +2 -2
- data/lib/chef/application/base.rb +1 -1
- data/lib/chef/application/client.rb +7 -2
- data/lib/chef/application/knife.rb +1 -1
- data/lib/chef/application/solo.rb +1 -1
- data/lib/chef/chef_fs/chef_fs_data_store.rb +1 -1
- data/lib/chef/chef_fs/data_handler/cookbook_data_handler.rb +1 -1
- data/lib/chef/chef_fs/file_pattern.rb +1 -1
- data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbook_entry.rb +1 -1
- data/lib/chef/client.rb +6 -32
- data/lib/chef/compliance/default_attributes.rb +89 -0
- data/lib/chef/compliance/fetcher/automate.rb +69 -0
- data/lib/chef/compliance/fetcher/chef_server.rb +134 -0
- data/lib/chef/compliance/reporter/automate.rb +202 -0
- data/lib/chef/compliance/reporter/chef_server_automate.rb +94 -0
- data/lib/chef/compliance/reporter/compliance_enforcer.rb +20 -0
- data/lib/chef/compliance/reporter/json_file.rb +19 -0
- data/lib/chef/compliance/runner.rb +261 -0
- data/lib/chef/cookbook/gem_installer.rb +1 -1
- data/lib/chef/cookbook_manifest.rb +2 -1
- data/lib/chef/cookbook_site_streaming_uploader.rb +1 -1
- data/lib/chef/cookbook_version.rb +2 -5
- data/lib/chef/data_collector.rb +1 -1
- data/lib/chef/encrypted_data_bag_item/assertions.rb +1 -1
- data/lib/chef/environment.rb +1 -1
- data/lib/chef/event_loggers/windows_eventlog.rb +1 -1
- data/lib/chef/exceptions.rb +5 -1
- data/lib/chef/file_access_control/windows.rb +1 -4
- data/lib/chef/file_content_management/tempfile.rb +1 -1
- data/lib/chef/formatters/error_inspectors/compile_error_inspector.rb +2 -2
- data/lib/chef/formatters/error_inspectors/resource_failure_inspector.rb +5 -5
- data/lib/chef/formatters/indentable_output_stream.rb +2 -2
- data/lib/chef/guard_interpreter/resource_guard_interpreter.rb +28 -39
- data/lib/chef/http.rb +2 -12
- data/lib/chef/http/basic_client.rb +1 -1
- data/lib/chef/http/http_request.rb +1 -1
- data/lib/chef/http/socketless_chef_zero_client.rb +1 -1
- data/lib/chef/http/ssl_policies.rb +6 -0
- data/lib/chef/json_compat.rb +2 -7
- data/lib/chef/key.rb +1 -1
- data/lib/chef/knife/bootstrap.rb +2 -1
- data/lib/chef/knife/bootstrap/templates/windows-chef-client-msi.erb +2 -2
- data/lib/chef/knife/bootstrap/train_connector.rb +1 -1
- data/lib/chef/knife/config_show.rb +1 -1
- data/lib/chef/knife/core/cookbook_scm_repo.rb +1 -1
- data/lib/chef/knife/core/gem_glob_loader.rb +1 -1
- data/lib/chef/knife/core/ui.rb +5 -2
- data/lib/chef/knife/core/windows_bootstrap_context.rb +7 -4
- data/lib/chef/knife/node_policy_set.rb +2 -2
- data/lib/chef/knife/node_run_list_add.rb +1 -1
- data/lib/chef/knife/node_run_list_remove.rb +1 -1
- data/lib/chef/knife/node_run_list_set.rb +1 -1
- data/lib/chef/knife/role_env_run_list_add.rb +1 -1
- data/lib/chef/knife/role_env_run_list_set.rb +1 -1
- data/lib/chef/knife/role_run_list_add.rb +1 -1
- data/lib/chef/knife/role_run_list_set.rb +1 -1
- data/lib/chef/knife/search.rb +0 -1
- data/lib/chef/knife/ssh.rb +5 -3
- data/lib/chef/knife/tag_create.rb +1 -1
- data/lib/chef/knife/tag_delete.rb +1 -1
- data/lib/chef/local_mode.rb +1 -1
- data/lib/chef/mixin/convert_to_class_name.rb +0 -56
- data/lib/chef/mixin/openssl_helper.rb +1 -1
- data/lib/chef/mixin/powershell_exec.rb +24 -10
- data/lib/chef/mixin/powershell_out.rb +12 -5
- data/lib/chef/mixin/properties.rb +2 -0
- data/lib/chef/mixin/template.rb +1 -1
- data/lib/chef/mixin/unformatter.rb +1 -1
- data/lib/chef/mixin/uris.rb +3 -1
- data/lib/chef/node/attribute_collections.rb +2 -6
- data/lib/chef/node/mixin/immutablize_hash.rb +2 -0
- data/lib/chef/node_map.rb +2 -2
- data/lib/chef/platform/query_helpers.rb +4 -4
- data/lib/chef/policy_builder/dynamic.rb +2 -0
- data/lib/chef/powershell.rb +10 -4
- data/lib/chef/property.rb +1 -1
- data/lib/chef/provider.rb +1 -1
- data/lib/chef/provider/cron.rb +2 -13
- data/lib/chef/provider/dsc_resource.rb +12 -24
- data/lib/chef/provider/dsc_script.rb +16 -20
- data/lib/chef/provider/file.rb +1 -1
- data/lib/chef/provider/git.rb +5 -5
- data/lib/chef/provider/group.rb +14 -6
- data/lib/chef/provider/group/windows.rb +12 -1
- data/lib/chef/provider/ifconfig.rb +8 -8
- data/lib/chef/provider/ifconfig/debian.rb +38 -22
- data/lib/chef/provider/ifconfig/redhat.rb +54 -18
- data/lib/chef/provider/launchd.rb +1 -11
- data/lib/chef/provider/link.rb +0 -9
- data/lib/chef/provider/mount.rb +18 -1
- data/lib/chef/provider/mount/linux.rb +4 -0
- data/lib/chef/provider/mount/mount.rb +41 -43
- data/lib/chef/provider/package.rb +3 -0
- data/lib/chef/provider/package/apt.rb +1 -1
- data/lib/chef/provider/package/chocolatey.rb +6 -6
- data/lib/chef/provider/package/dpkg.rb +3 -12
- data/lib/chef/provider/package/freebsd/base.rb +3 -2
- data/lib/chef/provider/package/freebsd/pkgng.rb +1 -1
- data/lib/chef/provider/package/homebrew.rb +1 -1
- data/lib/chef/provider/package/ips.rb +1 -1
- data/lib/chef/provider/package/powershell.rb +2 -3
- data/lib/chef/provider/package/rubygems.rb +1 -1
- data/lib/chef/provider/package/snap.rb +1 -3
- data/lib/chef/provider/package/solaris.rb +0 -2
- data/lib/chef/provider/package/yum/rpm_utils.rb +1 -1
- data/lib/chef/provider/package/zypper.rb +98 -71
- data/lib/chef/provider/powershell_script.rb +12 -1
- data/lib/chef/provider/registry_key.rb +4 -3
- data/lib/chef/provider/route.rb +2 -2
- data/lib/chef/provider/service/debian.rb +2 -1
- data/lib/chef/provider/service/redhat.rb +1 -1
- data/lib/chef/provider/user.rb +17 -9
- data/lib/chef/provider/user/aix.rb +1 -1
- data/lib/chef/provider/user/dscl.rb +2 -2
- data/lib/chef/provider/user/mac.rb +14 -6
- data/lib/chef/provider/user/solaris.rb +1 -1
- data/lib/chef/provider/user/windows.rb +10 -3
- data/lib/chef/providers.rb +0 -3
- data/lib/chef/pwsh.rb +71 -0
- data/lib/chef/resource.rb +1 -1
- data/lib/chef/resource/apt_repository.rb +6 -5
- data/lib/chef/resource/bash.rb +119 -1
- data/lib/chef/resource/batch.rb +1 -1
- data/lib/chef/resource/breakpoint.rb +3 -1
- data/lib/chef/resource/build_essential.rb +5 -8
- data/lib/chef/resource/chef_client_config.rb +313 -0
- data/lib/chef/resource/chef_client_cron.rb +5 -5
- data/lib/chef/resource/chef_client_scheduled_task.rb +4 -4
- data/lib/chef/resource/chef_client_systemd_timer.rb +5 -5
- data/lib/chef/resource/chef_handler.rb +1 -0
- data/lib/chef/resource/chef_sleep.rb +1 -1
- data/lib/chef/resource/cron/_cron_shared.rb +1 -0
- data/lib/chef/resource/cron/cron_d.rb +2 -2
- data/lib/chef/resource/csh.rb +2 -2
- data/lib/chef/resource/dsc_script.rb +8 -1
- data/lib/chef/resource/execute.rb +6 -4
- data/lib/chef/resource/file.rb +2 -2
- data/lib/chef/resource/homebrew_update.rb +4 -1
- data/lib/chef/resource/hostname.rb +5 -5
- data/lib/chef/resource/ifconfig.rb +52 -5
- data/lib/chef/resource/kernel_module.rb +1 -1
- data/lib/chef/resource/ksh.rb +3 -3
- data/lib/chef/resource/launchd.rb +15 -15
- data/lib/chef/resource/lwrp_base.rb +3 -5
- data/lib/chef/resource/mount.rb +8 -2
- data/lib/chef/resource/perl.rb +2 -2
- data/lib/chef/resource/plist.rb +2 -6
- data/lib/chef/resource/powershell_package_source.rb +19 -18
- data/lib/chef/resource/powershell_script.rb +14 -11
- data/lib/chef/resource/python.rb +2 -2
- data/lib/chef/resource/registry_key.rb +93 -2
- data/lib/chef/resource/route.rb +1 -1
- data/lib/chef/resource/ruby.rb +2 -2
- data/lib/chef/resource/scm/_scm.rb +2 -1
- data/lib/chef/resource/scm/git.rb +82 -1
- data/lib/chef/resource/scm/subversion.rb +12 -0
- data/lib/chef/resource/script.rb +2 -2
- data/lib/chef/resource/solaris_package.rb +0 -2
- data/lib/chef/resource/sudo.rb +1 -1
- data/lib/chef/resource/support/client.erb +64 -0
- data/lib/chef/resource/systemd_unit.rb +42 -1
- data/lib/chef/resource/template.rb +2 -2
- data/lib/chef/resource/windows_ad_join.rb +9 -9
- data/lib/chef/resource/windows_audit_policy.rb +26 -24
- data/lib/chef/resource/windows_certificate.rb +13 -7
- data/lib/chef/resource/windows_dfs_server.rb +7 -4
- data/lib/chef/resource/windows_env.rb +173 -0
- data/lib/chef/resource/windows_feature.rb +2 -0
- data/lib/chef/resource/windows_firewall_profile.rb +7 -12
- data/lib/chef/resource/windows_firewall_rule.rb +9 -11
- data/lib/chef/resource/windows_font.rb +1 -1
- data/lib/chef/resource/windows_package.rb +1 -0
- data/lib/chef/resource/windows_path.rb +38 -0
- data/lib/chef/resource/windows_security_policy.rb +5 -5
- data/lib/chef/resource/windows_service.rb +108 -0
- data/lib/chef/resource/windows_share.rb +18 -18
- data/lib/chef/resource/windows_task.rb +629 -28
- data/lib/chef/resource/windows_workgroup.rb +6 -4
- data/lib/chef/resource/yum_repository.rb +1 -1
- data/lib/chef/resource_collection/resource_set.rb +2 -6
- data/lib/chef/resource_inspector.rb +77 -75
- data/lib/chef/resource_reporter.rb +0 -2
- data/lib/chef/resources.rb +1 -0
- data/lib/chef/run_lock.rb +2 -2
- data/lib/chef/search/query.rb +3 -1
- data/lib/chef/server_api.rb +0 -4
- data/lib/chef/shell/ext.rb +1 -1
- data/lib/chef/util/backup.rb +1 -1
- data/lib/chef/util/dsc/configuration_generator.rb +52 -11
- data/lib/chef/util/dsc/lcm_output_parser.rb +4 -7
- data/lib/chef/util/dsc/local_configuration_manager.rb +18 -15
- data/lib/chef/util/dsc/resource_store.rb +5 -11
- data/lib/chef/version.rb +1 -1
- data/lib/chef/win32/api/file.rb +4 -0
- data/lib/chef/win32/file.rb +1 -1
- data/lib/chef/win32/security/sid.rb +1 -1
- data/lib/chef/win32/unicode.rb +1 -1
- data/spec/functional/mixin/powershell_out_spec.rb +11 -3
- data/spec/functional/resource/apt_package_spec.rb +4 -6
- data/spec/functional/resource/chocolatey_package_spec.rb +3 -3
- data/spec/functional/resource/cron_spec.rb +3 -3
- data/spec/functional/resource/dsc_script_spec.rb +6 -9
- data/spec/functional/resource/mount_spec.rb +10 -2
- data/spec/functional/resource/powershell_package_source_spec.rb +107 -0
- data/spec/functional/resource/powershell_script_spec.rb +57 -14
- data/spec/functional/resource/windows_certificate_spec.rb +10 -6
- data/spec/functional/resource/windows_firewall_rule_spec.rb +93 -0
- data/spec/functional/resource/windows_package_spec.rb +36 -10
- data/spec/functional/resource/windows_share_spec.rb +103 -0
- data/spec/functional/resource/windows_task_spec.rb +2 -3
- data/spec/functional/resource/zypper_package_spec.rb +11 -0
- data/spec/integration/client/client_spec.rb +2 -1
- data/spec/integration/compliance/compliance_spec.rb +81 -0
- data/spec/integration/knife/client_key_create_spec.rb +1 -1
- data/spec/integration/knife/node_create_spec.rb +1 -1
- data/spec/integration/knife/node_environment_set_spec.rb +1 -1
- data/spec/integration/knife/node_run_list_add_spec.rb +4 -4
- data/spec/integration/knife/node_run_list_remove_spec.rb +1 -1
- data/spec/integration/knife/node_run_list_set_spec.rb +1 -1
- data/spec/integration/knife/node_show_spec.rb +1 -1
- data/spec/integration/recipes/notifies_spec.rb +1 -1
- data/spec/integration/recipes/provider_choice.rb +2 -2
- data/spec/integration/recipes/recipe_dsl_spec.rb +1 -0
- data/spec/spec_helper.rb +3 -4
- data/spec/support/lib/chef/resource/cat.rb +1 -1
- data/spec/support/lib/chef/resource/one_two_three_four.rb +1 -1
- data/spec/support/mock/platform.rb +24 -16
- data/spec/support/platform_helpers.rb +11 -4
- data/spec/support/shared/unit/knife_shared.rb +1 -1
- data/spec/support/shared/unit/script_resource.rb +4 -4
- data/spec/support/shared/unit/windows_script_resource.rb +1 -1
- data/spec/unit/chef_fs/config_spec.rb +1 -1
- data/spec/unit/chef_fs/data_handler/data_bag_item_data_handler.rb +1 -1
- data/spec/unit/client_spec.rb +17 -0
- data/spec/unit/compliance/fetcher/automate_spec.rb +134 -0
- data/spec/unit/compliance/fetcher/chef_server_spec.rb +93 -0
- data/spec/unit/compliance/reporter/automate_spec.rb +427 -0
- data/spec/unit/compliance/reporter/chef_server_automate_spec.rb +177 -0
- data/spec/unit/compliance/reporter/compliance_enforcer_spec.rb +48 -0
- data/spec/unit/compliance/runner_spec.rb +140 -0
- data/spec/unit/data_collector_spec.rb +0 -4
- data/spec/unit/guard_interpreter/resource_guard_interpreter_spec.rb +11 -11
- data/spec/unit/http/ssl_policies_spec.rb +11 -0
- data/spec/unit/knife/client_create_spec.rb +2 -2
- data/spec/unit/knife/configure_client_spec.rb +5 -5
- data/spec/unit/knife/configure_spec.rb +3 -3
- data/spec/unit/knife/cookbook_delete_spec.rb +2 -2
- data/spec/unit/knife/cookbook_download_spec.rb +2 -2
- data/spec/unit/knife/cookbook_list_spec.rb +2 -2
- data/spec/unit/knife/cookbook_metadata_spec.rb +3 -3
- data/spec/unit/knife/core/node_editor_spec.rb +1 -1
- data/spec/unit/knife/environment_compare_spec.rb +3 -3
- data/spec/unit/knife/supermarket_download_spec.rb +8 -8
- data/spec/unit/knife/supermarket_list_spec.rb +3 -3
- data/spec/unit/knife/supermarket_search_spec.rb +1 -1
- data/spec/unit/knife/tag_create_spec.rb +1 -1
- data/spec/unit/knife/tag_delete_spec.rb +1 -1
- data/spec/unit/knife/user_create_spec.rb +1 -1
- data/spec/unit/mixin/powershell_exec_spec.rb +41 -4
- data/spec/unit/mixin/powershell_out_spec.rb +14 -0
- data/spec/unit/mixin/which.rb +1 -1
- data/spec/unit/platform/query_helpers_spec.rb +11 -12
- data/spec/unit/provider/dsc_resource_spec.rb +10 -27
- data/spec/unit/provider/dsc_script_spec.rb +1 -1
- data/spec/unit/provider/group/windows_spec.rb +6 -0
- data/spec/unit/provider/group_spec.rb +1 -1
- data/spec/unit/provider/mount/linux_spec.rb +10 -0
- data/spec/unit/provider/mount/mount_spec.rb +21 -10
- data/spec/unit/provider/mount/solaris_spec.rb +1 -1
- data/spec/unit/provider/mount/windows_spec.rb +1 -0
- data/spec/unit/provider/mount_spec.rb +31 -0
- data/spec/unit/provider/package/chocolatey_spec.rb +1 -2
- data/spec/unit/provider/package/powershell_spec.rb +87 -95
- data/spec/unit/provider/package/zypper_spec.rb +0 -25
- data/spec/unit/provider/package_spec.rb +2 -2
- data/spec/unit/provider/powershell_script_spec.rb +11 -0
- data/spec/unit/provider/subversion_spec.rb +0 -3
- data/spec/unit/provider/systemd_unit_spec.rb +1 -1
- data/spec/unit/provider/user_spec.rb +7 -1
- data/spec/unit/provider/windows_env_spec.rb +18 -34
- data/spec/unit/provider/windows_path_spec.rb +6 -11
- data/spec/unit/provider/windows_task_spec.rb +7 -6
- data/spec/unit/resource/breakpoint_spec.rb +1 -1
- data/spec/unit/resource/build_essential_spec.rb +0 -12
- data/spec/unit/resource/chef_client_config_spec.rb +137 -0
- data/spec/unit/resource/ifconfig_spec.rb +2 -10
- data/spec/unit/resource/mount_spec.rb +18 -5
- data/spec/unit/resource/powershell_package_source_spec.rb +20 -20
- data/spec/unit/resource/powershell_script_spec.rb +4 -74
- data/spec/unit/resource/service_spec.rb +2 -2
- data/spec/unit/resource/solaris_package_spec.rb +8 -10
- data/spec/unit/resource/windows_certificate_spec.rb +12 -0
- data/spec/unit/resource_inspector_spec.rb +3 -3
- data/spec/unit/shell_spec.rb +2 -2
- data/spec/unit/util/dsc/configuration_generator_spec.rb +79 -0
- data/spec/unit/util/dsc/local_configuration_manager_spec.rb +27 -35
- data/tasks/rspec.rb +1 -1
- metadata +47 -24
- data/lib/chef/monkey_patches/net_http.rb +0 -22
- data/lib/chef/provider/windows_env.rb +0 -210
- data/lib/chef/provider/windows_path.rb +0 -61
- data/lib/chef/provider/windows_task.rb +0 -631
- data/lib/chef/util/powershell/cmdlet.rb +0 -175
- data/lib/chef/util/powershell/cmdlet_result.rb +0 -61
- data/spec/functional/util/powershell/cmdlet_spec.rb +0 -111
- data/spec/support/mock/constant.rb +0 -52
- data/spec/unit/monkey_patches/uri_spec.rb +0 -34
- data/spec/unit/provider_resolver_spec.rb +0 -885
- data/spec/unit/resource/data/InstallHistory_with_CLT.plist +0 -92
- data/spec/unit/resource/data/InstallHistory_without_CLT.plist +0 -38
- data/spec/unit/util/powershell/cmdlet_spec.rb +0 -106
@@ -96,31 +96,6 @@ describe Chef::Provider::Package::Zypper do
|
|
96
96
|
provider.load_current_resource
|
97
97
|
end
|
98
98
|
|
99
|
-
it "should set the candidate version if zypper info has one (zypper version < 1.13.0)" do
|
100
|
-
status = double(stdout: "Version: 1.0\nInstalled: No\nStatus: out-of-date (version 0.9 installed)", exitstatus: 0)
|
101
|
-
|
102
|
-
allow(provider).to receive(:shell_out_compacted!).and_return(status)
|
103
|
-
provider.load_current_resource
|
104
|
-
expect(provider.candidate_version).to eql(["1.0"])
|
105
|
-
end
|
106
|
-
|
107
|
-
it "should set the candidate version if zypper info has one (zypper version >= 1.13.0)" do
|
108
|
-
status = double(stdout: "Version : 1.0 \nInstalled : No \nStatus : out-of-date (version 0.9 installed)", exitstatus: 0)
|
109
|
-
|
110
|
-
allow(provider).to receive(:shell_out_compacted!).and_return(status)
|
111
|
-
provider.load_current_resource
|
112
|
-
expect(provider.candidate_version).to eql(["1.0"])
|
113
|
-
end
|
114
|
-
|
115
|
-
it "should have differing current and candidate versions if zypper detects an upgrade" do
|
116
|
-
status = double(stdout: "Version : 1.0 \nInstalled : Yes \nStatus : out-of-date (version 0.9 installed)", exitstatus: 0)
|
117
|
-
|
118
|
-
allow(provider).to receive(:shell_out_compacted!).and_return(status)
|
119
|
-
provider.load_current_resource
|
120
|
-
expect(provider.get_current_versions).to eq(["0.9"])
|
121
|
-
expect(provider.get_candidate_versions).to eq(["1.0"])
|
122
|
-
end
|
123
|
-
|
124
99
|
it "should return the current resouce" do
|
125
100
|
expect(provider.load_current_resource).to eql(current_resource)
|
126
101
|
end
|
@@ -517,8 +517,8 @@ describe "Chef::Provider::Package - Multi" do
|
|
517
517
|
end
|
518
518
|
|
519
519
|
it "installs the specified version when some are out of date" do
|
520
|
-
current_resource.version(["1.0", "6.
|
521
|
-
new_resource.version(["1.0", "6.
|
520
|
+
current_resource.version(["1.0", "6.1"])
|
521
|
+
new_resource.version(["1.0", "6.2"])
|
522
522
|
provider.run_action(:install)
|
523
523
|
expect(new_resource).to be_updated
|
524
524
|
end
|
@@ -46,5 +46,16 @@ describe Chef::Provider::PowershellScript, "action_run" do
|
|
46
46
|
|
47
47
|
expect(provider.command).to eq(expected)
|
48
48
|
end
|
49
|
+
|
50
|
+
it "uses pwsh when given the pwsh interpreter" do
|
51
|
+
new_resource.interpreter = "pwsh"
|
52
|
+
provider.send(:script_file_path=, "C:\\Temp\\Script.ps1")
|
53
|
+
|
54
|
+
expected = <<~CMD.strip
|
55
|
+
"pwsh" -NoLogo -NonInteractive -NoProfile -ExecutionPolicy Bypass -InputFormat None -File "C:\\Temp\\Script.ps1"
|
56
|
+
CMD
|
57
|
+
|
58
|
+
expect(provider.command).to eq(expected)
|
59
|
+
end
|
49
60
|
end
|
50
61
|
end
|
@@ -271,9 +271,6 @@ describe Chef::Provider::Subversion do
|
|
271
271
|
end
|
272
272
|
|
273
273
|
context "selects the correct svn binary" do
|
274
|
-
before do
|
275
|
-
end
|
276
|
-
|
277
274
|
it "selects 'svn' as the binary by default" do
|
278
275
|
@resource.svn_binary nil
|
279
276
|
allow(ChefUtils).to receive(:windows?) { false }
|
@@ -259,6 +259,7 @@ describe Chef::Provider::User do
|
|
259
259
|
it "should call manage_user if the user exists and has mismatched properties" do
|
260
260
|
@provider.user_exists = true
|
261
261
|
allow(@provider).to receive(:compare_user).and_return(true)
|
262
|
+
allow(@provider).to receive(:change_desc).and_return([ ])
|
262
263
|
expect(@provider).to receive(:manage_user).and_return(true)
|
263
264
|
@provider.action_create
|
264
265
|
end
|
@@ -266,6 +267,7 @@ describe Chef::Provider::User do
|
|
266
267
|
it "should set the new_resources updated flag when it creates the user if we call manage_user" do
|
267
268
|
@provider.user_exists = true
|
268
269
|
allow(@provider).to receive(:compare_user).and_return(true)
|
270
|
+
allow(@provider).to receive(:change_desc).and_return([ ])
|
269
271
|
allow(@provider).to receive(:manage_user).and_return(true)
|
270
272
|
@provider.action_create
|
271
273
|
@provider.set_updated_status
|
@@ -315,14 +317,16 @@ describe Chef::Provider::User do
|
|
315
317
|
# @provider.stub(:manage_user).and_return(true)
|
316
318
|
end
|
317
319
|
|
318
|
-
it "should
|
320
|
+
it "should call manage_user if the user exists and has mismatched properties" do
|
319
321
|
expect(@provider).to receive(:compare_user).and_return(true)
|
322
|
+
allow(@provider).to receive(:change_desc).and_return([ ])
|
320
323
|
expect(@provider).to receive(:manage_user).and_return(true)
|
321
324
|
@provider.action_manage
|
322
325
|
end
|
323
326
|
|
324
327
|
it "should set the new resources updated flag to true if manage_user is called" do
|
325
328
|
allow(@provider).to receive(:compare_user).and_return(true)
|
329
|
+
allow(@provider).to receive(:change_desc).and_return([ ])
|
326
330
|
allow(@provider).to receive(:manage_user).and_return(true)
|
327
331
|
@provider.action_manage
|
328
332
|
@provider.set_updated_status
|
@@ -360,12 +364,14 @@ describe Chef::Provider::User do
|
|
360
364
|
|
361
365
|
it "should run manage_user if the user exists and has mismatched properties" do
|
362
366
|
expect(@provider).to receive(:compare_user).and_return(true)
|
367
|
+
allow(@provider).to receive(:change_desc).and_return([ ])
|
363
368
|
expect(@provider).to receive(:manage_user).and_return(true)
|
364
369
|
@provider.action_modify
|
365
370
|
end
|
366
371
|
|
367
372
|
it "should set the new resources updated flag to true if manage_user is called" do
|
368
373
|
allow(@provider).to receive(:compare_user).and_return(true)
|
374
|
+
allow(@provider).to receive(:change_desc).and_return([ ])
|
369
375
|
allow(@provider).to receive(:manage_user).and_return(true)
|
370
376
|
@provider.action_modify
|
371
377
|
@provider.set_updated_status
|
@@ -18,21 +18,17 @@
|
|
18
18
|
|
19
19
|
require "spec_helper"
|
20
20
|
|
21
|
-
describe
|
21
|
+
describe "windows_env provider", :windows_only do
|
22
22
|
|
23
23
|
let(:run_context) do
|
24
24
|
Chef::RunContext.new(Chef::Node.new, {}, Chef::EventDispatch::Dispatcher.new)
|
25
25
|
end
|
26
26
|
|
27
27
|
before do
|
28
|
-
@new_resource = Chef::Resource::WindowsEnv.new("FOO")
|
28
|
+
@new_resource = Chef::Resource::WindowsEnv.new("FOO", run_context)
|
29
29
|
@new_resource.value("bar")
|
30
30
|
@new_resource.user("<System>")
|
31
|
-
@provider =
|
32
|
-
end
|
33
|
-
|
34
|
-
it "assumes the key_name exists by default" do
|
35
|
-
expect(@provider.key_exists).to be_truthy
|
31
|
+
@provider = @new_resource.provider_for_action(:create)
|
36
32
|
end
|
37
33
|
|
38
34
|
describe "when loading the current status" do
|
@@ -41,7 +37,7 @@ describe Chef::Provider::WindowsEnv, :windows_only do
|
|
41
37
|
# Chef::Resource::Env.stub(:new).and_return(@current_resource)
|
42
38
|
@provider.current_resource = @current_resource
|
43
39
|
allow(@provider).to receive(:env_value).with("FOO").and_return("bar")
|
44
|
-
allow(@provider).to receive(:
|
40
|
+
allow(@provider).to receive(:key_exists?).and_return(true)
|
45
41
|
end
|
46
42
|
|
47
43
|
it "should create a current resource with the same name as the new resource" do
|
@@ -59,18 +55,6 @@ describe Chef::Provider::WindowsEnv, :windows_only do
|
|
59
55
|
expect(@provider.current_resource.key_name).to eq("FOO")
|
60
56
|
end
|
61
57
|
|
62
|
-
it "should check if the key_name and user exist" do
|
63
|
-
expect(@provider).to receive(:env_key_exists).with("FOO").and_return(true)
|
64
|
-
@provider.load_current_resource
|
65
|
-
expect(@provider.key_exists).to be_truthy
|
66
|
-
end
|
67
|
-
|
68
|
-
it "should flip the value of exists if the key does not exist" do
|
69
|
-
expect(@provider).to receive(:env_key_exists).with("FOO").and_return(false)
|
70
|
-
@provider.load_current_resource
|
71
|
-
expect(@provider.key_exists).to be_falsey
|
72
|
-
end
|
73
|
-
|
74
58
|
it "should return the current resource" do
|
75
59
|
expect(@provider.load_current_resource).to be_a_kind_of(Chef::Resource::WindowsEnv)
|
76
60
|
end
|
@@ -78,7 +62,7 @@ describe Chef::Provider::WindowsEnv, :windows_only do
|
|
78
62
|
|
79
63
|
describe "action_create" do
|
80
64
|
before do
|
81
|
-
@provider.key_exists
|
65
|
+
allow(@provider).to receive(:key_exists?).and_return(false)
|
82
66
|
allow(@provider).to receive(:create_env).and_return(true)
|
83
67
|
allow(@provider).to receive(:modify_env).and_return(true)
|
84
68
|
end
|
@@ -94,20 +78,20 @@ describe Chef::Provider::WindowsEnv, :windows_only do
|
|
94
78
|
end
|
95
79
|
|
96
80
|
it "should check to see if the values are the same if the key exists" do
|
97
|
-
@provider.key_exists
|
81
|
+
allow(@provider).to receive(:key_exists?).and_return(true)
|
98
82
|
expect(@provider).to receive(:requires_modify_or_create?).and_return(false)
|
99
83
|
@provider.action_create
|
100
84
|
end
|
101
85
|
|
102
86
|
it "should call modify_env if the key exists with provided user and values are not equal" do
|
103
|
-
@provider.key_exists
|
87
|
+
allow(@provider).to receive(:key_exists?).and_return(true)
|
104
88
|
allow(@provider).to receive(:requires_modify_or_create?).and_return(true)
|
105
89
|
expect(@provider).to receive(:modify_env).and_return(true)
|
106
90
|
@provider.action_create
|
107
91
|
end
|
108
92
|
|
109
93
|
it "should set the new_resources updated flag when it updates an existing value" do
|
110
|
-
@provider.key_exists
|
94
|
+
allow(@provider).to receive(:key_exists?).and_return(true)
|
111
95
|
allow(@provider).to receive(:requires_modify_or_create?).and_return(true)
|
112
96
|
allow(@provider).to receive(:modify_env).and_return(true)
|
113
97
|
@provider.action_create
|
@@ -118,7 +102,7 @@ describe Chef::Provider::WindowsEnv, :windows_only do
|
|
118
102
|
describe "action_delete" do
|
119
103
|
before(:each) do
|
120
104
|
@provider.current_resource = @current_resource
|
121
|
-
@provider.key_exists
|
105
|
+
allow(@provider).to receive(:key_exists?).and_return(false)
|
122
106
|
allow(@provider).to receive(:delete_element).and_return(false)
|
123
107
|
allow(@provider).to receive(:delete_env).and_return(true)
|
124
108
|
end
|
@@ -134,13 +118,13 @@ describe Chef::Provider::WindowsEnv, :windows_only do
|
|
134
118
|
end
|
135
119
|
|
136
120
|
it "should call delete_env if the key exists" do
|
137
|
-
@provider.key_exists
|
121
|
+
allow(@provider).to receive(:key_exists?).and_return(true)
|
138
122
|
expect(@provider).to receive(:delete_env)
|
139
123
|
@provider.action_delete
|
140
124
|
end
|
141
125
|
|
142
126
|
it "should set the new_resources updated flag to true if the key is deleted" do
|
143
|
-
@provider.key_exists
|
127
|
+
allow(@provider).to receive(:key_exists?).and_return(true)
|
144
128
|
@provider.action_delete
|
145
129
|
expect(@new_resource).to be_updated
|
146
130
|
end
|
@@ -149,7 +133,7 @@ describe Chef::Provider::WindowsEnv, :windows_only do
|
|
149
133
|
describe "action_modify" do
|
150
134
|
before(:each) do
|
151
135
|
@provider.current_resource = @current_resource
|
152
|
-
@provider.key_exists
|
136
|
+
allow(@provider).to receive(:key_exists?).and_return(true)
|
153
137
|
allow(@provider).to receive(:modify_env).and_return(true)
|
154
138
|
end
|
155
139
|
|
@@ -179,7 +163,7 @@ describe Chef::Provider::WindowsEnv, :windows_only do
|
|
179
163
|
end
|
180
164
|
|
181
165
|
it "should raise a Chef::Exceptions::WindowsEnv if the key doesn't exist" do
|
182
|
-
@provider.key_exists
|
166
|
+
allow(@provider).to receive(:key_exists?).and_return(false)
|
183
167
|
expect { @provider.action_modify }.to raise_error(Chef::Exceptions::WindowsEnv)
|
184
168
|
end
|
185
169
|
end
|
@@ -324,12 +308,12 @@ describe Chef::Provider::WindowsEnv, :windows_only do
|
|
324
308
|
|
325
309
|
context "when environment variable is not PATH" do
|
326
310
|
let(:new_resource) do
|
327
|
-
new_resource = Chef::Resource::WindowsEnv.new("CHEF_WINDOWS_ENV_TEST")
|
311
|
+
new_resource = Chef::Resource::WindowsEnv.new("CHEF_WINDOWS_ENV_TEST", run_context)
|
328
312
|
new_resource.value("foo")
|
329
313
|
new_resource
|
330
314
|
end
|
331
315
|
let(:provider) do
|
332
|
-
provider =
|
316
|
+
provider = new_resource.provider_for_action(:create)
|
333
317
|
allow(provider).to receive(:env_obj).and_return(double("null object").as_null_object)
|
334
318
|
provider
|
335
319
|
end
|
@@ -337,7 +321,7 @@ describe Chef::Provider::WindowsEnv, :windows_only do
|
|
337
321
|
describe "action_create" do
|
338
322
|
before do
|
339
323
|
ENV.delete("CHEF_WINDOWS_ENV_TEST")
|
340
|
-
provider.key_exists
|
324
|
+
allow(provider).to receive(:key_exists?).and_return(false)
|
341
325
|
end
|
342
326
|
|
343
327
|
it "should update the ruby ENV object when it creates the key" do
|
@@ -376,12 +360,12 @@ describe Chef::Provider::WindowsEnv, :windows_only do
|
|
376
360
|
let(:system_root) { "%SystemRoot%" }
|
377
361
|
let(:system_root_value) { 'D:\Windows' }
|
378
362
|
let(:new_resource) do
|
379
|
-
new_resource = Chef::Resource::WindowsEnv.new("PATH")
|
363
|
+
new_resource = Chef::Resource::WindowsEnv.new("PATH", run_context)
|
380
364
|
new_resource.value(system_root)
|
381
365
|
new_resource
|
382
366
|
end
|
383
367
|
let(:provider) do
|
384
|
-
provider =
|
368
|
+
provider = new_resource.provider_for_action(:create)
|
385
369
|
allow(provider).to receive(:env_obj).and_return(double("null object").as_null_object)
|
386
370
|
provider
|
387
371
|
end
|
@@ -18,7 +18,7 @@
|
|
18
18
|
|
19
19
|
require "spec_helper"
|
20
20
|
|
21
|
-
describe
|
21
|
+
describe "windows_path provider", :windows_only do
|
22
22
|
before(:all) do
|
23
23
|
@old_path = ENV["PATH"].dup
|
24
24
|
end
|
@@ -27,14 +27,9 @@ describe Chef::Provider::WindowsPath, :windows_only do
|
|
27
27
|
ENV["PATH"] = @old_path
|
28
28
|
end
|
29
29
|
|
30
|
-
let(:
|
31
|
-
|
32
|
-
let(:provider)
|
33
|
-
node = Chef::Node.new
|
34
|
-
events = Chef::EventDispatch::Dispatcher.new
|
35
|
-
run_context = Chef::RunContext.new(node, {}, events)
|
36
|
-
Chef::Provider::WindowsPath.new(new_resource, run_context)
|
37
|
-
end
|
30
|
+
let(:run_context) { Chef::RunContext.new(Chef::Node.new, {}, Chef::EventDispatch::Dispatcher.new) }
|
31
|
+
let(:new_resource) { Chef::Resource::WindowsPath.new("some_path", run_context) }
|
32
|
+
let(:provider) { new_resource.provider_for_action(:add) }
|
38
33
|
|
39
34
|
describe "#load_current_resource" do
|
40
35
|
it "returns a current_resource" do
|
@@ -50,7 +45,7 @@ describe Chef::Provider::WindowsPath, :windows_only do
|
|
50
45
|
describe "#action_add" do
|
51
46
|
it "uses env resource to add 'path' environment variable" do
|
52
47
|
allow(provider).to receive(:expand_env_vars)
|
53
|
-
expect(provider).to receive(:declare_resource).with(:env, "path")
|
48
|
+
expect(provider).to receive(:declare_resource).with(:env, "path", hash_including)
|
54
49
|
provider.run_action(:add)
|
55
50
|
end
|
56
51
|
end
|
@@ -58,7 +53,7 @@ describe Chef::Provider::WindowsPath, :windows_only do
|
|
58
53
|
describe "#action_remove" do
|
59
54
|
it "uses env resource to remove 'path' environment variable" do
|
60
55
|
allow(provider).to receive(:expand_env_vars)
|
61
|
-
expect(provider).to receive(:declare_resource).with(:env, "path")
|
56
|
+
expect(provider).to receive(:declare_resource).with(:env, "path", hash_including)
|
62
57
|
provider.run_action(:remove)
|
63
58
|
end
|
64
59
|
end
|
@@ -18,15 +18,16 @@
|
|
18
18
|
|
19
19
|
require "spec_helper"
|
20
20
|
|
21
|
-
describe
|
22
|
-
let(:new_resource) { Chef::Resource::WindowsTask.new("sample_task") }
|
21
|
+
describe "windows_task provider", :windows_only do
|
22
|
+
let(:new_resource) { Chef::Resource::WindowsTask.new("sample_task", run_context) }
|
23
23
|
let(:current_resource) { Chef::Resource::WindowsTask.new }
|
24
24
|
|
25
|
+
let(:run_context) do
|
26
|
+
Chef::RunContext.new(Chef::Node.new, {}, Chef::EventDispatch::Dispatcher.new)
|
27
|
+
end
|
28
|
+
|
25
29
|
let(:provider) do
|
26
|
-
|
27
|
-
events = Chef::EventDispatch::Dispatcher.new
|
28
|
-
run_context = Chef::RunContext.new(node, {}, events)
|
29
|
-
Chef::Provider::WindowsTask.new(new_resource, run_context)
|
30
|
+
new_resource.provider_for_action(:create)
|
30
31
|
end
|
31
32
|
|
32
33
|
describe "#load_current_resource" do
|
@@ -58,7 +58,7 @@ describe Chef::Resource::Breakpoint do
|
|
58
58
|
|
59
59
|
it "names itself after the line number of the file where it's created" do
|
60
60
|
resource = Chef::Resource::Breakpoint.new
|
61
|
-
expect(resource.name).to match(/breakpoint_spec\.rb
|
61
|
+
expect(resource.name).to match(/breakpoint_spec\.rb\:\d{2}\:in \`new\'$/)
|
62
62
|
end
|
63
63
|
|
64
64
|
end
|
@@ -57,18 +57,6 @@ describe Chef::Resource::BuildEssential do
|
|
57
57
|
end
|
58
58
|
end
|
59
59
|
|
60
|
-
describe "#xcode_cli_installed?" do
|
61
|
-
it "returns true if the CLI is in the InstallHistory plist" do
|
62
|
-
allow(::File).to receive(:open).with("/Library/Receipts/InstallHistory.plist", "r").and_return(::File.join(::File.dirname(__FILE__), "data/InstallHistory_with_CLT.plist"))
|
63
|
-
expect(provider.xcode_cli_installed?).to eql(true)
|
64
|
-
end
|
65
|
-
|
66
|
-
it "returns false if the pkgutil doesn't list the package" do
|
67
|
-
allow(::File).to receive(:open).with("/Library/Receipts/InstallHistory.plist", "r").and_return(::File.join(::File.dirname(__FILE__), "data/InstallHistory_without_CLT.plist"))
|
68
|
-
expect(provider.xcode_cli_installed?).to eql(false)
|
69
|
-
end
|
70
|
-
end
|
71
|
-
|
72
60
|
describe "#xcode_cli_package_label" do
|
73
61
|
it "returns a package name on macOS < 10.15" do
|
74
62
|
allow(provider).to receive(:shell_out).with("softwareupdate", "--list").and_return(softwareupdate_pre_catalina)
|
@@ -0,0 +1,137 @@
|
|
1
|
+
#
|
2
|
+
# Author:: Tim Smith (<tsmith@chef.io>)
|
3
|
+
# Copyright:: Copyright (c) Chef Software Inc.
|
4
|
+
# License:: Apache License, Version 2.0
|
5
|
+
#
|
6
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
7
|
+
# you may not use this file except in compliance with the License.
|
8
|
+
# You may obtain a copy of the License at
|
9
|
+
#
|
10
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
11
|
+
#
|
12
|
+
# Unless required by applicable law or agreed to in writing, software
|
13
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
14
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
15
|
+
# See the License for the specific language governing permissions and
|
16
|
+
# limitations under the License.
|
17
|
+
#
|
18
|
+
|
19
|
+
require "spec_helper"
|
20
|
+
|
21
|
+
describe Chef::Resource::ChefClientConfig do
|
22
|
+
let(:node) { Chef::Node.new }
|
23
|
+
let(:events) { Chef::EventDispatch::Dispatcher.new }
|
24
|
+
let(:run_context) { Chef::RunContext.new(node, {}, events) }
|
25
|
+
let(:resource) { Chef::Resource::ChefClientConfig.new("fakey_fakerton", run_context) }
|
26
|
+
let(:provider) { resource.provider_for_action(:create) }
|
27
|
+
|
28
|
+
it "sets the default action as :create" do
|
29
|
+
expect(resource.action).to eql([:create])
|
30
|
+
end
|
31
|
+
|
32
|
+
it "supports :create and :remove actions" do
|
33
|
+
expect { resource.action :create }.not_to raise_error
|
34
|
+
expect { resource.action :remove }.not_to raise_error
|
35
|
+
end
|
36
|
+
|
37
|
+
describe "ssl_verify_mode property" do
|
38
|
+
it "coerces String to Symbol" do
|
39
|
+
resource.ssl_verify_mode "verify_peer"
|
40
|
+
expect(resource.ssl_verify_mode).to eql(:verify_peer)
|
41
|
+
end
|
42
|
+
|
43
|
+
it "coerces Symbol-like String to Symbol" do
|
44
|
+
resource.ssl_verify_mode ":verify_peer"
|
45
|
+
expect(resource.ssl_verify_mode).to eql(:verify_peer)
|
46
|
+
end
|
47
|
+
|
48
|
+
it "raises an error if it is not an allowed value" do
|
49
|
+
expect { resource.ssl_verify_mode("foo") }.to raise_error(Chef::Exceptions::ValidationFailed)
|
50
|
+
expect { resource.ssl_verify_mode(:verify_none) }.not_to raise_error
|
51
|
+
expect { resource.ssl_verify_mode(:verify_peer) }.not_to raise_error
|
52
|
+
end
|
53
|
+
end
|
54
|
+
|
55
|
+
describe "no_proxy property" do
|
56
|
+
it "coerces Array into comma separated list" do
|
57
|
+
resource.no_proxy ["something.com", "example.com"]
|
58
|
+
expect(resource.no_proxy).to eql("something.com,example.com")
|
59
|
+
end
|
60
|
+
|
61
|
+
it "accepts String of comma separated values" do
|
62
|
+
resource.no_proxy "something.com,example.com"
|
63
|
+
expect(resource.no_proxy).to eql("something.com,example.com")
|
64
|
+
end
|
65
|
+
end
|
66
|
+
|
67
|
+
describe "ohai_disabled_plugins property" do
|
68
|
+
it "coerces String values into capitalized symbols" do
|
69
|
+
resource.ohai_disabled_plugins %w{foo Bar}
|
70
|
+
expect(resource.ohai_disabled_plugins).to eql(%i{Foo Bar})
|
71
|
+
end
|
72
|
+
|
73
|
+
it "coerces symbol-like string values into capitalized Symbols" do
|
74
|
+
resource.ohai_disabled_plugins [":foo", ":Bar"]
|
75
|
+
expect(resource.ohai_disabled_plugins).to eql(%i{Foo Bar})
|
76
|
+
end
|
77
|
+
|
78
|
+
it "coerces Symbol values into capitalized Symbols" do
|
79
|
+
resource.ohai_disabled_plugins %i{foo Bar}
|
80
|
+
expect(resource.ohai_disabled_plugins).to eql(%i{Foo Bar})
|
81
|
+
end
|
82
|
+
end
|
83
|
+
|
84
|
+
describe "ohai_optional_plugins property" do
|
85
|
+
it "coerces String values into capitalized symbols" do
|
86
|
+
resource.ohai_optional_plugins %w{foo Bar}
|
87
|
+
expect(resource.ohai_optional_plugins).to eql(%i{Foo Bar})
|
88
|
+
end
|
89
|
+
|
90
|
+
it "coerces symbol-like string values into capitalized Symbols" do
|
91
|
+
resource.ohai_optional_plugins [":foo", ":Bar"]
|
92
|
+
expect(resource.ohai_optional_plugins).to eql(%i{Foo Bar})
|
93
|
+
end
|
94
|
+
|
95
|
+
it "coerces Symbol values into capitalized Symbols" do
|
96
|
+
resource.ohai_optional_plugins %i{foo Bar}
|
97
|
+
expect(resource.ohai_optional_plugins).to eql(%i{Foo Bar})
|
98
|
+
end
|
99
|
+
end
|
100
|
+
|
101
|
+
describe "log_level property" do
|
102
|
+
it "accepts auto trace debug info warn fatal" do
|
103
|
+
expect { resource.log_level(:auto) }.not_to raise_error
|
104
|
+
expect { resource.log_level(:trace) }.not_to raise_error
|
105
|
+
expect { resource.log_level(:debug) }.not_to raise_error
|
106
|
+
expect { resource.log_level(:info) }.not_to raise_error
|
107
|
+
expect { resource.log_level(:warn) }.not_to raise_error
|
108
|
+
end
|
109
|
+
|
110
|
+
it "raises an error if an invalid value is passed" do
|
111
|
+
expect { resource.log_level(":foo") }.to raise_error(Chef::Exceptions::ValidationFailed)
|
112
|
+
end
|
113
|
+
end
|
114
|
+
|
115
|
+
describe "log_location property" do
|
116
|
+
it "accepts a String logfile location" do
|
117
|
+
expect { resource.log_location("/foo/bar/") }.not_to raise_error
|
118
|
+
end
|
119
|
+
|
120
|
+
it "accepts a String form of STDOUT/STDERR" do
|
121
|
+
expect { resource.log_location("STDOUT") }.not_to raise_error
|
122
|
+
expect { resource.log_location("STDERR") }.not_to raise_error
|
123
|
+
end
|
124
|
+
|
125
|
+
it "accepts :syslog or :win_evt Symbols" do
|
126
|
+
expect { resource.log_location(:syslog) }.not_to raise_error
|
127
|
+
expect { resource.log_location(:win_evt) }.not_to raise_error
|
128
|
+
expect { resource.log_location(:nope) }.to raise_error(Chef::Exceptions::ValidationFailed)
|
129
|
+
end
|
130
|
+
end
|
131
|
+
|
132
|
+
describe "#format_handler" do
|
133
|
+
it "provides an array of handler object creation code" do
|
134
|
+
expect(provider.format_handler([{ "class" => "Foo", "arguments" => ["'one'", "two", "three"] }])).to eql(["Foo.new('one',two,three)"])
|
135
|
+
end
|
136
|
+
end
|
137
|
+
end
|