diff --git a/.kitchen.yml b/.kitchen.yml index 31b01e2..c02f1e3 100644 --- a/.kitchen.yml +++ b/.kitchen.yml @@ -36,8 +36,12 @@ platforms: suites : - name : simple provisioner : - script : <%= File.dirname(__FILE__) %>/test/integration/simple/run_as_kitchen.sh + script : test/integration/simple/run_as_kitchen.sh - name : advanced provisioner : script : test/integration/advanced/run_as_kitchen.sh + + - name : cli + provisioner : + script : test/integration/cli/run_as_kitchen.sh \ No newline at end of file diff --git a/setup.sh b/setup.sh index 66b4aa6..61361ae 100755 --- a/setup.sh +++ b/setup.sh @@ -1,24 +1,6 @@ #!/bin/sh set -e -## First thing what kind of shell are we running. It turns out that is not so easy to find -## Really unreliable and should be changed :( -shell_path="$(ps -o comm= $$ | tr -d "-" | head -1)" # Get this process name -if ! [ -f "${shell_path}" ]; then shell_path="/bin/${shell_path}"; fi # assume it is in /bin if not full path -shell_help="$(${shell_path} --help 2>&1 | head -1)" # just get help screen -if echo "${shell_help}" | grep bash > /dev/null 2>&1; then - SHELL_TYPE="bash" -elif echo "${shell_help}" | grep zsh > /dev/null 2>&1; then - SHELL_TYPE="zsh" -elif echo "${shell_help}" | grep BusyBox > /dev/null 2>&1; then - SHELL_TYPE="BusyBox" -elif echo "${shell_help}" | grep Illegal > /dev/null 2>&1 && readlink "${shell_path}" | grep "dash"; then - SHELL_TYPE="dash" -else - echo "**** WARNING I HAVE NO IDEA WHAT KIND OF SHELL YOU ARE RUNNNING ****" - echo "**** Might not work. Probably will not if it does let me know :)****" -fi - ## default variable MSG_STATUS="0" avm_dir="" @@ -228,9 +210,6 @@ manage_git(){ eval "${4}=${source_git_dir}/${package_name}" } -## Good to know what shell -print_verbose "AVM run using shell=${SHELL_TYPE}" - # AVM version to install. Supports git releases (default to master) # if set to "local" will use pwd good for debuging and CI AVM_VERSION="${AVM_VERSION-master}" diff --git a/test/integration/cli/install.sh b/test/integration/cli/install.sh new file mode 100755 index 0000000..482d416 --- /dev/null +++ b/test/integration/cli/install.sh @@ -0,0 +1,36 @@ +#!/bin/bash +set -e + +echo "Running advanced.sh" +TEST_SHELL="${TEST_SHELL-/bin/sh}" + +if [ -f /etc/redhat-release ]; then + yum update +fi + +if [ -f /etc/lsb-release ]; then + sudo apt-get -y install git +fi + +## Setup config +export SETUP_USER=kitchen +# don't clone use local path +export AVM_VERSION="local" +export AVM_VERBOSE="v" + +## Link dir .avm/.source_git/ since we are running local +mkdir -p /home/${SETUP_USER}/.avm/.source_git/ +ln -sfn /avm /home/${SETUP_USER}/.avm/.source_git/ + +## Run the setup +${TEST_SHELL} /avm/setup.sh + +## Run installation +printf "\nRunning avm install cli (1)\n" +/usr/local/bin/avm install -v 2.0.2.0 -l v2.0 -r /avm/test/integration/cli/requirements.txt + +printf "\nRunning avm install cli (2)\n" +/usr/local/bin/avm install -v 2.1.1.0 -l v2.1 -t pip + +printf "\nRunning avm install cli (3)\n" +/usr/local/bin/avm install --version devel --label devel --requirements /avm/test/integration/cli/requirements.txt -t git diff --git a/test/integration/cli/requirements.txt b/test/integration/cli/requirements.txt new file mode 100644 index 0000000..511ab49 --- /dev/null +++ b/test/integration/cli/requirements.txt @@ -0,0 +1,2 @@ +# AWS python boto +boto3 \ No newline at end of file diff --git a/test/integration/cli/run_as_kitchen.sh b/test/integration/cli/run_as_kitchen.sh new file mode 100755 index 0000000..87d4f96 --- /dev/null +++ b/test/integration/cli/run_as_kitchen.sh @@ -0,0 +1,9 @@ +#!/bin/bash + +if [ -f /etc/lsb-release ]; then + # travis issue :( + sudo locale-gen en_US.UTF-8 +fi + +echo "Installing" +sudo su -c /avm/test/integration/cli/install.sh kitchen diff --git a/test/integration/cli/serverspec/ansible_spec.rb b/test/integration/cli/serverspec/ansible_spec.rb new file mode 100644 index 0000000..631da1d --- /dev/null +++ b/test/integration/cli/serverspec/ansible_spec.rb @@ -0,0 +1,48 @@ +require_relative '../../helper_spec.rb' + +context 'Ansible binaries' do + describe command 'command -v ansible' do + it 'executes ansible' do + expect(subject.exit_status).to eq 0 + end + end + + describe command 'command -v ansible-playbook' do + it 'executes ansible-playbook' do + expect(subject.exit_status).to eq 0 + end + end + + describe command 'command -v ansible-doc' do + it 'executes ansible-doc' do + expect(subject.exit_status).to eq 0 + end + end + + describe command 'command -v ansible-galaxy' do + it 'executes ansible-galaxy' do + expect(subject.exit_status).to eq 0 + end + end + + describe command 'command -v ansible-pull' do + it 'executes ansible-pull' do + expect(subject.exit_status).to eq 0 + end + end + + describe command 'command -v ansible-vault' do + it 'executes ansible-vault' do + expect(subject.exit_status).to eq 0 + end + end + + # describe command 'command -v ansible-console' do + # let(:pre_command) { 'avm use v2.1' } + # it 'executes ansible-console' do + # expect(subject.exit_status).to eq 0 + # end + # end + +end + diff --git a/test/integration/cli/serverspec/avm_activate_spec.rb b/test/integration/cli/serverspec/avm_activate_spec.rb new file mode 100644 index 0000000..284a1ed --- /dev/null +++ b/test/integration/cli/serverspec/avm_activate_spec.rb @@ -0,0 +1,18 @@ +require_relative '../../helper_spec.rb' + +context 'AVM activate' do + describe command 'avm activate' do + it 'prints arguments' do + expect(subject.exit_status).to eq 1 + expect(subject.stdout).to match('argument') + end + end + + describe command 'avm activate xxxx' do + it 'pints installed version' do + expect(subject.exit_status).to eq 1 + expect(subject.stdout).to match('available') + end + end + +end diff --git a/test/integration/cli/serverspec/avm_spec.rb b/test/integration/cli/serverspec/avm_spec.rb new file mode 100644 index 0000000..07a0da0 --- /dev/null +++ b/test/integration/cli/serverspec/avm_spec.rb @@ -0,0 +1,79 @@ +require_relative '../../helper_spec.rb' + +context 'AVM commands' do + describe command 'command -v avm' do + it 'executes avm' do + expect(subject.exit_status).to eq 0 + end + end + + describe command 'avm' do + it 'no args prints usage' do + expect(subject.exit_status).to eq 0 + expect(subject.stdout).to match('Usage') + end + end + + describe command 'command -v ansible-vault' do + it 'executes ansible-vault' do + expect(subject.exit_status).to eq 0 + end + end +end + +context 'AVM Manage' do + + describe command 'avm installed' do + let(:pre_command) { 'avm use v2.1' } + it 'shows version v2.1' do + expect(subject.exit_status).to eq 0 + expect(subject.stdout).to match('v2.1') + end + end + + describe command 'avm list' do + it 'show installed version' do + expect(subject.exit_status).to eq 0 + expect(subject.stdout).to match("installed versions: '2.0.2.0' '2.1.1.0' 'devel' 'v2.0' 'v2.1'") + end + end + + describe command 'avm info' do + let(:pre_command) { 'avm use v2.0' } + it 'use v2.0' do + expect(subject.exit_status).to eq 0 + expect(subject.stdout).to match('v2.0') + end + end + + describe command 'ansible --version' do + let(:pre_command) { 'avm use v2.0' } + it 'version is set 2.0' do + expect(subject.exit_status).to eq 0 + expect(subject.stdout).to match('ansible 2.0') + end + end + + describe command 'avm info' do + let(:pre_command) { 'avm use v2.0' } + it 'use v1' do + expect(subject.exit_status).to eq 0 + expect(subject.stdout).to match('v2.0') + end + end + + describe command 'avm path v2.0' do + it 'print the correct v2.0 path ' do + expect(subject.exit_status).to eq 0 + expect(subject.stdout).to match('/home/kitchen/.avm/v2.0/venv/bin/') + end + end + + describe command 'avm path v2.1' do + it 'print the correct v2.1 path ' do + expect(subject.exit_status).to eq 0 + expect(subject.stdout).to match('/home/kitchen/.avm/v2.1/venv/bin/') + end + end + +end diff --git a/test/integration/cli/serverspec/directory_spec.rb b/test/integration/cli/serverspec/directory_spec.rb new file mode 100644 index 0000000..61b75b9 --- /dev/null +++ b/test/integration/cli/serverspec/directory_spec.rb @@ -0,0 +1,62 @@ +require_relative '../../helper_spec.rb' + +context 'Directory stucture for V2.0' do + + describe command '/home/kitchen/.avm/v2.0/venv/bin/python -c "import boto3"' do + it 'does have boto installed' do + expect(subject.exit_status).to eq 0 + end + end + + describe file('/home/kitchen/.avm/v2.0/ansible/.git') do + it 'does not have .git' do + should_not exist + end + end +end + +context 'Directory stucture for V2.1' do + describe command '/home/kitchen/.avm/v2.1/venv/bin/python -c "import boto3"' do + it 'does not have boto installed' do + expect(subject.exit_status).to eq 1 + end + end + + describe file('/home/kitchen/.avm/v2.1/ansible/.git') do + it 'does not have .git' do + should_not exist + end + end +end + +context 'Directory stucture for devel' do + describe command ' /home/kitchen/.avm/devel/venv/bin/python -c "import boto3"' do + it 'does have boto installed' do + expect(subject.exit_status).to eq 0 + end + end + + describe file('/home/kitchen/.avm/.source_git/ansible/.git') do + it 'has .git' do + should exist + end + end + + describe command 'cd /home/kitchen/.avm/.source_git/ansible/;git branch' do + it 'is devel' do + expect(subject.stdout).to match('devel') + end + end + +end + +context 'Directory stucture venv' do + describe file('/home/kitchen/.avm/') do + it 'has right perm' do + should exist + should be_directory + should be_mode 755 + should be_owned_by 'kitchen' + end + end +end