2013-12-04 18:50:19 +00:00
|
|
|
require "json"
|
|
|
|
require "pathname"
|
|
|
|
|
|
|
|
require File.expand_path("../../../../base", __FILE__)
|
|
|
|
|
|
|
|
describe VagrantPlugins::CommandPlugin::StateFile do
|
|
|
|
let(:path) do
|
|
|
|
f = Tempfile.new("vagrant")
|
|
|
|
p = f.path
|
|
|
|
f.close
|
|
|
|
f.unlink
|
|
|
|
Pathname.new(p)
|
|
|
|
end
|
|
|
|
|
|
|
|
after do
|
|
|
|
path.unlink if path.file?
|
|
|
|
end
|
|
|
|
|
|
|
|
subject { described_class.new(path) }
|
|
|
|
|
2013-12-04 19:17:48 +00:00
|
|
|
context "new usage" do
|
|
|
|
it "should have no plugins without saving some" do
|
|
|
|
expect(subject.installed_plugins).to be_empty
|
|
|
|
end
|
2013-12-04 18:50:19 +00:00
|
|
|
|
2013-12-04 19:17:48 +00:00
|
|
|
it "should have plugins when saving" do
|
|
|
|
subject.add_plugin("foo")
|
2013-12-04 18:50:19 +00:00
|
|
|
|
2013-12-04 19:17:48 +00:00
|
|
|
instance = described_class.new(path)
|
|
|
|
plugins = instance.installed_plugins
|
|
|
|
expect(plugins.length).to eql(1)
|
2013-12-04 19:43:39 +00:00
|
|
|
expect(plugins["foo"]).to eql({
|
|
|
|
"ruby_version" => RUBY_VERSION,
|
|
|
|
"vagrant_version" => Vagrant::VERSION,
|
|
|
|
})
|
2013-12-04 19:17:48 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
it "should remove plugins" do
|
|
|
|
subject.add_plugin("foo")
|
|
|
|
subject.remove_plugin("foo")
|
2013-12-04 18:50:19 +00:00
|
|
|
|
2013-12-04 19:17:48 +00:00
|
|
|
instance = described_class.new(path)
|
|
|
|
expect(instance.installed_plugins).to be_empty
|
|
|
|
end
|
2013-12-04 18:50:19 +00:00
|
|
|
|
2013-12-04 19:17:48 +00:00
|
|
|
it "should store plugins uniquely" do
|
|
|
|
subject.add_plugin("foo")
|
|
|
|
subject.add_plugin("foo")
|
|
|
|
|
|
|
|
instance = described_class.new(path)
|
|
|
|
expect(instance.installed_plugins.keys).to eql(["foo"])
|
|
|
|
end
|
2013-12-04 18:50:19 +00:00
|
|
|
end
|
|
|
|
|
2013-12-04 19:17:48 +00:00
|
|
|
context "with an old-style file" do
|
|
|
|
before do
|
|
|
|
data = {
|
|
|
|
"installed" => ["foo"],
|
|
|
|
}
|
|
|
|
|
|
|
|
path.open("w+") do |f|
|
|
|
|
f.write(JSON.dump(data))
|
|
|
|
end
|
|
|
|
end
|
2013-12-04 18:50:19 +00:00
|
|
|
|
2013-12-04 19:17:48 +00:00
|
|
|
it "should have the right installed plugins" do
|
2013-12-04 19:29:17 +00:00
|
|
|
plugins = subject.installed_plugins
|
|
|
|
expect(plugins.keys).to eql(["foo"])
|
2013-12-04 19:43:39 +00:00
|
|
|
expect(plugins["foo"]["ruby_version"]).to eql("0")
|
2013-12-04 19:29:17 +00:00
|
|
|
expect(plugins["foo"]["vagrant_version"]).to eql("0")
|
2013-12-04 19:17:48 +00:00
|
|
|
end
|
2013-12-04 18:50:19 +00:00
|
|
|
end
|
2013-12-20 09:54:10 +00:00
|
|
|
|
|
|
|
context "with parse errors" do
|
|
|
|
before do
|
|
|
|
path.open("w+") do |f|
|
|
|
|
f.write("I'm not json")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should raise a VagrantError" do
|
|
|
|
expect { subject }.
|
|
|
|
to raise_error(Vagrant::Errors::PluginStateFileParseError)
|
|
|
|
end
|
|
|
|
end
|
2013-12-04 18:50:19 +00:00
|
|
|
end
|