From d074ac7906f2068b96a4987190d91ef62ff82f16 Mon Sep 17 00:00:00 2001 From: Tobias Date: Tue, 28 Feb 2017 08:22:05 -0800 Subject: [PATCH] guests/esxi: Added public_key_test --- .../guests/esxi/cap/public_key_test.rb | 48 +++++++++++++++++++ 1 file changed, 48 insertions(+) create mode 100644 test/unit/plugins/guests/esxi/cap/public_key_test.rb diff --git a/test/unit/plugins/guests/esxi/cap/public_key_test.rb b/test/unit/plugins/guests/esxi/cap/public_key_test.rb new file mode 100644 index 000000000..93a300852 --- /dev/null +++ b/test/unit/plugins/guests/esxi/cap/public_key_test.rb @@ -0,0 +1,48 @@ +require_relative "../../../../base" + +describe "VagrantPlugins::GuestEsxi::Cap::PublicKey" do + let(:caps) do + VagrantPlugins::GuestEsxi::Plugin + .components + .guest_capabilities[:esxi] + end + + let(:machine) { double("machine") } + let(:comm) { VagrantTests::DummyCommunicator::Communicator.new(machine) } + + before do + allow(machine).to receive(:communicate).and_return(comm) + end + + after do + comm.verify_expectations! + end + + describe ".insert_public_key" do + let(:cap) { caps.get(:insert_public_key) } + + it "inserts the public key" do + cap.insert_public_key(machine, "ssh-rsa ...") + expect(comm.received_commands[0]).to match(/SSH_DIR=".*"/) + expect(comm.received_commands[0]).to match(/mkdir -p "\${SSH_DIR}"/) + expect(comm.received_commands[0]).to match(/chmod 0700 "\${SSH_DIR}"/) + expect(comm.received_commands[0]).to match(/cat '\/tmp\/vagrant-(.+)' >> "\${SSH_DIR}\/authorized_keys"/) + expect(comm.received_commands[0]).to match(/chmod 0600 "\${SSH_DIR}\/authorized_keys"/) + expect(comm.received_commands[0]).to match(/rm -f '\/tmp\/vagrant-(.+)'/) + end + end + + describe ".remove_public_key" do + let(:cap) { caps.get(:remove_public_key) } + + it "removes the public key" do + cap.remove_public_key(machine, "ssh-rsa ...") + expect(comm.received_commands[0]).to match(/SSH_DIR=".*"/) + expect(comm.received_commands[0]).to match(/grep -v -x -f '\/tmp\/vagrant-(.+)' "\${SSH_DIR}\/authorized_keys" > "\${SSH_DIR}\/authorized_keys\.tmp"/) + expect(comm.received_commands[0]).to match(/mv "\${SSH_DIR}\/authorized_keys\.tmp" "\${SSH_DIR}\/authorized_keys"/) + expect(comm.received_commands[0]).to match(/chmod 0600 "\${SSH_DIR}\/authorized_keys"/) + expect(comm.received_commands[0]).to match(/rm -f '\/tmp\/vagrant-(.+)'/) + end + end + +end