summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPrajaktaPurohit <PrajaktaPurohit@users.noreply.github.com>2022-04-12 12:42:36 -0700
committerGitHub <noreply@github.com>2022-04-12 12:42:36 -0700
commitf8dcc9d0bcba88a2ba13941a6ad88fe43e3a8841 (patch)
tree12c20d2583f2bba119bf3737135fbd613d26f18f
parent4f1723722cdac9d27fbb46c3df304ed7f7a6ce75 (diff)
parent5a746b9ac87e0f3c4eeb0dcc96943ce27506ba93 (diff)
downloadchef-f8dcc9d0bcba88a2ba13941a6ad88fe43e3a8841.tar.gz
Merge pull request #12772 from sanjain-progress/fix/sanjain/2505-fix-pem-generation
Fix pem generation when user created
-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