(#7221) Introduce flag for suspending all machines
This commit introduces a new flag to the suspend command, `--all-global`, which will suepend all vms both locally and globally.
This commit is contained in:
parent
02c207b42e
commit
aa5687cd14
|
@ -8,8 +8,13 @@ module VagrantPlugins
|
|||
end
|
||||
|
||||
def execute
|
||||
options = {}
|
||||
opts = OptionParser.new do |o|
|
||||
o.banner = "Usage: vagrant suspend [name|id]"
|
||||
o.banner = "Usage: vagrant suspend [options] [name|id]"
|
||||
o.separator ""
|
||||
o.on("-a", "--all-global", "Suspend all running vms globally.") do |p|
|
||||
options[:all] = true
|
||||
end
|
||||
end
|
||||
|
||||
# Parse the options
|
||||
|
@ -17,7 +22,15 @@ module VagrantPlugins
|
|||
return if !argv
|
||||
|
||||
@logger.debug("'suspend' each target VM...")
|
||||
with_target_vms(argv) do |vm|
|
||||
target = []
|
||||
if options[:all]
|
||||
m = @env.machine_index.each { |m| m }
|
||||
target = m.keys
|
||||
else
|
||||
target = argv
|
||||
end
|
||||
|
||||
with_target_vms(target) do |vm|
|
||||
vm.action(:suspend)
|
||||
end
|
||||
|
||||
|
|
|
@ -0,0 +1,103 @@
|
|||
require File.expand_path("../../../../base", __FILE__)
|
||||
require Vagrant.source_root.join("plugins/commands/suspend/command")
|
||||
|
||||
describe VagrantPlugins::CommandSuspend::Command do
|
||||
include_context "unit"
|
||||
|
||||
let(:entry_klass) { Vagrant::MachineIndex::Entry }
|
||||
let(:argv) { [] }
|
||||
let(:vagrantfile_content){ "" }
|
||||
let(:iso_env) do
|
||||
env = isolated_environment
|
||||
env.vagrantfile(vagrantfile_content)
|
||||
env.create_vagrant_env
|
||||
end
|
||||
|
||||
subject { described_class.new(argv, iso_env) }
|
||||
|
||||
let(:action_runner) { double("action_runner") }
|
||||
let(:machine) { iso_env.machine(iso_env.machine_names[0], :dummy) }
|
||||
let(:machine2) { iso_env.machine(iso_env.machine_names[0], :dummy) }
|
||||
|
||||
def new_entry(name)
|
||||
entry_klass.new.tap do |e|
|
||||
e.name = name
|
||||
e.vagrantfile_path = "/bar"
|
||||
end
|
||||
end
|
||||
|
||||
before do
|
||||
allow(iso_env).to receive(:action_runner).and_return(action_runner)
|
||||
allow(subject).to receive(:with_target_vms) { |&block| block.call machine }
|
||||
end
|
||||
|
||||
context "with no argument" do
|
||||
let(:vagrantfile_content) do
|
||||
<<-VF
|
||||
Vagrant.configure("2") do |config|
|
||||
config.vm.define "app"
|
||||
config.vm.define "db"
|
||||
end
|
||||
VF
|
||||
end
|
||||
|
||||
it "should suspend all vms" do
|
||||
allow(subject).to receive(:with_target_vms) { |&block|
|
||||
block.call machine
|
||||
block.call machine2
|
||||
}
|
||||
expect(machine).to receive(:action) do |name, opts|
|
||||
expect(name).to eq(:suspend)
|
||||
end
|
||||
expect(machine2).to receive(:action) do |name, opts|
|
||||
expect(name).to eq(:suspend)
|
||||
end
|
||||
|
||||
expect(subject.execute).to eq(0)
|
||||
end
|
||||
end
|
||||
|
||||
context "with an argument" do
|
||||
let(:vagrantfile_content) do
|
||||
<<-VF
|
||||
Vagrant.configure("2") do |config|
|
||||
config.vm.define "app"
|
||||
config.vm.define "db"
|
||||
end
|
||||
VF
|
||||
end
|
||||
let(:argv) { ["app"] }
|
||||
|
||||
it "should suspend a vm" do
|
||||
expect(machine).to receive(:action) do |name, opts|
|
||||
expect(name).to eq(:suspend)
|
||||
end
|
||||
|
||||
expect(subject.execute).to eq(0)
|
||||
end
|
||||
end
|
||||
|
||||
context "with the global all flag" do
|
||||
let(:argv){ ["--all-global"] }
|
||||
|
||||
it "should suspend all vms globally" do
|
||||
global_env = isolated_environment
|
||||
global_env.vagrantfile("Vagrant.configure(2){|config| config.vm.box = 'dummy'}")
|
||||
global_venv = global_env.create_vagrant_env
|
||||
global_machine = global_venv.machine(global_venv.machine_names[0], :dummy)
|
||||
global_machine.id = "1234"
|
||||
global = new_entry(global_machine.name)
|
||||
global.provider = "dummy"
|
||||
global.vagrantfile_path = global_env.workdir
|
||||
locked = iso_env.machine_index.set(global)
|
||||
iso_env.machine_index.release(locked)
|
||||
|
||||
allow(subject).to receive(:with_target_vms) { |&block| block.call global_machine }
|
||||
expect(global_machine).to receive(:action) do |name, opts|
|
||||
expect(name).to eq(:suspend)
|
||||
end
|
||||
|
||||
expect(subject.execute).to eq(0)
|
||||
end
|
||||
end
|
||||
end
|
Loading…
Reference in New Issue