1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
|
#
# Author:: Tyler Cloke (<tyler@chef.io>)
# Copyright:: Copyright 2015-2016, Chef Software, Inc.
# License:: Apache License, Version 2.0
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
shared_examples_for "user or client create" do
context "when server API V1 is valid on the Chef Server receiving the request" do
it "creates a new object via the API" do
expect(rest_v1).to receive(:post).with(url, payload).and_return({})
object.create
end
it "creates a new object via the API with a public_key when it exists" do
object.public_key "some_public_key"
expect(rest_v1).to receive(:post).with(url, payload.merge({:public_key => "some_public_key"})).and_return({})
object.create
end
context "raise error when create_key and public_key are both set" do
before do
object.public_key "key"
object.create_key true
end
it "rasies the proper error" do
expect { object.create }.to raise_error(error)
end
end
context "when create_key == true" do
before do
object.create_key true
end
it "creates a new object via the API with create_key" do
expect(rest_v1).to receive(:post).with(url, payload.merge({:create_key => true})).and_return({})
object.create
end
end
context "when chef_key is returned by the server" do
let(:chef_key) {
{
"chef_key" => {
"public_key" => "some_public_key"
}
}
}
it "puts the public key into the objectr returned by create" do
expect(rest_v1).to receive(:post).with(url, payload).and_return(payload.merge(chef_key))
new_object = object.create
expect(new_object.public_key).to eq("some_public_key")
end
context "when private_key is returned in chef_key" do
let(:chef_key) {
{
"chef_key" => {
"public_key" => "some_public_key",
"private_key" => "some_private_key",
}
}
}
it "puts the private key into the object returned by create" do
expect(rest_v1).to receive(:post).with(url, payload).and_return(payload.merge(chef_key))
new_object = object.create
expect(new_object.private_key).to eq("some_private_key")
end
end
end # when chef_key is returned by the server
end # when server API V1 is valid on the Chef Server receiving the request
context "when server API V1 is not valid on the Chef Server receiving the request" do
context "when the server supports API V0" do
before do
allow(object).to receive(:server_client_api_version_intersection).and_return([0])
allow(rest_v1).to receive(:post).and_raise(exception_406)
end
it "creates a new object via the API" do
expect(rest_v0).to receive(:post).with(url, payload).and_return({})
object.create
end
it "creates a new object via the API with a public_key when it exists" do
object.public_key "some_public_key"
expect(rest_v0).to receive(:post).with(url, payload.merge({:public_key => "some_public_key"})).and_return({})
object.create
end
end # when the server supports API V0
end # when server API V1 is not valid on the Chef Server receiving the request
end # user or client create
|