Brian Cain 1ade699936 (#6827) Introduce tty flag for ssh command execution
Prior to this commit, if a user ran the `vagrant ssh -c CMD` command, it
would not allow the user to configure pseudo-terminal allocation. This
commit introduces a -t flag for the `vagrant ssh` command which defaults
to true if not specified.
2017-06-02 17:32:02 -07:00

84 lines
2.2 KiB
Ruby

require File.expand_path("../../../../base", __FILE__)
describe Vagrant::Action::Builtin::SSHRun do
let(:app) { lambda { |env| } }
let(:env) { { machine: machine, tty: true } }
# SSH configuration information mock
let(:ssh) do
double("ssh",
timeout: 1,
host: nil,
port: 5986,
guest_port: 5986,
pty: false,
keep_alive: false,
insert_key: false,
shell: 'bash -l'
)
end
# Configuration mock
let(:config) { double("config", ssh: ssh) }
let(:machine) do
double("machine",
config: config,)
end
let(:machine_ssh_info) { {} }
let(:ssh_klass) { Vagrant::Util::SSH }
before(:each) do
# Stub the methods so that even if we test incorrectly, no side
# effects actually happen.
allow(ssh_klass).to receive(:exec)
allow(machine).to receive(:ssh_info).and_return(machine_ssh_info)
end
it "should raise an exception if SSH is not ready" do
not_ready_machine = double("machine")
allow(not_ready_machine).to receive(:ssh_info).and_return(nil)
env[:machine] = not_ready_machine
expect { described_class.new(app, env).call(env) }.
to raise_error(Vagrant::Errors::SSHNotReady)
end
it "should exec with the SSH info in the env if given" do
ssh_info = { foo: :bar }
opts = {:extra_args=>["-t", "bash -l -c 'echo test'"], :subprocess=>true}
expect(ssh_klass).to receive(:exec).
with(ssh_info, opts)
env[:ssh_info] = ssh_info
env[:ssh_run_command] = "echo test"
described_class.new(app, env).call(env)
end
it "should exec with the SSH info in the env if given and disable tty" do
ssh_info = { foo: :bar }
opts = {:extra_args=>["bash -l -c 'echo test'"], :subprocess=>true}
env[:tty] = false
expect(ssh_klass).to receive(:exec).
with(ssh_info, opts)
env[:ssh_info] = ssh_info
env[:ssh_run_command] = "echo test"
described_class.new(app, env).call(env)
end
it "should exec with the options given in `ssh_opts`" do
ssh_opts = { foo: :bar }
expect(ssh_klass).to receive(:exec).
with(machine_ssh_info, ssh_opts)
env[:ssh_opts] = ssh_opts
env[:ssh_run_command] = "echo test"
described_class.new(app, env).call(env)
end
end