action/forward_ports: Merge port forwarding with sudo specs into a single file [GH-259]
This commit is contained in:
parent
a0fe2f9cf0
commit
9838d32c2d
2 changed files with 31 additions and 78 deletions
|
@ -6,7 +6,7 @@ require 'vagrant-lxc/action/forward_ports'
|
||||||
|
|
||||||
describe Vagrant::LXC::Action::ForwardPorts do
|
describe Vagrant::LXC::Action::ForwardPorts do
|
||||||
let(:app) { double(:app, call: true) }
|
let(:app) { double(:app, call: true) }
|
||||||
let(:env) { {machine: machine, ui: double(info: true)} }
|
let(:env) { {machine: machine, ui: double(info: true, warn: true)} }
|
||||||
let(:machine) { double(:machine) }
|
let(:machine) { double(:machine) }
|
||||||
let!(:data_dir) { Pathname.new(Dir.mktmpdir) }
|
let!(:data_dir) { Pathname.new(Dir.mktmpdir) }
|
||||||
let(:provider) { double(Vagrant::LXC::Provider, ssh_info: {host: container_ip}) }
|
let(:provider) { double(Vagrant::LXC::Provider, ssh_info: {host: container_ip}) }
|
||||||
|
@ -74,4 +74,34 @@ describe Vagrant::LXC::Action::ForwardPorts do
|
||||||
subject.stub(system: false)
|
subject.stub(system: false)
|
||||||
expect { subject.call(env) }.to raise_error(Vagrant::LXC::Errors::RedirNotInstalled)
|
expect { subject.call(env) }.to raise_error(Vagrant::LXC::Errors::RedirNotInstalled)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
context 'when a privileged port is used' do
|
||||||
|
let(:host_port) { 80 }
|
||||||
|
|
||||||
|
it 'forwards ports using redir' do
|
||||||
|
subject.stub(system: true)
|
||||||
|
subject.call(env)
|
||||||
|
expect(subject).to have_received(:spawn).with(
|
||||||
|
"sudo redir --laddr=#{host_ip} --lport=#{host_port} --caddr=#{container_ip} --cport=#{guest_port} 2>/dev/null"
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'skips --laddr parameter if host_ip is nil' do
|
||||||
|
forward_conf.delete(:host_ip)
|
||||||
|
subject.stub(system: true)
|
||||||
|
subject.call(env)
|
||||||
|
expect(subject).to have_received(:spawn).with(
|
||||||
|
"sudo redir --lport=#{host_port} --caddr=#{container_ip} --cport=#{guest_port} 2>/dev/null"
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'skips --laddr parameter if host_ip is a blank string' do
|
||||||
|
forward_conf[:host_ip] = ' '
|
||||||
|
subject.stub(system: true)
|
||||||
|
subject.call(env)
|
||||||
|
expect(subject).to have_received(:spawn).with(
|
||||||
|
"sudo redir --lport=#{host_port} --caddr=#{container_ip} --cport=#{guest_port} 2>/dev/null"
|
||||||
|
)
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,77 +0,0 @@
|
||||||
require 'unit_helper'
|
|
||||||
|
|
||||||
require 'tmpdir'
|
|
||||||
require 'vagrant-lxc/provider'
|
|
||||||
require 'vagrant-lxc/action/forward_ports'
|
|
||||||
|
|
||||||
describe Vagrant::LXC::Action::ForwardPorts do
|
|
||||||
let(:app) { double(:app, call: true) }
|
|
||||||
let(:env) { {machine: machine, ui: double(info: true, warn: true)} }
|
|
||||||
let(:machine) { double(:machine) }
|
|
||||||
let!(:data_dir) { Pathname.new(Dir.mktmpdir) }
|
|
||||||
let(:provider) { double(Vagrant::LXC::Provider, ssh_info: {host: container_ip}) }
|
|
||||||
let(:host_ip) { '127.0.0.1' }
|
|
||||||
let(:host_port) { 80 }
|
|
||||||
let(:guest_port) { 80 }
|
|
||||||
let(:container_ip) { '10.0.1.234' }
|
|
||||||
let(:pid) { 'a-pid' }
|
|
||||||
let(:forward_conf) { {guest: guest_port, host: host_port, host_ip: host_ip} }
|
|
||||||
let(:networks) { [[:other_config, {}], [:forwarded_port, forward_conf]] }
|
|
||||||
|
|
||||||
subject { described_class.new(app, env) }
|
|
||||||
|
|
||||||
before do
|
|
||||||
machine.stub_chain(:config, :vm, :networks).and_return(networks)
|
|
||||||
machine.stub(provider: provider, data_dir: data_dir)
|
|
||||||
|
|
||||||
subject.stub(exec: true)
|
|
||||||
subject.stub(spawn: pid)
|
|
||||||
end
|
|
||||||
|
|
||||||
after { FileUtils.rm_rf data_dir.to_s }
|
|
||||||
|
|
||||||
it 'forwards ports using redir' do
|
|
||||||
subject.stub(system: true)
|
|
||||||
subject.call(env)
|
|
||||||
expect(subject).to have_received(:spawn).with(
|
|
||||||
"sudo redir --laddr=#{host_ip} --lport=#{host_port} --caddr=#{container_ip} --cport=#{guest_port} 2>/dev/null"
|
|
||||||
)
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'skips --laddr parameter if host_ip is nil' do
|
|
||||||
forward_conf.delete(:host_ip)
|
|
||||||
subject.stub(system: true)
|
|
||||||
subject.call(env)
|
|
||||||
expect(subject).to have_received(:spawn).with(
|
|
||||||
"sudo redir --lport=#{host_port} --caddr=#{container_ip} --cport=#{guest_port} 2>/dev/null"
|
|
||||||
)
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'skips --laddr parameter if host_ip is a blank string' do
|
|
||||||
forward_conf[:host_ip] = ' '
|
|
||||||
subject.stub(system: true)
|
|
||||||
subject.call(env)
|
|
||||||
expect(subject).to have_received(:spawn).with(
|
|
||||||
"sudo redir --lport=#{host_port} --caddr=#{container_ip} --cport=#{guest_port} 2>/dev/null"
|
|
||||||
)
|
|
||||||
end
|
|
||||||
|
|
||||||
it "stores redir pids on machine's data dir" do
|
|
||||||
subject.stub(system: true)
|
|
||||||
subject.call(env)
|
|
||||||
pid_file = data_dir.join('pids', "redir_#{host_port}.pid").read
|
|
||||||
expect(pid_file).to eq(pid)
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'allows disabling a previously forwarded port' do
|
|
||||||
forward_conf[:disabled] = true
|
|
||||||
subject.stub(system: true)
|
|
||||||
subject.call(env)
|
|
||||||
expect(subject).not_to have_received(:spawn)
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'raises RedirNotInstalled error if `redir` is not installed' do
|
|
||||||
subject.stub(system: false)
|
|
||||||
expect { subject.call(env) }.to raise_error(Vagrant::LXC::Errors::RedirNotInstalled)
|
|
||||||
end
|
|
||||||
end
|
|
Loading…
Reference in a new issue