vagrant-lxc 0.1.1 → 0.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/CHANGELOG.md +6 -2
- data/Gemfile.lock +1 -1
- data/README.md +6 -5
- data/boxes/quantal64/lxc-template +4 -2
- data/boxes/quantal64/metadata.json +2 -2
- data/development/Vagrantfile +7 -4
- data/example/Vagrantfile +10 -4
- data/example/cookbooks/hello-world/recipes/default.rb +4 -0
- data/lib/vagrant-lxc/action.rb +21 -4
- data/lib/vagrant-lxc/action/compress_rootfs.rb +30 -0
- data/lib/vagrant-lxc/action/handle_box_metadata.rb +2 -1
- data/lib/vagrant-lxc/action/setup_package_files.rb +52 -0
- data/lib/vagrant-lxc/container.rb +20 -0
- data/lib/vagrant-lxc/version.rb +1 -1
- data/locales/en.yml +2 -0
- data/spec/unit/action/compress_rootfs_spec.rb +27 -0
- data/spec/unit/action/handle_box_metadata_spec.rb +1 -1
- data/spec/unit/action/setup_package_files_spec.rb +41 -0
- metadata +9 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 186bdb083beeef3921bd1365defc643f73ee384e
|
4
|
+
data.tar.gz: 493eaf050cd7c208af7098ed3f0d6a4ecd3b508f
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 1efa2adc9cce87eca8a4fa1878f019cecb0834ec347f0ec5fed463fed8a5dd50f63792d72928d2ba34fecc9ee908190d6a3119551987158bba47d68444e7dc95
|
7
|
+
data.tar.gz: 080dde3c3857967619f7b1033e379d9c8e0c340e6128b7d53edcd2a89b71b496fefbe4f525c7c6874ee1978c207f054777da6bf7e9f13234c4fb0beedb6a9b4a
|
data/CHANGELOG.md
CHANGED
@@ -1,4 +1,8 @@
|
|
1
|
-
## [0.
|
1
|
+
## [0.2.0](https://github.com/fgrehm/vagrant-lxc/compare/v0.1.1...v0.2.0)
|
2
|
+
|
3
|
+
- Experimental box packaging (only tested with Ubuntu 64 base box)
|
4
|
+
|
5
|
+
## [0.1.1](https://github.com/fgrehm/vagrant-lxc/compare/v0.1.0...v0.1.1)
|
2
6
|
|
3
7
|
- Removed support for development under Vagrant < 1.1
|
4
8
|
- Removed rsync from base quantal64 box to speed up containers creation [#40](https://github.com/fgrehm/vagrant-lxc/issues/40)
|
@@ -6,7 +10,7 @@
|
|
6
10
|
- Skip Vagrant's built in SSH redirect
|
7
11
|
- Allow setting rootfs from Vagrantfile [#30](https://github.com/fgrehm/vagrant-lxc/issues/30)
|
8
12
|
|
9
|
-
## 0.1.0
|
13
|
+
## [0.1.0](https://github.com/fgrehm/vagrant-lxc/compare/v0.0.3...v0.1.0)
|
10
14
|
|
11
15
|
- Support for chef added to base quantal64 box
|
12
16
|
- Puppet upgraded to 3.1.1 on base quantal64 box
|
data/Gemfile.lock
CHANGED
data/README.md
CHANGED
@@ -16,9 +16,11 @@ sudo dpkg -i /tmp/vagrant.deb
|
|
16
16
|
```
|
17
17
|
|
18
18
|
|
19
|
-
## What is currently supported? (v0.
|
19
|
+
## What is currently supported? (v0.2.0)
|
20
20
|
|
21
|
-
|
21
|
+
Pretty much everything you need from Vagrant:
|
22
|
+
|
23
|
+
* Vagrant's `up`, `halt`, `reload`, `destroy`, `ssh` and `package` commands (box packaging is kind of experimental)
|
22
24
|
* Shared folders
|
23
25
|
* Provisioning
|
24
26
|
* Setting container's host name
|
@@ -32,8 +34,7 @@ for the most up to date list.*
|
|
32
34
|
|
33
35
|
* Does not detect forwarded ports collision, right now you are responsible for taking care of that
|
34
36
|
* A hell lot of `sudo`s
|
35
|
-
* Only a [single ubuntu box supported](boxes)
|
36
|
-
on the .box file](https://github.com/fgrehm/vagrant-lxc/issues/4)
|
37
|
+
* Only a [single ubuntu box supported](boxes)
|
37
38
|
* "[works on my machine](https://github.com/fgrehm/vagrant-lxc/issues/20)" (TM)
|
38
39
|
* [Does not tell you if dependencies are not met](https://github.com/fgrehm/vagrant-lxc/issues/11)
|
39
40
|
(will probably just throw up some random error)
|
@@ -54,7 +55,7 @@ After that you can create a `Vagrantfile` like the one below and run `vagrant up
|
|
54
55
|
```ruby
|
55
56
|
Vagrant.configure("2") do |config|
|
56
57
|
config.vm.box = "lxc-quantal64"
|
57
|
-
config.vm.box_url = 'http://dl.dropbox.com/u/13510779/lxc-quantal64-2013-03-
|
58
|
+
config.vm.box_url = 'http://dl.dropbox.com/u/13510779/lxc-quantal64-2013-03-31.box'
|
58
59
|
|
59
60
|
# Share an additional folder to the guest Container. The first argument
|
60
61
|
# is the path on the host to the actual folder. The second argument is
|
@@ -78,8 +78,10 @@ EOF
|
|
78
78
|
rm -f $rootfs/etc/init/tty{5,6}.conf
|
79
79
|
fi
|
80
80
|
|
81
|
-
|
82
|
-
|
81
|
+
if ! (grep -q vagrant $rootfs/etc/passwd); then
|
82
|
+
chroot $rootfs useradd --create-home -s /bin/bash vagrant
|
83
|
+
echo "vagrant:vagrant" | chroot $rootfs chpasswd
|
84
|
+
fi
|
83
85
|
|
84
86
|
return 0
|
85
87
|
}
|
data/development/Vagrantfile
CHANGED
@@ -21,18 +21,19 @@ def local_gem_cache(box_name)
|
|
21
21
|
cache_dir
|
22
22
|
end
|
23
23
|
|
24
|
+
# Required to make sure vagrant picks it up during development
|
24
25
|
Vagrant.require_plugin 'vagrant-lxc'
|
25
26
|
|
26
27
|
Vagrant.configure("2") do |config|
|
27
28
|
config.vm.box = "quantal64"
|
28
29
|
|
29
|
-
config.vm.synced_folder "../", "/vagrant",
|
30
|
+
config.vm.synced_folder "../", "/vagrant", id: 'vagrant-root'
|
30
31
|
|
31
32
|
cache_dir = local_apt_cache(config.vm.box)
|
32
|
-
config.vm.synced_folder cache_dir, "/var/cache/apt/archives",
|
33
|
+
config.vm.synced_folder cache_dir, "/var/cache/apt/archives", id: "vagrant-apt-cache"
|
33
34
|
|
34
35
|
cache_dir = local_gem_cache(config.vm.box)
|
35
|
-
config.vm.synced_folder cache_dir, "/home/vagrant/gems/cache",
|
36
|
+
config.vm.synced_folder cache_dir, "/home/vagrant/gems/cache", id: "vagrant-gem-cache"
|
36
37
|
|
37
38
|
config.vm.define :vbox do |vb_config|
|
38
39
|
vb_config.vm.box_url = "https://github.com/downloads/roderik/VagrantQuantal64Box/quantal64.box"
|
@@ -50,13 +51,15 @@ Vagrant.configure("2") do |config|
|
|
50
51
|
|
51
52
|
config.vm.define :lxc do |lxc_config|
|
52
53
|
lxc_config.vm.hostname = 'lxc-dev-box'
|
54
|
+
lxc_config.vm.box_url = 'http://dl.dropbox.com/u/13510779/lxc-quantal64-2013-03-31.box'
|
53
55
|
# Uncomment to test boxes built locally:
|
54
56
|
# lxc_config.vm.box_url = '../boxes/output/lxc-quantal64.box'
|
55
|
-
lxc_config.vm.box_url = 'http://dl.dropbox.com/u/13510779/lxc-quantal64-2013-03-26.box'
|
56
57
|
|
57
58
|
lxc_config.vm.provider :lxc do |lxc|
|
58
59
|
# Required to boot nested containers
|
59
60
|
lxc.start_opts << 'lxc.aa_profile=unconfined'
|
61
|
+
# Change this to override the path where the rootfs gets stored
|
62
|
+
# lxc.target_rootfs_path = '/path/to/vagrant-lxc-dev-box-rootfs'
|
60
63
|
end
|
61
64
|
end
|
62
65
|
|
data/example/Vagrantfile
CHANGED
@@ -11,12 +11,15 @@ def local_cache(box_name)
|
|
11
11
|
cache_dir
|
12
12
|
end
|
13
13
|
|
14
|
+
# Not really needed, but useful while developing so that vagrant picks it up
|
14
15
|
Vagrant.require_plugin 'vagrant-lxc'
|
15
16
|
|
16
17
|
Vagrant.configure("2") do |config|
|
17
18
|
config.vm.box = "quantal64"
|
18
|
-
config.vm.box_url = 'http://dl.dropbox.com/u/13510779/lxc-quantal64-2013-03-
|
19
|
-
|
19
|
+
config.vm.box_url = 'http://dl.dropbox.com/u/13510779/lxc-quantal64-2013-03-31.box'
|
20
|
+
# Uncomment if you want to try out a box built locally
|
21
|
+
# config.vm.box_url = '../boxes/output/lxc-quantal64.box'
|
22
|
+
config.vm.hostname = 'lxc-quantal64-example'
|
20
23
|
|
21
24
|
config.vm.synced_folder "/tmp", "/vagrant_data"
|
22
25
|
|
@@ -36,7 +39,10 @@ echo "Hi there I'm a shell script used for provisioning"
|
|
36
39
|
puppet.module_path = "puppet/modules"
|
37
40
|
puppet.manifests_path = "puppet/manifests"
|
38
41
|
puppet.manifest_file = "site.pp"
|
39
|
-
|
40
|
-
|
42
|
+
end
|
43
|
+
|
44
|
+
config.vm.provision :chef_solo do |chef|
|
45
|
+
chef.add_recipe "hello-world"
|
46
|
+
chef.log_level = :debug
|
41
47
|
end
|
42
48
|
end
|
data/lib/vagrant-lxc/action.rb
CHANGED
@@ -10,11 +10,13 @@ require 'vagrant-lxc/action/create'
|
|
10
10
|
require 'vagrant-lxc/action/created'
|
11
11
|
require 'vagrant-lxc/action/destroy'
|
12
12
|
require 'vagrant-lxc/action/disconnect'
|
13
|
+
require 'vagrant-lxc/action/compress_rootfs'
|
13
14
|
require 'vagrant-lxc/action/forced_halt'
|
14
15
|
require 'vagrant-lxc/action/forward_ports'
|
15
16
|
require 'vagrant-lxc/action/handle_box_metadata'
|
16
17
|
require 'vagrant-lxc/action/is_running'
|
17
18
|
require 'vagrant-lxc/action/network'
|
19
|
+
require 'vagrant-lxc/action/setup_package_files'
|
18
20
|
require 'vagrant-lxc/action/share_folders'
|
19
21
|
|
20
22
|
module Vagrant
|
@@ -58,7 +60,6 @@ module Vagrant
|
|
58
60
|
b.use ShareFolders
|
59
61
|
b.use Network
|
60
62
|
b.use Vagrant::Action::Builtin::SetHostname
|
61
|
-
# b.use SaneDefaults
|
62
63
|
# b.use Customize
|
63
64
|
b.use ForwardPorts
|
64
65
|
b.use Boot
|
@@ -84,7 +85,6 @@ module Vagrant
|
|
84
85
|
next
|
85
86
|
end
|
86
87
|
|
87
|
-
# b3.use CheckAccessible
|
88
88
|
b3.use Vagrant::Action::Builtin::Provision
|
89
89
|
end
|
90
90
|
end
|
@@ -175,12 +175,30 @@ module Vagrant
|
|
175
175
|
end
|
176
176
|
end
|
177
177
|
|
178
|
+
# This action packages the virtual machine into a single box file.
|
179
|
+
def self.action_package
|
180
|
+
Vagrant::Action::Builder.new.tap do |b|
|
181
|
+
# b.use CheckDependencies
|
182
|
+
b.use Vagrant::Action::Builtin::Call, Created do |env1, b2|
|
183
|
+
if !env1[:result]
|
184
|
+
# TODO: Implement our own MessageNotCreated
|
185
|
+
b2.use VagrantPlugins::ProviderVirtualBox::Action::MessageNotCreated
|
186
|
+
next
|
187
|
+
end
|
188
|
+
|
189
|
+
b2.use action_halt
|
190
|
+
b2.use CompressRootFS
|
191
|
+
b2.use SetupPackageFiles
|
192
|
+
b2.use Vagrant::Action::General::Package
|
193
|
+
end
|
194
|
+
end
|
195
|
+
end
|
196
|
+
|
178
197
|
# This is the action that will exec into an SSH shell.
|
179
198
|
def self.action_ssh
|
180
199
|
Vagrant::Action::Builder.new.tap do |b|
|
181
200
|
# b.use CheckDependencies
|
182
201
|
b.use CheckCreated
|
183
|
-
# b.use CheckAccessible
|
184
202
|
b.use CheckRunning
|
185
203
|
b.use Vagrant::Action::Builtin::SSHExec
|
186
204
|
end
|
@@ -191,7 +209,6 @@ module Vagrant
|
|
191
209
|
Vagrant::Action::Builder.new.tap do |b|
|
192
210
|
# b.use CheckDependencies
|
193
211
|
b.use CheckCreated
|
194
|
-
# b.use CheckAccessible
|
195
212
|
b.use CheckRunning
|
196
213
|
b.use Vagrant::Action::Builtin::SSHRun
|
197
214
|
end
|
@@ -0,0 +1,30 @@
|
|
1
|
+
require "fileutils"
|
2
|
+
|
3
|
+
module Vagrant
|
4
|
+
module LXC
|
5
|
+
module Action
|
6
|
+
class CompressRootFS
|
7
|
+
def initialize(app, env)
|
8
|
+
@app = app
|
9
|
+
end
|
10
|
+
|
11
|
+
def call(env)
|
12
|
+
raise Vagrant::Errors::VMPowerOffToPackage if env[:machine].provider.state.id != :stopped
|
13
|
+
|
14
|
+
env[:ui].info I18n.t("vagrant.actions.lxc.compressing_rootfs")
|
15
|
+
@rootfs = env['package.rootfs'] = env[:machine].provider.container.compress_rootfs
|
16
|
+
|
17
|
+
@app.call env
|
18
|
+
|
19
|
+
recover # called to remove the rootfs tarball
|
20
|
+
end
|
21
|
+
|
22
|
+
def recover(*)
|
23
|
+
if @rootfs && File.exist?(@rootfs)
|
24
|
+
FileUtils.rm_rf(File.dirname @rootfs)
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
@@ -29,7 +29,8 @@ module Vagrant
|
|
29
29
|
system(%Q[sudo su root -c "cp #{lxc_template_src} #{dest}"])
|
30
30
|
|
31
31
|
@logger.debug('Extracting rootfs')
|
32
|
-
|
32
|
+
# TODO: Ideally the compressed rootfs should not output errors...
|
33
|
+
system(%Q[sudo su root -c "cd #{box.directory} && tar xfz rootfs.tar.gz -C #{rootfs_cache} 2>/dev/null"])
|
33
34
|
|
34
35
|
box.metadata.merge!(
|
35
36
|
'template-name' => template_name,
|
@@ -0,0 +1,52 @@
|
|
1
|
+
require 'fileutils'
|
2
|
+
|
3
|
+
module Vagrant
|
4
|
+
module LXC
|
5
|
+
module Action
|
6
|
+
class SetupPackageFiles
|
7
|
+
def initialize(app, env)
|
8
|
+
@app = app
|
9
|
+
|
10
|
+
env["package.include"] ||= []
|
11
|
+
env["package.vagrantfile"] ||= nil
|
12
|
+
end
|
13
|
+
|
14
|
+
def call(env)
|
15
|
+
@env = env
|
16
|
+
|
17
|
+
create_package_temp_dir
|
18
|
+
move_rootfs_to_pkg_dir
|
19
|
+
copy_box_files_to_pkg_dir
|
20
|
+
|
21
|
+
@app.call env
|
22
|
+
|
23
|
+
recover # called to cleanup temp directory
|
24
|
+
end
|
25
|
+
|
26
|
+
def recover(*)
|
27
|
+
if @temp_dir && File.exist?(@temp_dir)
|
28
|
+
FileUtils.rm_rf(@temp_dir)
|
29
|
+
end
|
30
|
+
end
|
31
|
+
|
32
|
+
private
|
33
|
+
|
34
|
+
def create_package_temp_dir
|
35
|
+
@env[:ui].info I18n.t("vagrant.actions.vm.export.create_dir")
|
36
|
+
@temp_dir = @env["package.directory"] = @env[:tmp_path].join("container-export-#{Time.now.to_i.to_s}")
|
37
|
+
FileUtils.mkpath(@temp_dir)
|
38
|
+
end
|
39
|
+
|
40
|
+
def move_rootfs_to_pkg_dir
|
41
|
+
FileUtils.mv @env['package.rootfs'].to_s, @env['package.directory'].to_s
|
42
|
+
end
|
43
|
+
|
44
|
+
def copy_box_files_to_pkg_dir
|
45
|
+
box_dir = @env[:machine].box.directory
|
46
|
+
FileUtils.cp box_dir.join('lxc-template').to_s, @env['package.directory'].to_s
|
47
|
+
FileUtils.cp box_dir.join('metadata.json').to_s, @env['package.directory'].to_s
|
48
|
+
end
|
49
|
+
end
|
50
|
+
end
|
51
|
+
end
|
52
|
+
end
|
@@ -93,6 +93,26 @@ module Vagrant
|
|
93
93
|
@cli.destroy
|
94
94
|
end
|
95
95
|
|
96
|
+
# TODO: This needs to be reviewed and specs needs to be written
|
97
|
+
def compress_rootfs
|
98
|
+
# TODO: Our template should not depend on container's arch
|
99
|
+
arch = base_path.join('config').read.match(/^lxc\.arch\s+=\s+(.+)$/)[1]
|
100
|
+
rootfs_dirname = File.dirname rootfs_path
|
101
|
+
basename = rootfs_path.to_s.gsub(/^#{Regexp.escape rootfs_dirname}\//, '')
|
102
|
+
# TODO: Pass in tmpdir so we can clean up from outside
|
103
|
+
target_path = "#{Dir.mktmpdir}/rootfs.tar.gz"
|
104
|
+
|
105
|
+
Dir.chdir base_path do
|
106
|
+
@logger.info "Compressing '#{rootfs_path}' rootfs to #{target_path}"
|
107
|
+
system "sudo rm -f rootfs.tar.gz && sudo bsdtar -s /#{basename}/rootfs-#{arch}/ --numeric-owner -czf #{target_path} #{basename}/* 2>/dev/null"
|
108
|
+
|
109
|
+
@logger.info "Changing rootfs tarbal owner"
|
110
|
+
system "sudo chown #{ENV['USER']}:#{ENV['USER']} #{target_path}"
|
111
|
+
end
|
112
|
+
|
113
|
+
target_path
|
114
|
+
end
|
115
|
+
|
96
116
|
def state
|
97
117
|
if @name
|
98
118
|
@cli.state
|
data/lib/vagrant-lxc/version.rb
CHANGED
data/locales/en.yml
CHANGED
@@ -0,0 +1,27 @@
|
|
1
|
+
require 'unit_helper'
|
2
|
+
|
3
|
+
require 'vagrant-lxc/action/compress_rootfs'
|
4
|
+
|
5
|
+
describe Vagrant::LXC::Action::CompressRootFS do
|
6
|
+
let(:app) { mock(:app, call: true) }
|
7
|
+
let(:env) { {machine: machine, ui: stub(info: true)} }
|
8
|
+
let(:machine) { fire_double('Vagrant::Machine', provider: provider) }
|
9
|
+
let(:provider) { fire_double('Vagrant::LXC::Provider', container: container) }
|
10
|
+
let(:container) { fire_double('Vagrant::LXC::Container', compress_rootfs: compressed_rootfs_path) }
|
11
|
+
let(:compressed_rootfs_path) { '/path/to/rootfs.tar.gz' }
|
12
|
+
|
13
|
+
subject { described_class.new(app, env) }
|
14
|
+
|
15
|
+
before do
|
16
|
+
provider.stub_chain(:state, :id).and_return(:stopped)
|
17
|
+
subject.call(env)
|
18
|
+
end
|
19
|
+
|
20
|
+
it 'asks the container to compress its rootfs' do
|
21
|
+
container.should have_received(:compress_rootfs)
|
22
|
+
end
|
23
|
+
|
24
|
+
it 'sets export.temp_dir on action env' do
|
25
|
+
env['package.rootfs'].should == compressed_rootfs_path
|
26
|
+
end
|
27
|
+
end
|
@@ -39,6 +39,6 @@ describe Vagrant::LXC::Action::HandleBoxMetadata do
|
|
39
39
|
|
40
40
|
it 'extracts rootfs into a tmp folder' do
|
41
41
|
subject.should have_received(:system).
|
42
|
-
with(%Q[sudo su root -c "cd #{box_directory} && tar xfz rootfs.tar.gz -C #{tmpdir}"])
|
42
|
+
with(%Q[sudo su root -c "cd #{box_directory} && tar xfz rootfs.tar.gz -C #{tmpdir} 2>/dev/null"])
|
43
43
|
end
|
44
44
|
end
|
@@ -0,0 +1,41 @@
|
|
1
|
+
require 'unit_helper'
|
2
|
+
|
3
|
+
require 'vagrant-lxc/action/setup_package_files'
|
4
|
+
|
5
|
+
describe Vagrant::LXC::Action::SetupPackageFiles do
|
6
|
+
let(:app) { mock(:app, call: true) }
|
7
|
+
let(:env) { {machine: machine, tmp_path: tmp_path, ui: stub(info: true), 'package.rootfs' => rootfs_path} }
|
8
|
+
let(:machine) { fire_double('Vagrant::Machine', box: box) }
|
9
|
+
let!(:tmp_path) { Pathname.new(Dir.mktmpdir) }
|
10
|
+
let(:box) { fire_double('Vagrant::Box', directory: tmp_path.join('box')) }
|
11
|
+
let(:rootfs_path) { tmp_path.join('rootfs-amd64.tar.gz') }
|
12
|
+
|
13
|
+
subject { described_class.new(app, env) }
|
14
|
+
|
15
|
+
before do
|
16
|
+
box.directory.mkdir
|
17
|
+
[box.directory.join('lxc-template'), box.directory.join('metadata.json'), rootfs_path].each do |file|
|
18
|
+
file.open('w') { |f| f.puts file.to_s }
|
19
|
+
end
|
20
|
+
|
21
|
+
subject.stub(recover: true) # Prevents files from being removed on specs
|
22
|
+
subject.call(env)
|
23
|
+
end
|
24
|
+
|
25
|
+
after do
|
26
|
+
FileUtils.rm_rf(tmp_path.to_s)
|
27
|
+
end
|
28
|
+
|
29
|
+
it 'copies box lxc-template to package directory' do
|
30
|
+
env['package.directory'].join('lxc-template').should be_file
|
31
|
+
end
|
32
|
+
|
33
|
+
it 'copies metadata.json to package directory' do
|
34
|
+
env['package.directory'].join('metadata.json').should be_file
|
35
|
+
end
|
36
|
+
|
37
|
+
it 'moves the compressed rootfs to package directory' do
|
38
|
+
env['package.directory'].join(rootfs_path.basename).should be_file
|
39
|
+
env['package.rootfs'].should_not be_file
|
40
|
+
end
|
41
|
+
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: vagrant-lxc
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.2.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Fabio Rehm
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2013-03-
|
11
|
+
date: 2013-03-31 00:00:00.000000000 Z
|
12
12
|
dependencies: []
|
13
13
|
description: Linux Containers provider for Vagrant
|
14
14
|
email:
|
@@ -37,6 +37,7 @@ files:
|
|
37
37
|
- development/shell-provisioning/upgrade-kernel
|
38
38
|
- development/site.pp
|
39
39
|
- example/Vagrantfile
|
40
|
+
- example/cookbooks/hello-world/recipes/default.rb
|
40
41
|
- example/puppet/manifests/site.pp
|
41
42
|
- example/puppet/modules/hello_world/manifests/init.pp
|
42
43
|
- lib/vagrant-lxc.rb
|
@@ -46,6 +47,7 @@ files:
|
|
46
47
|
- lib/vagrant-lxc/action/check_created.rb
|
47
48
|
- lib/vagrant-lxc/action/check_running.rb
|
48
49
|
- lib/vagrant-lxc/action/clear_forwarded_ports.rb
|
50
|
+
- lib/vagrant-lxc/action/compress_rootfs.rb
|
49
51
|
- lib/vagrant-lxc/action/create.rb
|
50
52
|
- lib/vagrant-lxc/action/created.rb
|
51
53
|
- lib/vagrant-lxc/action/destroy.rb
|
@@ -55,6 +57,7 @@ files:
|
|
55
57
|
- lib/vagrant-lxc/action/handle_box_metadata.rb
|
56
58
|
- lib/vagrant-lxc/action/is_running.rb
|
57
59
|
- lib/vagrant-lxc/action/network.rb
|
60
|
+
- lib/vagrant-lxc/action/setup_package_files.rb
|
58
61
|
- lib/vagrant-lxc/action/share_folders.rb
|
59
62
|
- lib/vagrant-lxc/config.rb
|
60
63
|
- lib/vagrant-lxc/container.rb
|
@@ -69,8 +72,10 @@ files:
|
|
69
72
|
- spec/spec_helper.rb
|
70
73
|
- spec/support/unit_example_group.rb
|
71
74
|
- spec/unit/action/clear_forwarded_ports_spec.rb
|
75
|
+
- spec/unit/action/compress_rootfs_spec.rb
|
72
76
|
- spec/unit/action/forward_ports_spec.rb
|
73
77
|
- spec/unit/action/handle_box_metadata_spec.rb
|
78
|
+
- spec/unit/action/setup_package_files_spec.rb
|
74
79
|
- spec/unit/container/cli_spec.rb
|
75
80
|
- spec/unit/container_spec.rb
|
76
81
|
- spec/unit/machine_state_spec.rb
|
@@ -106,8 +111,10 @@ test_files:
|
|
106
111
|
- spec/spec_helper.rb
|
107
112
|
- spec/support/unit_example_group.rb
|
108
113
|
- spec/unit/action/clear_forwarded_ports_spec.rb
|
114
|
+
- spec/unit/action/compress_rootfs_spec.rb
|
109
115
|
- spec/unit/action/forward_ports_spec.rb
|
110
116
|
- spec/unit/action/handle_box_metadata_spec.rb
|
117
|
+
- spec/unit/action/setup_package_files_spec.rb
|
111
118
|
- spec/unit/container/cli_spec.rb
|
112
119
|
- spec/unit/container_spec.rb
|
113
120
|
- spec/unit/machine_state_spec.rb
|