summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLamont Granquist <454857+lamont-granquist@users.noreply.github.com>2022-03-15 12:48:29 -0700
committerGitHub <noreply@github.com>2022-03-15 12:48:29 -0700
commit64afc0b095a2df54d3fca8787114a23aedc82fbd (patch)
tree472a1971b744b4917770e87b8b2cbcef9c951a89
parentd62945c3a94de662846245a3025fdcfa121e1298 (diff)
parent9081cfafc2f7fb4aa768d851bfa6bf393613556d (diff)
downloadchef-64afc0b095a2df54d3fca8787114a23aedc82fbd.tar.gz
Merge pull request #12619 from sanjain-progress/sanjain/2505-fix-pem-generation
-rw-r--r--knife/lib/chef/knife/user_create.rb8
-rw-r--r--knife/spec/unit/knife/user_create_spec.rb42
2 files changed, 39 insertions, 11 deletions
diff --git a/knife/lib/chef/knife/user_create.rb b/knife/lib/chef/knife/user_create.rb
index 009f193d46..158e8d11cd 100644
--- a/knife/lib/chef/knife/user_create.rb
+++ b/knife/lib/chef/knife/user_create.rb
@@ -128,6 +128,7 @@ class Chef
display_name: "#{user.first_name} #{user.last_name}",
email: user.email,
password: password,
+ create_key: user.create_key,
}
else
user_hash = {
@@ -137,6 +138,7 @@ class Chef
display_name: user.display_name,
email: user.email,
password: password,
+ create_key: user.create_key,
}
end
@@ -159,13 +161,13 @@ class Chef
end
ui.info("Created #{user.username}")
- if final_user["private_key"]
+ if final_user["chef_key"] && final_user["chef_key"]["private_key"]
if config[:file]
File.open(config[:file], "w") do |f|
- f.print(final_user["private_key"])
+ f.print(final_user["chef_key"]["private_key"])
end
else
- ui.msg final_user["private_key"]
+ ui.msg final_user["chef_key"]["private_key"]
end
end
end
diff --git a/knife/spec/unit/knife/user_create_spec.rb b/knife/spec/unit/knife/user_create_spec.rb
index 1257d92ee9..32a3448205 100644
--- a/knife/spec/unit/knife/user_create_spec.rb
+++ b/knife/spec/unit/knife/user_create_spec.rb
@@ -16,7 +16,6 @@
# See the License for the specific language governing permissions and
# limitations under the License.
#
-
require "knife_spec_helper"
Chef::Knife::UserCreate.load_deps
@@ -80,7 +79,7 @@ describe Chef::Knife::UserCreate do
before :each do
@user = double("Chef::User")
@key = "You don't come into cooking to get rich - Ramsay"
- allow(@user).to receive(:[]).with("private_key").and_return(@key)
+ allow(@user).to receive(:[]).with("chef_key").and_return(@key)
knife.config[:passwordprompt] = true
knife.name_args = name_args
end
@@ -97,7 +96,7 @@ describe Chef::Knife::UserCreate do
before do
@user = double("Chef::User")
@key = "You don't come into cooking to get rich - Ramsay"
- allow(@user).to receive(:[]).with("private_key").and_return(@key)
+ allow(@user).to receive(:[]).with("chef_key").and_return(@key)
knife.name_args = %w{some_user some_display_name some_first_name some_last_name some_email some_password}
end
@@ -177,17 +176,39 @@ describe Chef::Knife::UserCreate do
describe "with user_name, first_name, last_name, email and password" do
let(:name_args) { %w{some_user some_display_name some_first_name some_last_name test@email.com some_password} }
+ before :each do
+ @user = double("Chef::User")
+ expect(Chef::ServerAPI).to receive(:new).with(Chef::Config[:chef_server_root]).and_return(root_rest)
+ expect(root_rest).to receive(:post).and_return(@user)
+ @key = IO.read(File.join(CHEF_SPEC_DATA, "ssl", "private_key.pem"))
+ allow(@user).to receive(:[]).with("chef_key").and_return(nil)
+ knife.name_args = name_args
+ end
+
+ it "creates an user without private key" do
+ expect(knife.ui).to_not receive(:msg).with(@key)
+ knife.run
+ end
+ end
+ describe "with user_name, first_name, last_name, email and password" do
+ let(:name_args) { %w{some_user some_display_name some_first_name some_last_name test@email.com some_password} }
before :each do
@user = double("Chef::User")
expect(Chef::ServerAPI).to receive(:new).with(Chef::Config[:chef_server_root]).and_return(root_rest)
expect(root_rest).to receive(:post).and_return(@user)
- @key = "You don't come into cooking to get rich - Ramsay"
- allow(@user).to receive(:[]).with("private_key").and_return(@key)
+ @username = "Created #{name_args.first}"
+ @key = IO.read(File.join(CHEF_SPEC_DATA, "ssl", "private_key.pem"))
+ allow(@user).to receive(:[]).with("chef_key").and_return("private_key" => @key)
knife.name_args = name_args
end
it "creates an user" do
+ expect(knife.ui).to receive(:info).with(@username)
+ knife.run
+ end
+
+ it "creates an user private key" do
expect(knife.ui).to receive(:msg).with(@key)
knife.run
end
@@ -204,7 +225,6 @@ describe Chef::Knife::UserCreate do
}
it "creates an user, associates a user, and adds it to the admins group" do
-
expect(root_rest).to receive(:post).with("organizations/ramsay/association_requests", request_body).and_return(@user)
expect(root_rest).to receive(:put).with("users/some_user/association_requests/1", { response: "accept" })
knife.run
@@ -219,14 +239,20 @@ describe Chef::Knife::UserCreate do
@user = double("Chef::User")
expect(Chef::ServerAPI).to receive(:new).with(Chef::Config[:chef_server_root]).and_return(root_rest)
expect(root_rest).to receive(:post).and_return(@user)
- @key = "You don't come into cooking to get rich - Ramsay"
- allow(@user).to receive(:[]).with("private_key").and_return(@key)
+ @username = "Created #{name_args.first}"
+ @key = IO.read(File.join(CHEF_SPEC_DATA, "ssl", "private_key.pem"))
+ allow(@user).to receive(:[]).with("chef_key").and_return("private_key" => @key)
knife.name_args = name_args
knife.config[:email] = "test@email.com"
knife.config[:password] = "some_password"
end
it "creates an user" do
+ expect(knife.ui).to receive(:info).with(@username)
+ knife.run
+ end
+
+ it "creates an user private key" do
expect(knife.ui).to receive(:msg).with(@key)
knife.run
end