vagrant/test/acceptance/support/output.rb

71 lines
2.0 KiB
Ruby
Raw Normal View History

module Acceptance
# This class helps with matching against output so that every
# test isn't inherently tied to the output format of Vagrant.
class Output
def initialize(text)
@text = text
end
2011-11-05 22:01:00 +00:00
# Checks that an error message was outputted about the box
# being added being invalid.
def box_invalid
@text =~ /^The box file you're attempting to add is invalid./
end
2011-11-05 22:01:00 +00:00
# Checks that an error message was outputted about the path
# not existing to the box.
def box_path_doesnt_exist
@text =~ /^The specified path to a file doesn't exist.$/
end
2011-11-05 22:01:00 +00:00
# Tests that the box with given name is installed.
def box_installed(name)
2011-11-05 22:01:00 +00:00
@text =~ /^#{name}$/
end
2011-11-05 22:01:00 +00:00
# Tests that the output says there are no installed boxes.
def no_boxes
@text =~ /There are no installed boxes!/
end
# Tests that the output says there is no Vagrantfile, and as such
# can't do whatever we requested Vagrant to do.
def no_vagrantfile
@text =~ /^No Vagrant environment detected/
end
2011-11-05 22:01:00 +00:00
# Tests that the output contains a specific Vagrant version.
def version(version)
@text =~ /^Vagrant version #{version}$/
end
# This checks that the VM with the given `vm_name` has the
# status of `status`.
def status(vm_name, status)
@text =~ /^#{vm_name}\s+#{status}$/
end
2011-11-07 06:21:02 +00:00
# This checks that an error message that the VM must be created
# is shown.
def error_vm_must_be_created
@text =~ /^VM must be created/
end
2011-11-20 21:37:01 +00:00
# This checks that the warning that the VM is not created is emitted.
def vm_not_created_warning
@text =~ /VM not created. Moving on...$/
end
2011-11-20 21:37:01 +00:00
# This checks that the VM is destroyed.
def vm_destroyed
@text =~ /Destroying VM and associated drives...$/
end
2011-11-22 05:55:03 +00:00
# This checks that the "up" output properly contains text showing that
# it is downloading the box during the up process.
def up_fetching_box(name)
@text =~ /Box #{name} was not found. Fetching box from specified URL...$/
end
end
end