This workspace is being developed alongside a series of blog posts on badgerops.net. While it can be used as a stand alone framework, there will (hopefully!) be good value in following along with the blog series.
The following information should get you up and running on either OS X, Windows or Linux.
-
Install dependencies
a. Install Virtualbox
b. Install Vagrant
- install vagrant plugin:
vagrant plugin install vagrant-hostmanager
c. Install Docker for Mac
d. Ensure Git is installed Download Git. If already installed via xcode tools, you should be ready to go.
e. ensure Homebrew is installed Homebrew website
f. Ensure pyaml is installed:
brew install libyaml sudo python -m easy_install pyyaml
-
Clone the repo, build the project and run the tests (may take a while for the first time). DO NOT move on until dependencies are resolved.
docker-machine start eval $(docker-machine env ) git clone https://github.com/BadgerOps/salt-workspace.git cd salt-workspace make make test
- if make test fails, its most likely because pyyaml is not installed
(I don't use windows, but this should work)
-
Install dependencies
a. Install Virtualbox
b. Install Vagrant- install vagrant plugin:
vagrant plugin install vagrant-hostmanager
c. Install boot2docker
d. Install Download Git
When you install Git, you have the option to add Git and its Linux-style command line tools to your system Path. Do this!
Select the Advanced context menu (git-cheetah plugin)
Select "Use Git and optional Unix tools from the Windows Command Prompt"
Select "Checkout Windows-style, commit Unix-style line endings"
For convenience you’ll want to set up an elevated command prompt shortcut. - Create New Shortcut to : %windir%\system32\cmd.exe - Under the security tab confirm that it "Runs as Admin"
-
Setup boot2docker, clone the repo, build the project and run the tests (may take a while for the first time)
boot2docker init boot2docker start boot2docker status # this should say "running" git clone https://github.com/BadgerOps/salt-workspace.git cd salt-workspace
Prior to testing your changes, make sure you build the project first. Vagrant will only expose the ./dist directory to the saltmaster's /srv directory. Running the command 'make' in the root directory should build the entire project for you.
Make sure you re-run make after each local change or it will not be reflected in the virtual environment.
This can be automated on your development machine using various tools such as Watchman. They will monitor your directory for changes and automatically run the make command for you.
Because development environment differ, this is not included in this repository.
The Linux test hosts default to RHEL 7.x. If you want to test RHEL 6.x, set your environment variable LINUX_VERSION to 6: export LINUX_VERSION=6
- Launch the saltmaster and linux hosts
vagrant up
. This may take a while when running for the very first time because the VM needs to be downloaded. Ensure that you're on a fast internet connection. - Log into the test Linux host
vagrant ssh linux-1
. Here you can runsudo su -
to become root. No password is required. (if prompted, it will be the vagrant default 'vagrant') - A highstate should get invoked during provisioning. To re-run a highstate, invoke
sudo salt-call state.highstate
from within the test VM. - To test a specific role, add a role to the grains file in
/etc/salt/grains
and re-run a highstate. For example, to test the role foo_bar, edit the grains file to match the following snippet.
roles:
- foo_bar
If testing a role/formula that requires multiple minions, you can increase the linux minion count by setting the LINUX_MINION_COUNT environment variable before running vagrant up. See below as an example.
export LINUX_MINION_COUNT=3
vagrant up /linux/
You should now have a linux-1, linux-2, and linux-3 machine.
Some minions may require more than the default memory of 512MB. You may increase this before running vagrant up. The following example uses 1GB of memory per minion.
export LINUX_BOX_RAM=1024
vagrant up
- Launch the saltmaster and windows hosts
vagrant up saltmaster
,vagrant up windows
. This may take a while when running for the very first time because the VM needs to be downloaded. Ensure that you are on a fast internet connection. - Log into the test Windows host
vagrant rdp windows
. The username is Administrator and password is vagrant all lower case. - A highstate should get invoked during provisioning. To re-run a highstate, invoke
c:\salt-call.bat state.highstate
from within a terminal. - To test a specific role, add a role to the grains file in c:\salt\conf\grains and re-run a highstate. For example, to test the role foo_bar, edit the grains file to match the following snippet.
roles:
- foo_bar
Use the following workflow to submit a new feature or bug fix.
- Fork the repository
- Clone the repository.
- Ensure your user information is correct.
- Create a new branch locally.
- Make your changes and commit locally.
- Push the changes to Stash to the new branch.
- Submit a pull request.
Below is an example of steps 2-5 - you'll want to fork the repository to your own github profile first.
git clone https://github.com/john_doe/salt-workspace.git
cd salt-workspace
git config user.name "Doe, John"
git config user.email [email protected]
git checkout -b feature/some-new-feature
# Make your changes.
vim ./path/to/file.sls
# Commit your changes locally.
git add ./poth/to/file.sls
git commit -m 'Making a change to file.sls for reason foo'
# Push your changes to the Git server.
git push --set-upstream origin feature/some-new-feature
When you create a branch - You branch from a parent. You generally want the parent to always be an updated master. Thus before making any new branches or changes - you want to obtain an updated master. If you were to attempt to make a new branch with out running the following commands after doing the git push you would be creating a new branch that has a parent of the previous branch you just pushed.
git checkout master
git fetch
git pull origin master
git checkout -b feature/some-new-feature
See Daniel Miessler's git Primer for more help with using Git.
It's possible to encrypt pillar values using the GPG renderer. This is highly advised for any sensitive information such as passwords and SSL keys.
You'll need to first install GnuPG. Once installed, you can create and import the Salt key with the following command.
You can then follow this guide to create your GPG key, the following steps assume the name is 'Salt Master'
gpg --import salt_key.asc
You can encrypt a new password with the following command where 'mysecret' without quotes is your secret value.
echo -n 'mysecret' | gpg --armor --encrypt -r 'Salt Master'
Once you have this text, you can add to Pillar. Any pillar file must have the string '#!yaml|gpg' without quotes at the top in order for the GPG renderer to kick in.
When the pillar file is rendered, it will get decrypted on the master and your minion will receive the plain text value.