/vagrant-puppet-install

A Vagrant plugin that ensures the desired version of Puppet is installed via the Puppet Labs package repo.

Primary LanguageRubyApache License 2.0Apache-2.0

vagrant-puppet-install

Gem Version Build Status Dependency Status Code Climate

A Vagrant plugin that ensures the desired version of Puppet is installed via the Puppet Labs package repo. This proves very useful when using Vagrant with provisioner-less baseboxes OR cloud images.

This plugin has been verified to work with the following Vagrant providers:

It may work with other Vagrant providers but is not guaranteed to!

Installation

Ensure you have downloaded and installed Vagrant 1.1.x from the Vagrant downloads page.

Installation is performed in the prescribed manner for Vagrant 1.1 plugins.

$ vagrant plugin install vagrant-puppet-install

Usage

The Puppet Install Vagrant plugin automatically hooks into the Vagrant provisioning middleware. You specify the version of the puppet-common package you want installed using the puppet_install.version config key. The version string should be a valid Puppet release (ie. 2.7.11, 3.0.*, etc.).

Install the latest version of Puppet:

Vagrant.configure("2") do |config|

  config.puppet_install.version = "*"

  ...

end

Install a specific version of Puppet:

Vagrant.configure("2") do |config|

  config.puppet_install.version = "2.7.11"

  ...

end

Tests

Unit

The unit tests can be run with:

rake test:unit

The test are also executed by Travis CI every time code is pushed to GitHub.

Acceptance

Currently this repo ships with a set of basic acceptance tests that will:

  • Provision a Vagrant instance.
  • Attempt to install Chef 11.4.0 using this plugin.
  • Perform a very basic chef-solo run to ensure Chef is in fact installed.

The acceptance tests are run against the Vagrant providers mentioned above. The acceptance tests can be run with:

rake test:acceptance

And as expected, all acceptance tests only uses provisioner-less baseboxes and cloud images!

Contributing

  1. Fork it
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create new Pull Request

Authors

Seth Chisamore (schisamo@opscode.com)