Skip to content

Commit

Permalink
Merge pull request ansible#6453 from jlaska/test_git
Browse files Browse the repository at this point in the history
Additional test scenarios in roles/test_git
  • Loading branch information
mpdehaan committed Mar 12, 2014
2 parents 78ebf5d + bc678e7 commit e753b39
Show file tree
Hide file tree
Showing 3 changed files with 89 additions and 22 deletions.
19 changes: 11 additions & 8 deletions test/integration/Makefile
Original file line number Diff line number Diff line change
@@ -1,17 +1,20 @@
INVENTORY ?= inventory
VARS_FILE ?= integration_config.yml

all: non_destructive destructive check_mode test_hash

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:
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:
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:
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=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"}}'

cloud: amazon rackspace

Expand All @@ -25,17 +28,17 @@ rackspace_cleanup:
@#python cleanup_rax.py -y

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

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=$$? ; \
make amazon_cleanup ; \
exit $$RC;

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=$$? ; \
make rackspace_cleanup ; \
exit $$RC;
7 changes: 7 additions & 0 deletions test/integration/credentials.template
Original file line number Diff line number Diff line change
@@ -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"
85 changes: 71 additions & 14 deletions test/integration/roles/test_git/tasks/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -16,40 +16,42 @@
# You should have received a copy of the GNU General Public License
# along with Ansible. If not, see <http://www.gnu.org/licenses/>.

- name: set where to extract the repo
set_fact: checkout_dir={{ output_dir }}/git

- name: set what repo to use
set_fact: repo=https://github.com/jimi-c/test_role
- name: set role facts
set_fact:
checkout_dir: '{{ output_dir }}/git'
repo_format1: 'https://github.com/jimi-c/test_role'
repo_format2: '[email protected]:jimi-c/test_role.git'
repo_format3: 'ssh://[email protected]/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
shell: rm -rf {{ output_dir }}/*

- name: verify that git is installed so this test can continue
shell: which git

#
# Test repo=https://github.com/...
#

- name: initial checkout
git: repo={{ repo }} dest={{ checkout_dir }}
git: repo={{ repo_format1 }} dest={{ checkout_dir }}
register: git_result

- debug: var=git_result

- shell: ls ~/ansible_testing/git

- name: verify information about the initial clone
assert:
that:
- "'before' in git_result"
- "'after' in git_result"
- "not git_result.before"
- "git_result.changed"
- "git_result.changed"

- name: repeated checkout
git: repo={{ repo }} dest={{ checkout_dir }}
git: repo={{ repo_format1 }} dest={{ checkout_dir }}
register: git_result2

- debug: var=git_result2

- name: check for tags
stat: path={{ checkout_dir }}/.git/refs/tags
register: tags
Expand All @@ -74,6 +76,61 @@
that:
- "not git_result2.changed"

#
# Test [email protected]:/...
# 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://[email protected] 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 [email protected] 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://[email protected]/...
# Requires variable: github_ssh_private_key
#

- name: clear checkout_dir
file: state=absent path={{ checkout_dir }}

- name: checkout ssh://[email protected] 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

0 comments on commit e753b39

Please sign in to comment.