2017-02-07 05:43:49 +00:00
|
|
|
require 'optparse'
|
|
|
|
|
|
|
|
module VagrantPlugins
|
|
|
|
module CommandValidate
|
|
|
|
class Command < Vagrant.plugin("2", :command)
|
|
|
|
def self.synopsis
|
|
|
|
"validates the Vagrantfile"
|
|
|
|
end
|
|
|
|
|
|
|
|
def execute
|
2018-10-30 19:35:46 +00:00
|
|
|
options = {}
|
|
|
|
|
2017-02-07 05:43:49 +00:00
|
|
|
opts = OptionParser.new do |o|
|
2018-10-30 19:35:46 +00:00
|
|
|
o.banner = "Usage: vagrant validate [options]"
|
|
|
|
o.separator ""
|
|
|
|
o.separator "Validates a Vagrantfile config"
|
|
|
|
o.separator ""
|
|
|
|
o.separator "Options:"
|
|
|
|
o.separator ""
|
|
|
|
|
|
|
|
o.on("-p", "--ignore-provider", "Ignores provider config options") do |p|
|
|
|
|
options[:ignore_provider] = p
|
|
|
|
end
|
2017-02-07 05:43:49 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
# Parse the options
|
|
|
|
argv = parse_options(opts)
|
|
|
|
return if !argv
|
|
|
|
|
2018-10-30 19:35:46 +00:00
|
|
|
action_env = {}
|
|
|
|
if options[:ignore_provider]
|
|
|
|
action_env[:ignore_provider] = true
|
2018-12-03 22:45:26 +00:00
|
|
|
tmp_data_dir = mockup_providers!
|
2018-10-30 19:35:46 +00:00
|
|
|
end
|
2018-11-29 21:29:46 +00:00
|
|
|
|
2017-08-15 20:52:35 +00:00
|
|
|
# Validate the configuration of all machines
|
|
|
|
with_target_vms() do |machine|
|
2018-10-30 19:35:46 +00:00
|
|
|
machine.action_raw(:config_validate, Vagrant::Action::Builtin::ConfigValidate, action_env)
|
2017-08-15 20:52:35 +00:00
|
|
|
end
|
2017-02-07 05:43:49 +00:00
|
|
|
|
|
|
|
@env.ui.info(I18n.t("vagrant.commands.validate.success"))
|
|
|
|
|
|
|
|
# Success, exit status 0
|
|
|
|
0
|
2018-12-03 22:45:26 +00:00
|
|
|
ensure
|
|
|
|
FileUtils.remove_entry tmp_data_dir if tmp_data_dir
|
2017-02-07 05:43:49 +00:00
|
|
|
end
|
2018-11-29 21:29:46 +00:00
|
|
|
|
|
|
|
protected
|
|
|
|
|
|
|
|
# This method is required to bypass some of the provider checks that would
|
|
|
|
# otherwise raise exceptions before Vagrant could load and validate a config.
|
|
|
|
# It essentially ignores that there are no installed or usable prodivers so
|
|
|
|
# that Vagrant can go along and validate the rest of the Vagrantfile and ignore
|
|
|
|
# any provider blocks.
|
2018-12-03 22:45:26 +00:00
|
|
|
#
|
|
|
|
# return [String] tmp_data_dir - Temporary dir used to store guest metadata during validation
|
2018-11-29 21:29:46 +00:00
|
|
|
def mockup_providers!
|
|
|
|
require 'log4r'
|
|
|
|
logger = Log4r::Logger.new("vagrant::validate")
|
|
|
|
logger.debug("Overriding all registered provider classes for validate")
|
|
|
|
|
|
|
|
# Without setting up a tmp Environment, Vagrant will completely
|
|
|
|
# erase the local data dotfile and you can lose state after the
|
|
|
|
# validate command completes.
|
|
|
|
tmp_data_dir = Dir.mktmpdir("vagrant-validate-")
|
|
|
|
@env = Vagrant::Environment.new(
|
|
|
|
cwd: @env.cwd,
|
|
|
|
home_path: @env.home_path,
|
|
|
|
ui_class: @env.ui_class,
|
|
|
|
vagrantfile_name: @env.vagrantfile_name,
|
|
|
|
local_data_path: tmp_data_dir,
|
|
|
|
data_dir: tmp_data_dir
|
|
|
|
)
|
|
|
|
|
|
|
|
Vagrant.plugin("2").manager.providers.each do |key, data|
|
|
|
|
data[0].class_eval do
|
|
|
|
def initialize(machine)
|
|
|
|
end
|
|
|
|
|
|
|
|
def machine_id_changed
|
|
|
|
end
|
|
|
|
|
|
|
|
def self.installed?
|
|
|
|
true
|
|
|
|
end
|
|
|
|
|
|
|
|
def self.usable?(raise_error=false)
|
|
|
|
true
|
|
|
|
end
|
|
|
|
|
|
|
|
def state
|
|
|
|
state_id = Vagrant::MachineState::NOT_CREATED_ID
|
|
|
|
short = :not_created
|
|
|
|
long = :not_created
|
|
|
|
Vagrant::MachineState.new(state_id, short, long)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2018-12-03 22:45:26 +00:00
|
|
|
tmp_data_dir
|
2018-11-29 21:29:46 +00:00
|
|
|
end
|
2017-02-07 05:43:49 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|