Merge pull request #6453 from jlaska/test_git

Additional test scenarios in roles/test_git
This commit is contained in:
Michael DeHaan 2014-03-12 17:21:53 -05:00
commit e753b39eae
3 changed files with 89 additions and 22 deletions

View file

@ -1,17 +1,20 @@
INVENTORY ?= inventory
VARS_FILE ?= integration_config.yml
all: non_destructive destructive check_mode test_hash all: non_destructive destructive check_mode test_hash
non_destructive: non_destructive:
ansible-playbook non_destructive.yml -i inventory -e @integration_config.yml -v $(TEST_FLAGS) ansible-playbook non_destructive.yml -i $(INVENTORY) -e @$(VARS_FILE) -v $(TEST_FLAGS)
destructive: destructive:
ansible-playbook destructive.yml -i inventory -e @integration_config.yml -v $(TEST_FLAGS) ansible-playbook destructive.yml -i $(INVENTORY) -e @$(VARS_FILE) -v $(TEST_FLAGS)
check_mode: check_mode:
ansible-playbook check_mode.yml -i inventory -e @integration_config.yml -v --check $(TEST_FLAGS) ansible-playbook check_mode.yml -i $(INVENTORY) -e @$(VARS_FILE) -v --check $(TEST_FLAGS)
test_hash: test_hash:
ANSIBLE_HASH_BEHAVIOUR=replace ansible-playbook test_hash.yml -i inventory -v -e '{"test_hash":{"extra_args":"this is an extra arg"}}' ANSIBLE_HASH_BEHAVIOUR=replace ansible-playbook test_hash.yml -i $(INVENTORY) -v -e '{"test_hash":{"extra_args":"this is an extra arg"}}'
ANSIBLE_HASH_BEHAVIOUR=merge ansible-playbook test_hash.yml -i inventory -v -e '{"test_hash":{"extra_args":"this is an extra arg"}}' ANSIBLE_HASH_BEHAVIOUR=merge ansible-playbook test_hash.yml -i $(INVENTORY) -v -e '{"test_hash":{"extra_args":"this is an extra arg"}}'
cloud: amazon rackspace cloud: amazon rackspace
@ -25,17 +28,17 @@ rackspace_cleanup:
@#python cleanup_rax.py -y @#python cleanup_rax.py -y
credentials.yml: credentials.yml:
@echo "No credentials.yml file found. A file named 'credentials.yml' is needed to provide credentials needed to run cloud tests." @echo "No credentials.yml file found. A file named 'credentials.yml' is needed to provide credentials needed to run cloud tests. See sample 'credentials.template' file."
@exit 1 @exit 1
amazon: credentials.yml amazon: credentials.yml
ansible-playbook amazon.yml -i inventory -e @integration_config.yml -e @credentials.yml -v $(TEST_FLAGS) ; \ ansible-playbook amazon.yml -i $(INVENTORY) -e @$(VARS_FILE) -e @credentials.yml -v $(TEST_FLAGS) ; \
RC=$$? ; \ RC=$$? ; \
make amazon_cleanup ; \ make amazon_cleanup ; \
exit $$RC; exit $$RC;
rackspace: credentials.yml rackspace: credentials.yml
ansible-playbook rackspace.yml -i inventory -e @integration_config.yml -e @credentials.yml -v $(TEST_FLAGS) ; \ ansible-playbook rackspace.yml -i $(INVENTORY) -e @$(VARS_FILE) -e @credentials.yml -v $(TEST_FLAGS) ; \
RC=$$? ; \ RC=$$? ; \
make rackspace_cleanup ; \ make rackspace_cleanup ; \
exit $$RC; exit $$RC;

View file

@ -0,0 +1,7 @@
---
# AWS Credentials
ec2_access_key: FIXME
ec2_secret_key: FIXME
# GITHUB Credentials
github_ssh_private_key: "{{ lookup('env','HOME') }}/.ssh/id_rsa"

View file

@ -16,11 +16,15 @@
# You should have received a copy of the GNU General Public License # You should have received a copy of the GNU General Public License
# along with Ansible. If not, see <http://www.gnu.org/licenses/>. # along with Ansible. If not, see <http://www.gnu.org/licenses/>.
- name: set where to extract the repo - name: set role facts
set_fact: checkout_dir={{ output_dir }}/git set_fact:
checkout_dir: '{{ output_dir }}/git'
- name: set what repo to use repo_format1: 'https://github.com/jimi-c/test_role'
set_fact: repo=https://github.com/jimi-c/test_role repo_format2: 'git@github.com:jimi-c/test_role.git'
repo_format3: 'ssh://git@github.com/jimi-c/test_role.git'
known_host_files:
- "{{ lookup('env','HOME') }}/.ssh/known_hosts"
- '/etc/ssh/ssh_known_hosts'
- name: clean out the output_dir - name: clean out the output_dir
shell: rm -rf {{ output_dir }}/* shell: rm -rf {{ output_dir }}/*
@ -28,28 +32,26 @@
- name: verify that git is installed so this test can continue - name: verify that git is installed so this test can continue
shell: which git shell: which git
#
# Test repo=https://github.com/...
#
- name: initial checkout - name: initial checkout
git: repo={{ repo }} dest={{ checkout_dir }} git: repo={{ repo_format1 }} dest={{ checkout_dir }}
register: git_result register: git_result
- debug: var=git_result
- shell: ls ~/ansible_testing/git
- name: verify information about the initial clone - name: verify information about the initial clone
assert: assert:
that: that:
- "'before' in git_result" - "'before' in git_result"
- "'after' in git_result" - "'after' in git_result"
- "not git_result.before" - "not git_result.before"
- "git_result.changed" - "git_result.changed"
- name: repeated checkout - name: repeated checkout
git: repo={{ repo }} dest={{ checkout_dir }} git: repo={{ repo_format1 }} dest={{ checkout_dir }}
register: git_result2 register: git_result2
- debug: var=git_result2
- name: check for tags - name: check for tags
stat: path={{ checkout_dir }}/.git/refs/tags stat: path={{ checkout_dir }}/.git/refs/tags
register: tags register: tags
@ -74,6 +76,61 @@
that: that:
- "not git_result2.changed" - "not git_result2.changed"
#
# Test repo=git@github.com:/...
# Requires variable: github_ssh_private_key
#
- name: clear checkout_dir
file: state=absent path={{ checkout_dir }}
- name: remove known_host files
file: state=absent path={{ item }}
with_items: known_host_files
- name: checkout ssh://git@github.com repo without accept_hostkey (expected fail)
git: repo={{ repo_format2 }} dest={{ checkout_dir }}
register: git_result
ignore_errors: true
- assert:
that:
- 'git_result.failed'
- 'git_result.msg == "github.com has an unknown hostkey. Set accept_hostkey to True or manually add the hostkey prior to running the git module"'
- name: checkout git@github.com repo with accept_hostkey (expected pass)
git:
repo: '{{ repo_format2 }}'
dest: '{{ checkout_dir }}'
accept_hostkey: true
key_file: '{{ github_ssh_private_key }}'
register: git_result
when: github_ssh_private_key is defined
- assert:
that:
- 'git_result.changed'
when: not git_result|skipped
#
# Test repo=ssh://git@github.com/...
# Requires variable: github_ssh_private_key
#
- name: clear checkout_dir
file: state=absent path={{ checkout_dir }}
- name: checkout ssh://git@github.com repo with accept_hostkey (expected pass)
git:
repo: '{{ repo_format3 }}'
dest: '{{ checkout_dir }}'
version: 'master'
accept_hostkey: false # should already have been accepted
key_file: '{{ github_ssh_private_key }}'
register: git_result
when: github_ssh_private_key is defined
- assert:
that:
- 'git_result.changed'
when: not git_result|skipped