chef 11.14.0.alpha.2-x86-mingw32 → 11.14.0.alpha.3-x86-mingw32
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/bin/chef-service-manager +1 -1
- data/lib/chef/application.rb +8 -2
- data/lib/chef/chef_fs/command_line.rb +4 -4
- data/lib/chef/chef_fs/file_system.rb +3 -3
- data/lib/chef/chef_fs/parallelizer.rb +66 -90
- data/lib/chef/chef_fs/parallelizer/flatten_enumerable.rb +35 -0
- data/lib/chef/chef_fs/parallelizer/parallel_enumerable.rb +279 -0
- data/lib/chef/config.rb +36 -2
- data/lib/chef/cookbook/cookbook_version_loader.rb +0 -1
- data/lib/chef/cookbook/synchronizer.rb +64 -42
- data/lib/chef/cookbook_uploader.rb +4 -25
- data/lib/chef/cookbook_version.rb +12 -11
- data/lib/chef/formatters/error_inspectors/api_error_formatting.rb +18 -1
- data/lib/chef/formatters/error_inspectors/cookbook_sync_error_inspector.rb +1 -3
- data/lib/chef/knife/bootstrap.rb +23 -1
- data/lib/chef/knife/bootstrap/chef-aix.erb +58 -0
- data/lib/chef/knife/bootstrap/chef-full.erb +16 -13
- data/lib/chef/knife/core/bootstrap_context.rb +25 -1
- data/lib/chef/knife/list.rb +9 -8
- data/lib/chef/knife/serve.rb +44 -0
- data/lib/chef/knife/show.rb +2 -3
- data/lib/chef/knife/ssh.rb +1 -0
- data/lib/chef/mixin/create_path.rb +20 -4
- data/lib/chef/node.rb +19 -3
- data/lib/chef/platform/provider_mapping.rb +0 -1
- data/lib/chef/platform/query_helpers.rb +4 -3
- data/lib/chef/provider/env/windows.rb +10 -3
- data/lib/chef/provider/file.rb +1 -1
- data/lib/chef/provider/mount.rb +84 -42
- data/lib/chef/provider/package/freebsd/base.rb +92 -0
- data/lib/chef/provider/package/freebsd/pkg.rb +113 -0
- data/lib/chef/provider/package/freebsd/pkgng.rb +80 -0
- data/lib/chef/provider/package/freebsd/port.rb +70 -0
- data/lib/chef/providers.rb +3 -1
- data/lib/chef/resource/chef_gem.rb +2 -1
- data/lib/chef/resource/freebsd_package.rb +39 -3
- data/lib/chef/resource/lwrp_base.rb +2 -2
- data/lib/chef/resource/mount.rb +9 -9
- data/lib/chef/util/threaded_job_queue.rb +61 -0
- data/lib/chef/version.rb +1 -1
- data/lib/chef/version/platform.rb +2 -0
- data/lib/chef/whitelist.rb +82 -0
- data/lib/chef/win32/registry.rb +0 -1
- data/lib/chef/win32/version.rb +4 -3
- data/spec/functional/win32/versions_spec.rb +4 -4
- data/spec/integration/client/ipv6_spec.rb +1 -1
- data/spec/integration/knife/chef_fs_data_store_spec.rb +1 -1
- data/spec/integration/knife/chef_repo_path_spec.rb +4 -1
- data/spec/integration/knife/common_options_spec.rb +9 -9
- data/spec/integration/knife/cookbook_api_ipv6_spec.rb +2 -2
- data/spec/integration/knife/deps_spec.rb +3 -0
- data/spec/integration/knife/list_spec.rb +3 -0
- data/spec/integration/knife/raw_spec.rb +5 -2
- data/spec/integration/knife/redirection_spec.rb +4 -1
- data/spec/integration/knife/serve_spec.rb +57 -0
- data/spec/integration/knife/show_spec.rb +3 -0
- data/spec/support/pedant/run_pedant.rb +1 -0
- data/spec/support/platform_helpers.rb +7 -5
- data/spec/support/shared/context/config.rb +21 -0
- data/spec/support/shared/functional/file_resource.rb +52 -0
- data/spec/unit/chef_fs/parallelizer.rb +482 -0
- data/spec/unit/client_spec.rb +4 -2
- data/spec/unit/config_spec.rb +66 -12
- data/spec/unit/knife/bootstrap_spec.rb +6 -0
- data/spec/unit/knife/core/bootstrap_context_spec.rb +31 -1
- data/spec/unit/node_spec.rb +73 -3
- data/spec/unit/provider/mount_spec.rb +102 -79
- data/spec/unit/provider/package/{freebsd_spec.rb → freebsd/pkg_spec.rb} +19 -32
- data/spec/unit/provider/package/freebsd/pkgng_spec.rb +155 -0
- data/spec/unit/provider/package/freebsd/port_spec.rb +160 -0
- data/spec/unit/resource/chef_gem_spec.rb +5 -0
- data/spec/unit/resource/freebsd_package_spec.rb +63 -11
- data/spec/unit/resource/mount_spec.rb +11 -0
- data/spec/unit/role_spec.rb +5 -1
- data/spec/unit/run_lock_spec.rb +2 -0
- data/spec/unit/util/threaded_job_queue_spec.rb +51 -0
- data/spec/unit/version/platform_spec.rb +1 -1
- metadata +176 -161
- data/lib/chef/provider/package/freebsd.rb +0 -149
@@ -37,14 +37,14 @@ class Chef
|
|
37
37
|
def self.build_from_file(cookbook_name, filename, run_context)
|
38
38
|
rname = filename_to_qualified_string(cookbook_name, filename)
|
39
39
|
|
40
|
-
# Add log entry if we override an existing
|
40
|
+
# Add log entry if we override an existing lightweight resource.
|
41
41
|
class_name = convert_to_class_name(rname)
|
42
42
|
if Resource.strict_const_defined?(class_name)
|
43
43
|
old_class = Resource.send(:remove_const, class_name)
|
44
44
|
# CHEF-3432 -- Chef::Resource keeps a list of subclasses; need to
|
45
45
|
# remove old ones from the list when replacing.
|
46
46
|
resource_classes.delete(old_class)
|
47
|
-
Chef::Log.info("#{class_name}
|
47
|
+
Chef::Log.info("#{class_name} lightweight resource already initialized -- overriding!")
|
48
48
|
end
|
49
49
|
|
50
50
|
resource_class = Class.new(self)
|
data/lib/chef/resource/mount.rb
CHANGED
@@ -81,16 +81,17 @@ class Chef
|
|
81
81
|
end
|
82
82
|
|
83
83
|
def options(arg=nil)
|
84
|
-
|
85
|
-
|
84
|
+
ret = set_or_return(
|
85
|
+
:options,
|
86
|
+
arg,
|
87
|
+
:kind_of => [ Array, String ]
|
88
|
+
)
|
89
|
+
|
90
|
+
if ret.is_a? String
|
91
|
+
ret.gsub(/,/, ' ').split(/ /)
|
86
92
|
else
|
87
|
-
|
93
|
+
ret
|
88
94
|
end
|
89
|
-
set_or_return(
|
90
|
-
:options,
|
91
|
-
converted_arg,
|
92
|
-
:kind_of => [ Array ]
|
93
|
-
)
|
94
95
|
end
|
95
96
|
|
96
97
|
def dump(arg=nil)
|
@@ -162,4 +163,3 @@ class Chef
|
|
162
163
|
end
|
163
164
|
end
|
164
165
|
end
|
165
|
-
|
@@ -0,0 +1,61 @@
|
|
1
|
+
# Copyright:: Copyright (c) 2014 Opscode, Inc.
|
2
|
+
# License:: Apache License, Version 2.0
|
3
|
+
#
|
4
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
5
|
+
# you may not use this file except in compliance with the License.
|
6
|
+
# You may obtain a copy of the License at
|
7
|
+
#
|
8
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
9
|
+
#
|
10
|
+
# Unless required by applicable law or agreed to in writing, software
|
11
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
12
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
13
|
+
# See the License for the specific language governing permissions and
|
14
|
+
# limitations under the License.
|
15
|
+
|
16
|
+
require 'thread'
|
17
|
+
|
18
|
+
class Chef
|
19
|
+
class Util
|
20
|
+
# A simple threaded job queue
|
21
|
+
#
|
22
|
+
# Create a queue:
|
23
|
+
#
|
24
|
+
# queue = ThreadedJobQueue.new
|
25
|
+
#
|
26
|
+
# Add jobs:
|
27
|
+
#
|
28
|
+
# queue << lambda { |lock| foo.the_bar }
|
29
|
+
#
|
30
|
+
# A job is a callable that optionally takes a Mutex instance as its only
|
31
|
+
# parameter.
|
32
|
+
#
|
33
|
+
# Then start processing jobs with +n+ threads:
|
34
|
+
#
|
35
|
+
# queue.process(n)
|
36
|
+
#
|
37
|
+
class ThreadedJobQueue
|
38
|
+
def initialize
|
39
|
+
@queue = Queue.new
|
40
|
+
@lock = Mutex.new
|
41
|
+
end
|
42
|
+
|
43
|
+
def <<(job)
|
44
|
+
@queue << job
|
45
|
+
end
|
46
|
+
|
47
|
+
def process(concurrency = 10)
|
48
|
+
workers = (1..concurrency).map do
|
49
|
+
Thread.new do
|
50
|
+
loop do
|
51
|
+
fn = @queue.pop
|
52
|
+
fn.arity == 1 ? fn.call(@lock) : fn.call
|
53
|
+
end
|
54
|
+
end
|
55
|
+
end
|
56
|
+
workers.each { |worker| self << Thread.method(:exit) }
|
57
|
+
workers.each { |worker| worker.join }
|
58
|
+
end
|
59
|
+
end
|
60
|
+
end
|
61
|
+
end
|
data/lib/chef/version.rb
CHANGED
@@ -31,6 +31,8 @@ class Chef
|
|
31
31
|
[ $1.to_i, $2.to_i, 0 ]
|
32
32
|
when /^(\d+)$/
|
33
33
|
[ $1.to_i, 0, 0 ]
|
34
|
+
when /^(\d+).(\d+)-[a-z]+\d?(-p(\d+))?$/i # Match FreeBSD
|
35
|
+
[ $1.to_i, $2.to_i, ($4 ? $4.to_i : 0)]
|
34
36
|
else
|
35
37
|
msg = "'#{str.to_s}' does not match 'x.y.z', 'x.y' or 'x'"
|
36
38
|
raise Chef::Exceptions::InvalidPlatformVersion.new( msg )
|
@@ -0,0 +1,82 @@
|
|
1
|
+
|
2
|
+
require 'chef/exceptions'
|
3
|
+
|
4
|
+
class Chef
|
5
|
+
class Whitelist
|
6
|
+
|
7
|
+
# filter takes two arguments - the data you want to filter, and a whitelisted array
|
8
|
+
# of keys you want included. You can capture a subtree of the data to filter by
|
9
|
+
# providing a "/"-delimited string of keys. If some key includes "/"-characters,
|
10
|
+
# you must provide an array of keys instead.
|
11
|
+
#
|
12
|
+
# Whitelist.filter(
|
13
|
+
# { "filesystem" => {
|
14
|
+
# "/dev/disk" => {
|
15
|
+
# "size" => "10mb"
|
16
|
+
# },
|
17
|
+
# "map - autohome" => {
|
18
|
+
# "size" => "10mb"
|
19
|
+
# }
|
20
|
+
# },
|
21
|
+
# "network" => {
|
22
|
+
# "interfaces" => {
|
23
|
+
# "eth0" => {...},
|
24
|
+
# "eth1" => {...}
|
25
|
+
# }
|
26
|
+
# }
|
27
|
+
# },
|
28
|
+
# ["network/interfaces/eth0", ["filesystem", "/dev/disk"]])
|
29
|
+
# will capture the eth0 and /dev/disk subtrees.
|
30
|
+
def self.filter(data, whitelist=nil)
|
31
|
+
return data if whitelist.nil?
|
32
|
+
|
33
|
+
new_data = {}
|
34
|
+
whitelist.each do |item|
|
35
|
+
self.add_data(data, new_data, item)
|
36
|
+
end
|
37
|
+
new_data
|
38
|
+
end
|
39
|
+
|
40
|
+
private
|
41
|
+
|
42
|
+
# Walk the data has according to the keys provided by the whitelisted item
|
43
|
+
# and add the data to the whitelisting result.
|
44
|
+
def self.add_data(data, new_data, item)
|
45
|
+
parts = self.to_array(item)
|
46
|
+
|
47
|
+
all_data = data
|
48
|
+
filtered_data = new_data
|
49
|
+
parts[0..-2].each do |part|
|
50
|
+
unless all_data[part]
|
51
|
+
Chef::Log.warn("Could not find whitelist attribute #{item}.")
|
52
|
+
return nil
|
53
|
+
end
|
54
|
+
|
55
|
+
filtered_data[part] ||= {}
|
56
|
+
filtered_data = filtered_data[part]
|
57
|
+
all_data = all_data[part]
|
58
|
+
end
|
59
|
+
|
60
|
+
unless all_data[parts[-1]]
|
61
|
+
Chef::Log.warn("Could not find whitelist attribute #{item}.")
|
62
|
+
return nil
|
63
|
+
end
|
64
|
+
|
65
|
+
filtered_data[parts[-1]] = all_data[parts[-1]]
|
66
|
+
new_data
|
67
|
+
end
|
68
|
+
|
69
|
+
# Accepts a String or an Array, and returns an Array of String keys that
|
70
|
+
# are used to traverse the data hash. Strings are split on "/", Arrays are
|
71
|
+
# assumed to contain exact keys (that is, Array elements will not be split
|
72
|
+
# by "/").
|
73
|
+
def self.to_array(item)
|
74
|
+
return item if item.kind_of? Array
|
75
|
+
|
76
|
+
parts = item.split("/")
|
77
|
+
parts.shift if !parts.empty? && parts[0].empty?
|
78
|
+
parts
|
79
|
+
end
|
80
|
+
|
81
|
+
end
|
82
|
+
end
|
data/lib/chef/win32/registry.rb
CHANGED
data/lib/chef/win32/version.rb
CHANGED
@@ -18,6 +18,7 @@
|
|
18
18
|
|
19
19
|
require 'chef/win32/api'
|
20
20
|
require 'chef/win32/api/system'
|
21
|
+
require 'wmi-lite/wmi'
|
21
22
|
|
22
23
|
class Chef
|
23
24
|
module ReservedNames::Win32
|
@@ -114,7 +115,6 @@ class Chef
|
|
114
115
|
# version numbers on Windows Server 2012 R2 and Windows 8.1 --
|
115
116
|
# WMI always returns the truth. See article at
|
116
117
|
# http://msdn.microsoft.com/en-us/library/windows/desktop/ms724439(v=vs.85).aspx
|
117
|
-
require 'ruby-wmi'
|
118
118
|
|
119
119
|
# CHEF-4888: Work around ruby #2618, expected to be fixed in Ruby 2.1.0
|
120
120
|
# https://github.com/ruby/ruby/commit/588504b20f5cc880ad51827b93e571e32446e5db
|
@@ -122,8 +122,9 @@ class Chef
|
|
122
122
|
|
123
123
|
WIN32OLE.ole_initialize
|
124
124
|
|
125
|
-
|
126
|
-
|
125
|
+
wmi = WmiLite::Wmi.new
|
126
|
+
os_info = wmi.first_of('Win32_OperatingSystem')
|
127
|
+
os_version = os_info['version']
|
127
128
|
|
128
129
|
WIN32OLE.ole_uninitialize
|
129
130
|
|
@@ -19,13 +19,13 @@
|
|
19
19
|
require 'spec_helper'
|
20
20
|
if Chef::Platform.windows?
|
21
21
|
require 'chef/win32/version'
|
22
|
-
require 'ruby-wmi'
|
23
22
|
end
|
24
23
|
|
25
24
|
describe "Chef::ReservedNames::Win32::Version", :windows_only, :not_supported_on_win2k3 do
|
26
25
|
before do
|
27
26
|
|
28
|
-
|
27
|
+
wmi = WmiLite::Wmi.new
|
28
|
+
host = wmi.first_of('Win32_OperatingSystem')
|
29
29
|
|
30
30
|
# Use WMI to determine current OS version.
|
31
31
|
# On Win2k8R2 and later, we can dynamically obtain marketing
|
@@ -44,7 +44,7 @@ describe "Chef::ReservedNames::Win32::Version", :windows_only, :not_supported_on
|
|
44
44
|
# The name from WMI is actually what we want in Win2k8R2+.
|
45
45
|
# So this expectation sould continue to hold without modification
|
46
46
|
# as new versions of Windows are released.
|
47
|
-
@current_os_version = host
|
47
|
+
@current_os_version = host['caption']
|
48
48
|
end
|
49
49
|
|
50
50
|
@version = Chef::ReservedNames::Win32::Version.new
|
@@ -98,7 +98,7 @@ describe "Chef::ReservedNames::Win32::Version", :windows_only, :not_supported_on
|
|
98
98
|
def is_windows_server_2008?(wmi_host)
|
99
99
|
is_win2k8 = false
|
100
100
|
|
101
|
-
os_version = wmi_host
|
101
|
+
os_version = wmi_host['version']
|
102
102
|
|
103
103
|
# The operating system version is a string in the following form
|
104
104
|
# that can be split into components based on the '.' delimiter:
|
@@ -62,7 +62,7 @@ END_VALIDATION_PEM
|
|
62
62
|
|
63
63
|
let(:basic_config_file) do
|
64
64
|
<<-END_CLIENT_RB
|
65
|
-
chef_server_url "http://[::1]:
|
65
|
+
chef_server_url "http://[::1]:8900"
|
66
66
|
validation_key '#{path_to('config/validator.pem')}'
|
67
67
|
cache_path '#{cache_path}'
|
68
68
|
client_key '#{cache_path}/client.pem'
|
@@ -16,6 +16,7 @@
|
|
16
16
|
# limitations under the License.
|
17
17
|
|
18
18
|
require 'support/shared/integration/integration_helper'
|
19
|
+
require 'support/shared/context/config'
|
19
20
|
require 'chef/knife/list'
|
20
21
|
require 'chef/knife/show'
|
21
22
|
|
@@ -101,7 +102,7 @@ EOM
|
|
101
102
|
/users/
|
102
103
|
/users/user3.json
|
103
104
|
EOM
|
104
|
-
end
|
105
|
+
end
|
105
106
|
|
106
107
|
context 'when cwd is at the top level' do
|
107
108
|
cwd '.'
|
@@ -801,6 +802,8 @@ EOM
|
|
801
802
|
end
|
802
803
|
|
803
804
|
context 'when data_bag_path is set and nothing else' do
|
805
|
+
include_context "default config options"
|
806
|
+
|
804
807
|
before :each do
|
805
808
|
%w(client cookbook environment node role user).each do |object_name|
|
806
809
|
Chef::Config.delete("#{object_name}_path".to_sym)
|
@@ -37,16 +37,16 @@ describe 'knife common options' do
|
|
37
37
|
Chef::Config.chef_zero.enabled = true
|
38
38
|
end
|
39
39
|
|
40
|
-
it 'knife raw /nodes/x should retrieve the
|
40
|
+
it 'knife raw /nodes/x should retrieve the node' do
|
41
41
|
knife('raw /nodes/x').should_succeed /"name": "x"/
|
42
42
|
end
|
43
43
|
|
44
44
|
context 'And chef_zero.port is 9999' do
|
45
45
|
before(:each) { Chef::Config.chef_zero.port = 9999 }
|
46
|
-
|
47
|
-
it 'knife raw /nodes/x should retrieve the
|
46
|
+
|
47
|
+
it 'knife raw /nodes/x should retrieve the node' do
|
48
48
|
knife('raw /nodes/x').should_succeed /"name": "x"/
|
49
|
-
Chef::Config.chef_server_url.should == 'http://
|
49
|
+
Chef::Config.chef_server_url.should == 'http://localhost:9999'
|
50
50
|
end
|
51
51
|
end
|
52
52
|
|
@@ -81,23 +81,23 @@ syHLXYFNy0OxMtH/bBAXBGNHd9gf5uOnqh0pYcbe/uRAxumC7Rl0cL509eURiA2T
|
|
81
81
|
-----END RSA PRIVATE KEY-----
|
82
82
|
EOM
|
83
83
|
|
84
|
-
it 'knife raw /nodes/x should retrieve the
|
84
|
+
it 'knife raw /nodes/x should retrieve the node' do
|
85
85
|
knife('raw /nodes/x').should_succeed /"name": "x"/
|
86
86
|
end
|
87
87
|
end
|
88
88
|
end
|
89
89
|
|
90
|
-
it 'knife raw -z /nodes/x retrieves the
|
90
|
+
it 'knife raw -z /nodes/x retrieves the node' do
|
91
91
|
knife('raw -z /nodes/x').should_succeed /"name": "x"/
|
92
92
|
end
|
93
93
|
|
94
|
-
it 'knife raw --local-mode /nodes/x retrieves the
|
94
|
+
it 'knife raw --local-mode /nodes/x retrieves the node' do
|
95
95
|
knife('raw --local-mode /nodes/x').should_succeed /"name": "x"/
|
96
96
|
end
|
97
97
|
|
98
|
-
it 'knife raw -z --chef-zero-port=9999 /nodes/x retrieves the
|
98
|
+
it 'knife raw -z --chef-zero-port=9999 /nodes/x retrieves the node' do
|
99
99
|
knife('raw -z --chef-zero-port=9999 /nodes/x').should_succeed /"name": "x"/
|
100
|
-
Chef::Config.chef_server_url.should == 'http://
|
100
|
+
Chef::Config.chef_server_url.should == 'http://localhost:9999'
|
101
101
|
end
|
102
102
|
end
|
103
103
|
end
|
@@ -74,7 +74,7 @@ END_VALIDATION_PEM
|
|
74
74
|
|
75
75
|
let(:knife_rb_content) do
|
76
76
|
<<-END_CLIENT_RB
|
77
|
-
chef_server_url "http://[::1]:
|
77
|
+
chef_server_url "http://[::1]:8900"
|
78
78
|
syntax_check_cache_path '#{cache_path}'
|
79
79
|
client_key '#{path_to('config/knifeuser.pem')}'
|
80
80
|
node_name 'whoisthisis'
|
@@ -89,7 +89,7 @@ END_CLIENT_RB
|
|
89
89
|
|
90
90
|
it "successfully uploads a cookbook" do
|
91
91
|
shell_out!("knife cookbook upload apache2 #{knife_config_flag}", :cwd => chef_dir)
|
92
|
-
versions_list_json = Chef::HTTP::Simple.new("http://[::1]:
|
92
|
+
versions_list_json = Chef::HTTP::Simple.new("http://[::1]:8900").get("/cookbooks/apache2", "accept" => "application/json")
|
93
93
|
versions_list = Chef::JSONCompat.from_json(versions_list_json)
|
94
94
|
versions_list["apache2"]["versions"].should_not be_empty
|
95
95
|
end
|
@@ -16,6 +16,7 @@
|
|
16
16
|
# limitations under the License.
|
17
17
|
|
18
18
|
require 'support/shared/integration/integration_helper'
|
19
|
+
require 'support/shared/context/config'
|
19
20
|
require 'chef/knife/deps'
|
20
21
|
|
21
22
|
describe 'knife deps' do
|
@@ -340,6 +341,8 @@ EOM
|
|
340
341
|
end
|
341
342
|
|
342
343
|
context 'remote' do
|
344
|
+
include_context "default config options"
|
345
|
+
|
343
346
|
when_the_chef_server 'has a role with no run_list' do
|
344
347
|
role 'starring', {}
|
345
348
|
it 'knife deps reports no dependencies' do
|
@@ -16,12 +16,15 @@
|
|
16
16
|
# limitations under the License.
|
17
17
|
|
18
18
|
require 'support/shared/integration/integration_helper'
|
19
|
+
require 'support/shared/context/config'
|
19
20
|
require 'chef/knife/list'
|
20
21
|
|
21
22
|
describe 'knife list' do
|
22
23
|
extend IntegrationSupport
|
23
24
|
include KnifeSupport
|
24
25
|
|
26
|
+
include_context "default config options"
|
27
|
+
|
25
28
|
when_the_chef_server "is empty" do
|
26
29
|
it "knife list / returns all top level directories" do
|
27
30
|
knife('list /').should_succeed <<EOM
|
@@ -16,6 +16,7 @@
|
|
16
16
|
# limitations under the License.
|
17
17
|
|
18
18
|
require 'support/shared/integration/integration_helper'
|
19
|
+
require 'support/shared/context/config'
|
19
20
|
require 'chef/knife/raw'
|
20
21
|
require 'chef/knife/show'
|
21
22
|
|
@@ -24,6 +25,8 @@ describe 'knife raw' do
|
|
24
25
|
include KnifeSupport
|
25
26
|
include AppServerSupport
|
26
27
|
|
28
|
+
include_context "default config options"
|
29
|
+
|
27
30
|
when_the_chef_server "has one of each thing" do
|
28
31
|
client 'x', '{}'
|
29
32
|
cookbook 'x', '1.0.0', { 'metadata.rb' => 'version "1.0.0"' }
|
@@ -166,7 +169,7 @@ EOM
|
|
166
169
|
|
167
170
|
context 'When a server returns raw json' do
|
168
171
|
before :each do
|
169
|
-
Chef::Config.chef_server_url = "http://
|
172
|
+
Chef::Config.chef_server_url = "http://localhost:9018"
|
170
173
|
app = lambda do |env|
|
171
174
|
[200, {'Content-Type' => 'application/json' }, ['{ "x": "y", "a": "b" }'] ]
|
172
175
|
end
|
@@ -196,7 +199,7 @@ EOM
|
|
196
199
|
|
197
200
|
context 'When a server returns text' do
|
198
201
|
before :each do
|
199
|
-
Chef::Config.chef_server_url = "http://
|
202
|
+
Chef::Config.chef_server_url = "http://localhost:9018"
|
200
203
|
app = lambda do |env|
|
201
204
|
[200, {'Content-Type' => 'text' }, ['{ "x": "y", "a": "b" }'] ]
|
202
205
|
end
|