mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-24 21:14:00 -07:00 
			
		
		
		
	Remove legacy test code.
This commit is contained in:
		
					parent
					
						
							
								851b264fb0
							
						
					
				
			
			
				commit
				
					
						580401c02b
					
				
			
		
					 27 changed files with 0 additions and 1102 deletions
				
			
		|  | @ -1,2 +0,0 @@ | |||
| [defaults] | ||||
| host_key_checking = False | ||||
|  | @ -1,40 +0,0 @@ | |||
| - name: Launch Instance | ||||
|   ec2: | ||||
|     group_id: 'sg-07bb906d' # jenkins-slave_new | ||||
|     count: 1 | ||||
|     instance_type: 'm3.large' | ||||
|     image: '{{ item.image }}' | ||||
|     wait: true | ||||
|     region: 'us-east-1' | ||||
|     keypair: '{{ keypair }}' | ||||
|     aws_access_key: "{{ aws_access_key|default(lookup('env', 'AWS_ACCESS_KEY')) }}" | ||||
|     aws_secret_key: "{{ aws_secret_key|default(lookup('env', 'AWS_SECRET_KEY')) }}" | ||||
|     instance_tags: | ||||
|       jenkins: jenkins_ansible_pr_test | ||||
|   register: ec2 | ||||
|   with_items: slaves | ||||
| # We could do an async here, that would speed things up | ||||
| 
 | ||||
| 
 | ||||
| - name: Wait for SSH | ||||
|   wait_for: | ||||
|     host: "{{ item['instances'][0]['public_ip'] }}" | ||||
|     port: 22 | ||||
|     delay: 10 | ||||
|     timeout: 320 | ||||
|     state: started | ||||
|   with_items: ec2.results | ||||
| 
 | ||||
| - name: Wait a little longer for centos | ||||
|   pause: seconds=20 | ||||
| 
 | ||||
| - name: Add hosts group temporary inventory group with pem path | ||||
|   add_host: | ||||
|     name: "{{ item.1.platform }}-{{ ec2.results[item.0]['instances'][0]['public_ip'] }}" | ||||
|     groups: dynamic_hosts | ||||
|     ansible_ssh_host: "{{ ec2.results[item.0]['instances'][0]['public_ip'] }}" | ||||
|     ansible_ssh_private_key_file: '{{ pem_path }}' | ||||
|     ansible_ssh_user: "{{ item.1.ssh_user }}" | ||||
|     ec2_vars: "{{ ec2.results[item.0]['instances'][0] }}" | ||||
|     ec2_instance_ids: "{{ ec2.results[item.0]['instance_ids'] }}" | ||||
|   with_indexed_items: slaves | ||||
|  | @ -1 +0,0 @@ | |||
| localhost ansible_connection=local | ||||
|  | @ -1,77 +0,0 @@ | |||
| - hosts: all | ||||
|   connection: local | ||||
|   vars: | ||||
|     slaves: | ||||
|       - distribution: "Ubuntu" | ||||
|         version: "12.04" | ||||
|         image: "ami-309ddf5a" | ||||
|         ssh_user: "ubuntu" | ||||
|         platform: "ubuntu-12.04-x86_64" | ||||
|       - distribution: "Ubuntu" | ||||
|         version: "14.04" | ||||
|         image: "ami-d06632ba" | ||||
|         ssh_user: "ubuntu" | ||||
|         platform: "ubuntu-14.04-x86_64" | ||||
|       - distribution: "CentOS" | ||||
|         version: "6.5" | ||||
|         image: "ami-8997afe0" | ||||
|         ssh_user: "root" | ||||
|         platform: "centos-6.5-x86_64" | ||||
|       - distribution: "CentOS" | ||||
|         version: "7" | ||||
|         image: "ami-61bbf104" | ||||
|         ssh_user: "centos" | ||||
|         platform: "centos-7-x86_64" | ||||
|       - distribution: "Fedora" | ||||
|         version: "23" | ||||
|         image: "ami-518bfb3b" | ||||
|         ssh_user: "fedora" | ||||
|         platform: "fedora-23-x86_64" | ||||
| 
 | ||||
|   tasks: | ||||
|     - debug: var=ansible_version | ||||
|     - include: ec2.yml | ||||
|       when: groups['dynamic_hosts'] is not defined | ||||
| 
 | ||||
| # Have to hardcode these per-slave. We can't even run setup yet so we can't | ||||
| # introspect what they have. | ||||
| - hosts: dynamic_hosts | ||||
|   sudo: true | ||||
|   gather_facts: False | ||||
|   tasks: | ||||
|     - name: Install packages that let setup and package manager modules run | ||||
|       raw: dnf install -y python2 python2-dnf libselinux-python | ||||
|       when: "'fedora-23' in '{{ inventory_hostname }}'" | ||||
| 
 | ||||
| - hosts: dynamic_hosts | ||||
|   sudo: true | ||||
|   vars: | ||||
|     credentials_file: '' | ||||
|     test_flags: "" | ||||
|     make_target: "non_destructive" | ||||
|   #pre_tasks: | ||||
|   roles: | ||||
|     - { role: ansible_test_deps, tags: ansible_test_deps } | ||||
|     - { role: run_integration, | ||||
|         tags: run_integration, | ||||
|         run_integration_test_flags: "{{ test_flags }}", | ||||
|         run_integration_credentials_file: "{{ credentials_file }}", | ||||
|         run_integration_make_target: "{{ make_target }}", } | ||||
|   tasks: | ||||
| 
 | ||||
|     - name: Kill ec2 instances | ||||
|       sudo: false | ||||
|       local_action: | ||||
|         module: ec2 | ||||
|         state: absent | ||||
|         region: 'us-east-1' | ||||
|         instance_ids: "{{ hostvars[item]['ec2_instance_ids'] }}" | ||||
|       when: hostvars[item]['ec2_instance_ids'] is defined and item == inventory_hostname | ||||
|       with_items: "{{groups['dynamic_hosts']}}" | ||||
| 
 | ||||
|     - set_fact: | ||||
|         ansible_connection: local | ||||
| 
 | ||||
|     - name: Fail | ||||
|       shell: 'echo "{{ inventory_hostname }}, Failed" && exit 1' | ||||
|       when: "'rc' not in test_results or test_results.rc != 0" | ||||
|  | @ -1,37 +0,0 @@ | |||
| sudo: required | ||||
| dist: trusty | ||||
| language: python | ||||
| python: | ||||
|   - "2.7" | ||||
| services: | ||||
|   - docker | ||||
| env: | ||||
|   global: | ||||
|     - PATH="/usr/bin:$PATH" | ||||
| 
 | ||||
| before_install: | ||||
|     # Ansible doesn't play well with virtualenv | ||||
|   - deactivate | ||||
|   - sudo apt-get update -qq | ||||
|   - sudo apt-get install docker-engine | ||||
| 
 | ||||
| install: | ||||
|   - sudo pip install docker-py | ||||
|     # software-properties-common for ubuntu 14.04 | ||||
|     # python-software-properties for ubuntu 12.04 | ||||
|   - sudo apt-get install -y sshpass software-properties-common python-software-properties | ||||
|   - sudo apt-add-repository -y ppa:ansible/ansible | ||||
|   - sudo apt-get update -qq | ||||
|   - sudo apt-get install -y ansible | ||||
|   - sudo rm /usr/bin/python && sudo ln -s /usr/bin/python2.7 /usr/bin/python | ||||
|   - ansible-galaxy install -r test/requirements.yml -p test/roles/ | ||||
| 
 | ||||
| script: | ||||
|   # Ensure any invocation of ansible-playbook (i.e. sudo) results in host_key_checking disabled | ||||
|   - sudo ansible all -i "127.0.0.1," -m lineinfile -a "regexp=^#host_key_checking dest=/etc/ansible/ansible.cfg line='host_key_checking = False'" -c local | ||||
|   - ansible-playbook -i test/inventory test/main.yml --syntax-check | ||||
|   - sudo ansible-playbook -i test/inventory test/main.yml | ||||
| 
 | ||||
| notifications: | ||||
|   # notify ansible galaxy of results | ||||
|   webhooks: http://goo.gl/nSuq9h | ||||
|  | @ -1,6 +0,0 @@ | |||
| [](https://travis-ci.org/chrismeyersfsu/ansible_test_deps) | ||||
| 
 | ||||
| ansible_test_deps | ||||
| ========= | ||||
| 
 | ||||
| Install needed packages to run ansible integration tests. | ||||
|  | @ -1,2 +0,0 @@ | |||
| --- | ||||
| # defaults file for . | ||||
|  | @ -1,2 +0,0 @@ | |||
| --- | ||||
| # handlers file for . | ||||
|  | @ -1 +0,0 @@ | |||
| {install_date: 'Tue Dec  8 15:06:28 2015', version: master} | ||||
|  | @ -1,22 +0,0 @@ | |||
| --- | ||||
| galaxy_info: | ||||
|   author: Chris Meyers | ||||
|   description: install ansible integration test dependencies | ||||
|   company: Ansible | ||||
|   license: license (GPLv2, CC-BY, etc) | ||||
|   min_ansible_version: 1.2 | ||||
|   platforms: | ||||
|   - name: EL | ||||
|     versions: | ||||
|     - 6 | ||||
|     - 7 | ||||
|   - name: Ubuntu | ||||
|     versions: | ||||
|     - precise | ||||
|     - trusty | ||||
|   galaxy_tags: | ||||
|     - testing | ||||
|     - integration | ||||
|     - ansible | ||||
|     - dependencies | ||||
| dependencies: [] | ||||
|  | @ -1,100 +0,0 @@ | |||
| --- | ||||
| 
 | ||||
| - apt: update_cache=yes | ||||
|   when: ansible_os_family == 'Debian' | ||||
| 
 | ||||
| - name: Install sudo | ||||
|   package: name=sudo state=installed | ||||
|   ignore_errors: true | ||||
| 
 | ||||
| - name: Install RH epel | ||||
|   yum: name="epel-release" state=installed | ||||
|   sudo: true | ||||
|   when: ansible_distribution in ('CentOS', 'RedHat') | ||||
| 
 | ||||
| - name: Install RH ansible dependencies | ||||
|   package: name="{{ item }}" state=installed | ||||
|   sudo: true | ||||
|   with_items: | ||||
|     - python-pip | ||||
|     - python-httplib2 | ||||
|     - rsync | ||||
|     - subversion | ||||
|     - mercurial | ||||
|     - git | ||||
|     - rubygems | ||||
|     - unzip | ||||
|     - openssl | ||||
|     - make | ||||
|     - gcc | ||||
|     - gawk | ||||
|     - python-devel | ||||
|     - libselinux-python | ||||
|     - python-virtualenv | ||||
|     - yum | ||||
|     - yum-metadata-parser | ||||
|     - redhat-rpm-config | ||||
|   when: ansible_os_family == 'RedHat' | ||||
| 
 | ||||
| - name: Install Debian ansible dependencies | ||||
|   apt: name="{{ item }}" state=installed update_cache=yes | ||||
|   sudo: true | ||||
|   with_items: | ||||
|     - python-pip | ||||
|     - python-httplib2 | ||||
|     - rsync | ||||
|     - subversion | ||||
|     - mercurial | ||||
|     - git | ||||
|     - unzip | ||||
|     - gawk | ||||
|     - python-dev | ||||
|     - python-virtualenv | ||||
|   when: ansible_os_family == 'Debian' | ||||
| 
 | ||||
| - name: update ca certificates | ||||
|   sudo: true | ||||
|   yum: name=ca-certificates state=latest | ||||
|   when: ansible_os_family == 'RedHat' | ||||
| 
 | ||||
| - name: Install ubuntu 12.04 ansible dependencies | ||||
|   apt: name="{{ item }}" state=installed update_cache=yes | ||||
|   sudo: true | ||||
|   with_items: | ||||
|     - rubygems | ||||
|   when: ansible_distribution == 'Ubuntu' and ansible_distribution_version == "12.04" | ||||
| 
 | ||||
| - name: Install ubuntu 14.04 ansible dependencies | ||||
|   apt: name="{{ item }}" state=installed update_cache=yes | ||||
|   sudo: true | ||||
|   with_items: | ||||
|     - rubygems-integration | ||||
|   when: ansible_distribution == 'Ubuntu' and ansible_distribution_version == "14.04" | ||||
| 
 | ||||
| # Not sure why CentOS 6 is working without this.... | ||||
| #- name: Install Red Hat 6 ansible dependencies | ||||
| #  yum: name="{{ item }}" state=installed | ||||
| #  sudo: true | ||||
| #  with_items: | ||||
| #    - python-crypto2.6 | ||||
| #  when: ansible_distribution in ('CentOS', 'RedHat') and ansible_distribution_major_version == "6" | ||||
| 
 | ||||
| - name: Install ansible pip deps | ||||
|   sudo: true | ||||
|   pip: name="{{ item }}" | ||||
|   with_items: | ||||
|     - PyYAML | ||||
|     - Jinja2 | ||||
|     - paramiko | ||||
| 
 | ||||
| - name: Install ubuntu 12.04 ansible pip deps | ||||
|   sudo: true | ||||
|   pip: name="{{ item }}" state=latest | ||||
|   with_items: | ||||
|     - pycrypto | ||||
|   when: ansible_distribution == 'Ubuntu' and ansible_distribution_version == "12.04" | ||||
| 
 | ||||
| - name: Remove tty sudo requirement | ||||
|   sudo: true | ||||
|   lineinfile: "dest=/etc/sudoers regexp='^Defaults[ ,       ]*requiretty'  line='#Defaults    requiretty'" | ||||
|   when: ansible_os_family == 'RedHat' | ||||
|  | @ -1 +0,0 @@ | |||
| localhost ansible_connection=local | ||||
|  | @ -1,28 +0,0 @@ | |||
| --- | ||||
| - name: Bring up docker containers | ||||
|   hosts: localhost | ||||
|   gather_facts: false | ||||
|   vars: | ||||
|     inventory: | ||||
|       - name: ansible_test_deps_host_1 | ||||
|         image: "chrismeyers/centos6" | ||||
|       - name: ansible_test_deps_host_2 | ||||
|         image: "chrismeyers/ubuntu12.04" | ||||
|       - name: ansible_test_deps_host_3 | ||||
|         image: "ubuntu-upstart:14.04" | ||||
|   roles: | ||||
|     - { role: provision_docker, provision_docker_company: 'ansible', provision_docker_inventory: "{{ inventory }}" } | ||||
| 
 | ||||
| - name: Run ansible_test_deps Tests | ||||
|   hosts: docker_containers | ||||
|   vars: | ||||
|     git_dir: "/tmp/ansible" | ||||
|   roles: | ||||
|     - { role: ansible_test_deps } | ||||
|   tasks: | ||||
|     - name: Clone ansible | ||||
|       git: | ||||
|         repo: "https://github.com/ansible/ansible.git" | ||||
|         dest: "{{ git_dir }}" | ||||
|     - name: Invoke ansible in hacking mode | ||||
|       shell: "cd {{ git_dir }} && . hacking/env-setup && ansible --version && ansible-playbook --version" | ||||
|  | @ -1,2 +0,0 @@ | |||
| - src: chrismeyersfsu.provision_docker | ||||
|   name: provision_docker | ||||
|  | @ -1 +0,0 @@ | |||
| ../../../ansible_test_deps | ||||
|  | @ -1,2 +0,0 @@ | |||
| --- | ||||
| # vars file for . | ||||
|  | @ -1,43 +0,0 @@ | |||
| --- | ||||
| - name: Sync ansible repo to ec2 instance | ||||
|   synchronize: | ||||
|     src: "{{ sync_dir }}/" | ||||
|     dest: "~/ansible" | ||||
|   no_log: true | ||||
| 
 | ||||
| - name: Get ansible source dir | ||||
|   sudo: false | ||||
|   shell: "cd ~/ansible && pwd" | ||||
|   register: results | ||||
| 
 | ||||
| - shell: "ls -la && . hacking/env-setup && cd test/integration && TEST_FLAGS='-e clean_working_dir=no' make {{ run_integration_make_target }}" | ||||
|   args: | ||||
|     chdir: "{{ results.stdout }}" | ||||
|   async: 3600 | ||||
|   poll: 0 | ||||
|   register: async_test_results | ||||
|   sudo: true | ||||
|   environment: | ||||
|     TEST_FLAGS: "{{ run_integration_test_flags|default(lookup('env', 'TEST_FLAGS')) }}" | ||||
|     CREDENTIALS_FILE: "{{ run_integration_credentials_file|default(lookup('env', 'CREDENTIALS_FILE')) }}" | ||||
| 
 | ||||
| - name: poll for test results | ||||
|   async_status: jid="{{async_test_results.ansible_job_id}}" | ||||
|   register: test_results | ||||
|   until: test_results.finished | ||||
|   retries: 120 | ||||
|   delay: 30 | ||||
|   ignore_errors: true | ||||
|   no_log: true | ||||
| 
 | ||||
| - name: save stdout test results for each host | ||||
|   local_action: copy | ||||
|   args: | ||||
|     dest: "{{sync_dir}}/{{inventory_hostname}}.stdout_results.txt" | ||||
|     content: "{{test_results.stdout}}" | ||||
| 
 | ||||
| - name: save stderr test results for each host | ||||
|   local_action: copy | ||||
|   args: | ||||
|     dest: "{{sync_dir}}/{{inventory_hostname}}.stderr_results.txt" | ||||
|     content: "{{test_results.stderr}}" | ||||
|  | @ -1,7 +0,0 @@ | |||
| #!/bin/bash -eux | ||||
| 
 | ||||
| set -o pipefail | ||||
| 
 | ||||
| source_root=$(python -c "from os import path; print(path.abspath(path.join(path.dirname('$0'), '../../..')))") | ||||
| 
 | ||||
| "${source_root}/test/utils/shippable/${TEST}.sh" 2>&1 | gawk '{ print strftime("%Y-%m-%d %H:%M:%S"), $0; fflush(); }' | ||||
|  | @ -1 +0,0 @@ | |||
| yamllint | ||||
|  | @ -1,31 +0,0 @@ | |||
| #!/bin/bash -eux | ||||
| 
 | ||||
| source_root=$(python -c "from os import path; print(path.abspath(path.join(path.dirname('$0'), '../../..')))") | ||||
| 
 | ||||
| install_deps="${INSTALL_DEPS:-}" | ||||
| 
 | ||||
| cd "${source_root}" | ||||
| 
 | ||||
| if [ "${install_deps}" != "" ]; then | ||||
|     apt-add-repository 'deb http://archive.ubuntu.com/ubuntu trusty-backports universe' | ||||
|     apt-get update -qq | ||||
|     apt-get install shellcheck | ||||
| 
 | ||||
|     pip install -r "${source_root}/test/utils/shippable/code-smell-requirements.txt" --upgrade | ||||
|     pip list | ||||
| fi | ||||
| 
 | ||||
| yamllint ./test | ||||
| 
 | ||||
| test/sanity/code-smell/replace-urlopen.sh | ||||
| test/sanity/code-smell/use-compat-six.sh | ||||
| test/sanity/code-smell/boilerplate.sh | ||||
| test/sanity/code-smell/required-and-default-attributes.sh | ||||
| test/sanity/code-smell/shebang.sh | ||||
| test/sanity/code-smell/line-endings.sh | ||||
| test/sanity/code-smell/empty-init.sh | ||||
| test/sanity/code-smell/no-basestring.sh | ||||
| 
 | ||||
| shellcheck \ | ||||
|     test/integration/targets/*/*.sh \ | ||||
|     test/utils/shippable/*.sh | ||||
|  | @ -1,288 +0,0 @@ | |||
| #!/usr/bin/env python | ||||
| 
 | ||||
| # (c) 2016 Matt Clay <matt@mystile.com> | ||||
| # | ||||
| # This file is part of Ansible | ||||
| # | ||||
| # Ansible is free software: you can redistribute it and/or modify | ||||
| # it under the terms of the GNU General Public License as published by | ||||
| # the Free Software Foundation, either version 3 of the License, or | ||||
| # (at your option) any later version. | ||||
| # | ||||
| # Ansible is distributed in the hope that it will be useful, | ||||
| # but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
| # GNU General Public License for more details. | ||||
| # | ||||
| # You should have received a copy of the GNU General Public License | ||||
| # along with Ansible.  If not, see <http://www.gnu.org/licenses/>. | ||||
| 
 | ||||
| from __future__ import print_function | ||||
| 
 | ||||
| import os | ||||
| import subprocess | ||||
| import sys | ||||
| 
 | ||||
| from os import path | ||||
| from argparse import ArgumentParser | ||||
| 
 | ||||
| import ansible.constants as C | ||||
| 
 | ||||
| from ansible.playbook import Playbook | ||||
| from ansible.vars import VariableManager | ||||
| from ansible.parsing.dataloader import DataLoader | ||||
| 
 | ||||
| 
 | ||||
| def main(): | ||||
|     """Generate an integration test script for changed modules.""" | ||||
| 
 | ||||
|     C.DEPRECATION_WARNINGS = False | ||||
| 
 | ||||
|     C.DEFAULT_ROLES_PATH = [os.path.abspath(os.path.join(os.path.dirname(os.path.abspath(__file__)), | ||||
|                                                          '..', '..', '..', 'integration', 'targets'))] | ||||
| 
 | ||||
|     posix_targets = [ | ||||
|         'non_destructive', | ||||
|         'destructive', | ||||
|     ] | ||||
| 
 | ||||
|     windows_targets = [ | ||||
|         'test_win_group1', | ||||
|         'test_win_group2', | ||||
|         'test_win_group3', | ||||
|     ] | ||||
| 
 | ||||
|     parser = ArgumentParser(description='Generate an integration test script for changed modules.') | ||||
|     parser.add_argument('module_group', choices=['core', 'extras'], help='module group to test') | ||||
|     parser.add_argument('-v', '--verbose', dest='verbose', action='store_true', help='write verbose output to stderr') | ||||
|     parser.add_argument('--changes', dest='changes', default=None, | ||||
|                         help='file listing changed paths (default: query git)') | ||||
|     parser.add_argument('--image', dest='image', default=os.environ.get('IMAGE'), | ||||
|                         help='image to run tests with') | ||||
|     parser.add_argument('--privileged', dest='privileged', action='store_true', | ||||
|                         default=os.environ.get('PRIVILEGED') == 'true', | ||||
|                         help='run container in privileged mode') | ||||
|     parser.add_argument('--python3', dest='python3', action='store_true', | ||||
|                         default=os.environ.get('PYTHON3', '') != '', | ||||
|                         help='run tests using python3') | ||||
|     parser.add_argument('--platform', dest='platform', default=os.environ.get('PLATFORM'), | ||||
|                         help='platform to run tests on') | ||||
|     parser.add_argument('--version', dest='version', default=os.environ.get('VERSION'), | ||||
|                         help='version of platform to run tests on') | ||||
|     parser.add_argument('--output', dest='output', required=True, | ||||
|                         help='path to write output script to') | ||||
| 
 | ||||
|     args = parser.parse_args() | ||||
| 
 | ||||
|     targets = posix_targets | ||||
| 
 | ||||
|     if args.image is not None: | ||||
|         script = 'integration' | ||||
|         options = '' | ||||
|         if args.privileged: | ||||
|             options += ' PRIVILEGED=true' | ||||
|         if args.python3: | ||||
|             options += ' PYTHON3=1' | ||||
|         jobs = ['IMAGE=%s%s' % (args.image, options)] | ||||
|     elif args.platform is not None and args.version is not None: | ||||
|         script = 'remote' | ||||
|         jobs = ['PLATFORM=%s VERSION=%s' % (args.platform, args.version)] | ||||
| 
 | ||||
|         if args.platform == 'windows': | ||||
|             targets = windows_targets | ||||
|     else: | ||||
|         raise Exception('job parameters not specified') | ||||
| 
 | ||||
|     generate_test_commands(args.module_group, targets, script, args.output, jobs=jobs, verbose=args.verbose, changes=args.changes) | ||||
| 
 | ||||
| 
 | ||||
| def generate_test_commands(module_group, targets, script, output, jobs=None, verbose=False, changes=None): | ||||
|     """Generate test commands for the given module group and test targets. | ||||
| 
 | ||||
|     Args: | ||||
|         module_group: The module group (core, extras) to examine. | ||||
|         targets: The test targets to examine. | ||||
|         script: The script used to execute the test targets. | ||||
|         output: The path to write the output script to. | ||||
|         jobs: The test jobs to execute, or None to auto-detect. | ||||
|         verbose: True to write detailed output to stderr. | ||||
|         changes: Path to file containing list of changed files, or None to query git. | ||||
|     """ | ||||
| 
 | ||||
|     base_dir = os.path.abspath(os.path.join(os.path.dirname(os.path.abspath(__file__)), '..', '..', '..', '..')) | ||||
| 
 | ||||
|     job_config_path = path.join(base_dir, 'shippable.yml') | ||||
|     module_dir = os.path.join(base_dir, 'lib', 'ansible', 'modules', module_group) | ||||
| 
 | ||||
|     if verbose: | ||||
|         print_stderr(' config: %s' % job_config_path) | ||||
|         print_stderr('modules: %s' % module_dir) | ||||
|         print_stderr('targets: %s' % ' '.join(targets)) | ||||
|         print_stderr() | ||||
| 
 | ||||
|     if changes is None: | ||||
|         paths_changed = get_changed_paths(module_dir) | ||||
|     else: | ||||
|         with open(changes, 'r') as f: | ||||
|             paths_changed = f.read().strip().split('\n') | ||||
| 
 | ||||
|     if len(paths_changed) == 0: | ||||
|         print_stderr('No changes to files detected.') | ||||
|         exit() | ||||
| 
 | ||||
|     if verbose: | ||||
|         dump_stderr('paths_changed', paths_changed) | ||||
| 
 | ||||
|     modules_changed = get_modules(paths_changed) | ||||
| 
 | ||||
|     if len(modules_changed) == 0: | ||||
|         print_stderr('No changes to modules detected.') | ||||
|         exit() | ||||
| 
 | ||||
|     if verbose: | ||||
|         dump_stderr('modules_changed', modules_changed) | ||||
| 
 | ||||
|     module_tags = get_module_test_tags(modules_changed) | ||||
| 
 | ||||
|     if verbose: | ||||
|         dump_stderr('module_tags', module_tags) | ||||
| 
 | ||||
|     available_tags = get_target_tags(base_dir, targets) | ||||
| 
 | ||||
|     if verbose: | ||||
|         dump_stderr('available_tags', available_tags) | ||||
| 
 | ||||
|     use_tags = module_tags & available_tags | ||||
| 
 | ||||
|     if len(use_tags) == 0: | ||||
|         print_stderr('No tagged test roles found for changed modules.') | ||||
|         exit() | ||||
| 
 | ||||
|     if verbose: | ||||
|         dump_stderr('use_tags', use_tags) | ||||
| 
 | ||||
|     target = ' '.join(targets) | ||||
|     tags = ','.join(use_tags) | ||||
|     script_path = 'test/utils/shippable/%s.sh' % script | ||||
| 
 | ||||
|     commands = ['TARGET="%s" TEST_FLAGS="-t %s" %s %s' % (target, tags, j, script_path) for j in jobs] | ||||
| 
 | ||||
|     with open(output, 'w') as f: | ||||
|         f.writelines(commands) | ||||
|         f.write('\n') | ||||
| 
 | ||||
| 
 | ||||
| def print_stderr(*args, **kwargs): | ||||
|     """Print to stderr.""" | ||||
| 
 | ||||
|     print(*args, file=sys.stderr, **kwargs) | ||||
|     sys.stderr.flush() | ||||
| 
 | ||||
| 
 | ||||
| def dump_stderr(label, l): | ||||
|     """Write a label and list contents to stderr. | ||||
| 
 | ||||
|     Args: | ||||
|         label: The label to print for this list. | ||||
|         l: The list to dump to stderr. | ||||
|     """ | ||||
| 
 | ||||
|     print_stderr('[%s:%s]\n%s\n' % (label, len(l), '\n'.join(l))) | ||||
| 
 | ||||
| 
 | ||||
| def get_target_tags(base_dir, targets): | ||||
|     """Get role tags from the integration tests for the given test targets. | ||||
| 
 | ||||
|     Args: | ||||
|         base_dir: The root of the ansible source code. | ||||
|         targets: The test targets to scan for tags. | ||||
| 
 | ||||
|     Returns: Set of role tags. | ||||
|     """ | ||||
| 
 | ||||
|     playbook_dir = os.path.join(base_dir, 'test', 'integration') | ||||
| 
 | ||||
|     tags = set() | ||||
| 
 | ||||
|     for target in targets: | ||||
|         playbook_path = os.path.join(playbook_dir, target + '.yml') | ||||
|         tags |= get_role_tags(playbook_path) | ||||
| 
 | ||||
|     return tags | ||||
| 
 | ||||
| 
 | ||||
| def get_role_tags(playbook_path): | ||||
|     """Get role tags from the given playbook. | ||||
| 
 | ||||
|     Args: | ||||
|         playbook_path: Path to the playbook to get role tags from. | ||||
| 
 | ||||
|     Returns: Set of role tags. | ||||
|     """ | ||||
| 
 | ||||
|     variable_manager = VariableManager() | ||||
|     loader = DataLoader() | ||||
|     playbook = Playbook.load(playbook_path, variable_manager=variable_manager, loader=loader) | ||||
|     tags = set() | ||||
| 
 | ||||
|     for play in playbook.get_plays(): | ||||
|         for role in play.get_roles(): | ||||
|             for tag in role.tags: | ||||
|                 tags.add(tag) | ||||
| 
 | ||||
|     return tags | ||||
| 
 | ||||
| 
 | ||||
| def get_changed_paths(git_root, branch='devel'): | ||||
|     """Get file paths changed in current branch vs given branch. | ||||
| 
 | ||||
|     Args: | ||||
|         git_root: The root of the git clone. | ||||
|         branch: The branch to compare against (default: devel) | ||||
| 
 | ||||
|     Returns: List of file paths changed. | ||||
|     """ | ||||
| 
 | ||||
|     paths = subprocess.check_output(['git', 'diff', '--name-only', branch], cwd=git_root).strip().split('\n') | ||||
| 
 | ||||
|     return paths | ||||
| 
 | ||||
| 
 | ||||
| def get_modules(paths): | ||||
|     """Get module names from file paths. | ||||
| 
 | ||||
|     Args: | ||||
|         paths: List of paths to extract module names from. | ||||
| 
 | ||||
|     Returns: List of module names. | ||||
|     """ | ||||
| 
 | ||||
|     module_extensions = [ | ||||
|         '.py', | ||||
|         '.ps1', | ||||
|     ] | ||||
| 
 | ||||
|     modules = [path.splitext(path.basename(c))[0].strip('_') for c in paths if | ||||
|                path.splitext(c)[1] in module_extensions and | ||||
|                '/' in c and | ||||
|                not c.startswith('test/') and | ||||
|                not path.basename(c)[0] == '__init__.py'] | ||||
| 
 | ||||
|     return modules | ||||
| 
 | ||||
| 
 | ||||
| def get_module_test_tags(modules): | ||||
|     """Get test tags from module names. | ||||
| 
 | ||||
|     Args: | ||||
|         modules: List of module names to get test tags for. | ||||
| 
 | ||||
|     Returns: Set of test tags. | ||||
|     """ | ||||
| 
 | ||||
|     tags = set(['test_' + m for m in modules]) | ||||
|     return tags | ||||
| 
 | ||||
| 
 | ||||
| if __name__ == '__main__': | ||||
|     main() | ||||
|  | @ -1,2 +0,0 @@ | |||
| jinja2 | ||||
| pyyaml | ||||
|  | @ -1,169 +0,0 @@ | |||
| #!/bin/sh | ||||
| 
 | ||||
| set -eux | ||||
| env | ||||
| 
 | ||||
| container="${PLATFORM}" | ||||
| build_dir="${HOME}/ansible" | ||||
| 
 | ||||
| test_target="${TARGET:-}" | ||||
| test_flags="${TEST_FLAGS:-}" | ||||
| 
 | ||||
| # Force ansible color output by default. | ||||
| # To disable color force mode use FORCE_COLOR=0 | ||||
| force_color="${FORCE_COLOR:-1}" | ||||
| 
 | ||||
| # FIXME: these tests fail | ||||
| skip_tags='test_service,test_postgresql,test_mysql_db,test_mysql_user,test_mysql_variables,test_uri,test_get_url' | ||||
| 
 | ||||
| cd ~/ | ||||
| 
 | ||||
| make="make" | ||||
| 
 | ||||
| if [ "${container}" = "freebsd" ]; then | ||||
|     make="gmake" | ||||
| 
 | ||||
|     pkg install -y curl | ||||
| 
 | ||||
|     if [ ! -f bootstrap.sh ]; then | ||||
|         curl "https://raw.githubusercontent.com/mattclay/ansible-hacking/master/bootstrap.sh" -o bootstrap.sh | ||||
|     fi | ||||
| 
 | ||||
|     chmod +x bootstrap.sh | ||||
|     ./bootstrap.sh pip -y -q | ||||
| 
 | ||||
|     # tests require these packages | ||||
|     # TODO: bootstrap.sh should be capable of installing these | ||||
|     pkg install -y \ | ||||
|         bash \ | ||||
|         devel/ruby-gems \ | ||||
|         gtar \ | ||||
|         mercurial \ | ||||
|         rsync \ | ||||
|         ruby \ | ||||
|         subversion \ | ||||
|         sudo \ | ||||
|         zip | ||||
| fi | ||||
| 
 | ||||
| # TODO: bootstrap.sh should install these | ||||
| pip install \ | ||||
|     junit-xml \ | ||||
|     virtualenv \ | ||||
|     jmespath | ||||
| 
 | ||||
| # Tests assume loopback addresses other than 127.0.0.1 will work. | ||||
| # Add aliases for loopback addresses used by tests. | ||||
| 
 | ||||
| for i in 3 4 254; do | ||||
|     ifconfig lo0 alias "127.0.0.${i}" up | ||||
| done | ||||
| 
 | ||||
| ifconfig lo0 | ||||
| 
 | ||||
| # Since tests run as root, we also need to be able to ssh to localhost as root. | ||||
| sed -i '' 's/^# *PermitRootLogin.*$/PermitRootLogin yes/;' /etc/ssh/sshd_config | ||||
| 
 | ||||
| if [ "${container}" = "freebsd" ]; then | ||||
|     # Restart sshd for configuration changes and loopback aliases to work. | ||||
|     service sshd restart | ||||
| fi | ||||
| 
 | ||||
| # Generate our ssh key and add it to our authorized_keys file. | ||||
| # We also need to add localhost's server keys to known_hosts. | ||||
| 
 | ||||
| if [ ! -f "${HOME}/.ssh/id_rsa.pub" ]; then | ||||
|     ssh-keygen -q -t rsa -N '' -f "${HOME}/.ssh/id_rsa" | ||||
|     cp "${HOME}/.ssh/id_rsa.pub" "${HOME}/.ssh/authorized_keys" | ||||
|     for key in /etc/ssh/ssh_host_*_key.pub; do | ||||
|         pk=$(cat "${key}") | ||||
|         echo "localhost ${pk}" >> "${HOME}/.ssh/known_hosts" | ||||
|     done | ||||
| fi | ||||
| 
 | ||||
| repo_name="${REPO_NAME:-ansible}" | ||||
| 
 | ||||
| if [ -d "${build_dir}" ]; then | ||||
|     cd "${build_dir}" | ||||
| elif [ "${repo_name}" = "ansible" ]; then | ||||
|     git clone "${REPOSITORY_URL:-https://github.com/ansible/ansible.git}" "${build_dir}" | ||||
|     cd "${build_dir}" | ||||
| 
 | ||||
|     if [ "${PULL_REQUEST:-false}" = "false" ]; then | ||||
|         git checkout -f "${BRANCH:-devel}" -- | ||||
|         git reset --hard "${COMMIT:-HEAD}" | ||||
|     else | ||||
|         git fetch origin "pull/${PULL_REQUEST}/head" | ||||
|         git checkout -f FETCH_HEAD | ||||
|         git merge "origin/${BRANCH}" | ||||
|     fi | ||||
| 
 | ||||
|     git submodule init | ||||
|     git submodule sync | ||||
|     git submodule update | ||||
| else | ||||
|     case "${repo_name}" in | ||||
|         "ansible-modules-core") | ||||
|             this_module_group="core" | ||||
|             ;; | ||||
|         "ansible-modules-extras") | ||||
|             this_module_group="extras" | ||||
|             ;; | ||||
|         *) | ||||
|             echo "Unsupported repo name: ${repo_name}" | ||||
|             exit 1 | ||||
|             ;; | ||||
|     esac | ||||
| 
 | ||||
|     git clone "https://github.com/ansible/ansible.git" "${build_dir}" | ||||
| 
 | ||||
|     cd "${build_dir}" | ||||
| 
 | ||||
|     git submodule init | ||||
|     git submodule sync | ||||
|     git submodule update | ||||
| 
 | ||||
|     cd "${build_dir}/lib/ansible/modules/${this_module_group}" | ||||
| 
 | ||||
|     if [ "${PULL_REQUEST:-false}" = "false" ]; then | ||||
|         echo "Only pull requests are supported for module repositories." | ||||
|         exit | ||||
|     else | ||||
|         git fetch origin "pull/${PULL_REQUEST}/head" | ||||
|         git checkout -f FETCH_HEAD | ||||
|         git merge "origin/${BRANCH}" | ||||
|     fi | ||||
| 
 | ||||
|     cd "${build_dir}" | ||||
| fi | ||||
| 
 | ||||
| set +u | ||||
| . hacking/env-setup | ||||
| set -u | ||||
| 
 | ||||
| cd test/integration | ||||
| 
 | ||||
| if [ "${container}" = "osx" ]; then | ||||
|     # FIXME: these test targets fail | ||||
|     sed -i '' 's/ test_gathering_facts / /;' Makefile | ||||
| 
 | ||||
|     # FIXME: these tests fail | ||||
|     skip_tags="${skip_tags},test_iterators,test_git" | ||||
| 
 | ||||
|     # test_template assumes the group 'root' exists if this variable is not set | ||||
|     export GROUP=wheel | ||||
| fi | ||||
| 
 | ||||
| # TODO: support httptester via reverse ssh tunnel | ||||
| 
 | ||||
| rm -rf "/tmp/shippable" | ||||
| mkdir -p "/tmp/shippable/testresults" | ||||
| 
 | ||||
| # TODO: enable jail test | ||||
| # shellcheck disable=SC2086 | ||||
| JUNIT_OUTPUT_DIR="/tmp/shippable/testresults" \ | ||||
|     ANSIBLE_FORCE_COLOR="${force_color}" \ | ||||
|     ANSIBLE_CALLBACK_WHITELIST=junit \ | ||||
|     TEST_FLAGS="-e ansible_python_interpreter=/usr/local/bin/python2 --skip-tags '${skip_tags}' ${test_flags}" \ | ||||
|     container="${container}" \ | ||||
|     ${make} ${test_target} | ||||
|  | @ -1,8 +0,0 @@ | |||
| cryptography | ||||
| junit-xml | ||||
| ndg-httpsclient | ||||
| pyasn1 | ||||
| pyopenssl | ||||
| requests | ||||
| pywinrm | ||||
| xmltodict | ||||
|  | @ -1,191 +0,0 @@ | |||
| #!/bin/bash -eux | ||||
| 
 | ||||
| set -o pipefail | ||||
| 
 | ||||
| source_root=$(python -c "from os import path; print(path.abspath(path.join(path.dirname('$0'), '../../..')))") | ||||
| 
 | ||||
| test_flags="${TEST_FLAGS:-}" | ||||
| test_platform="${PLATFORM}" | ||||
| test_version="${VERSION}" | ||||
| 
 | ||||
| test_target=(${TARGET}) | ||||
| 
 | ||||
| instance_id="${INSTANCE_ID:-}" | ||||
| start_instance= | ||||
| 
 | ||||
| if [ "${instance_id}" == "" ]; then | ||||
|     instance_id=$(python -c 'import uuid; print(uuid.uuid4())') | ||||
|     start_instance=1 | ||||
| fi | ||||
| 
 | ||||
| # Set this to a non-empty value to skip immediate termination of the remote instance after tests finish. | ||||
| # The remote instance will still be auto-terminated when the remote time limit is reached. | ||||
| keep_instance="${KEEP_INSTANCE:-}" | ||||
| 
 | ||||
| # Force ansible color output by default. | ||||
| # To disable color force mode use FORCE_COLOR=0 | ||||
| force_color="${FORCE_COLOR:-1}" | ||||
| 
 | ||||
| if [ "${SHIPPABLE:-}" = "true" ]; then | ||||
|     test_auth="shippable" | ||||
| else | ||||
|     test_auth="remote" | ||||
| fi | ||||
| 
 | ||||
| case "${test_platform}" in | ||||
|     "windows") | ||||
|         ci_endpoint="https://14blg63h2i.execute-api.us-east-1.amazonaws.com" | ||||
|         ;; | ||||
|     "freebsd") | ||||
|         ci_endpoint="https://14blg63h2i.execute-api.us-east-1.amazonaws.com" | ||||
|         ;; | ||||
|     "osx") | ||||
|         ci_endpoint="https://osx.testing.ansible.com" | ||||
|         ;; | ||||
|     *) | ||||
|         echo "unsupported platform: ${test_platform}" | ||||
|         exit 1 | ||||
|         ;; | ||||
| esac | ||||
| 
 | ||||
| env | ||||
| 
 | ||||
| case "${test_platform}" in | ||||
|     "windows") | ||||
|         args="" | ||||
|         ;; | ||||
|     *) | ||||
|         ssh_key="${HOME}/.ssh/id_rsa" | ||||
|         args="--public-key=${ssh_key}.pub" | ||||
|         if [ ! -f "${ssh_key}.pub" ]; then | ||||
|             ssh-keygen -q -t rsa -N '' -f "${ssh_key}" | ||||
|         fi | ||||
|         ;; | ||||
| esac | ||||
| 
 | ||||
| pre_cleanup= | ||||
| 
 | ||||
| function cleanup | ||||
| { | ||||
|     if [ "${pre_cleanup}" != '' ]; then | ||||
|         "${pre_cleanup}" | ||||
|     fi | ||||
| 
 | ||||
|     if [ "${keep_instance}" = '' ]; then | ||||
|         "${source_root}/test/utils/shippable/ansible-core-ci" --endpoint "${ci_endpoint}" -v stop "${instance_id}" | ||||
|     fi | ||||
| 
 | ||||
|     echo "instance_id: ${instance_id}" | ||||
| } | ||||
| 
 | ||||
| trap cleanup EXIT INT TERM | ||||
| 
 | ||||
| if [ ${start_instance} ]; then | ||||
|     # shellcheck disable=SC2086 | ||||
|     "${source_root}/test/utils/shippable/ansible-core-ci" --endpoint "${ci_endpoint}" -v \ | ||||
|         start --id "${instance_id}" "${test_auth}" "${test_platform}" "${test_version}" ${args} | ||||
| fi | ||||
| 
 | ||||
| pip install "${source_root}" --upgrade | ||||
| pip install -r "${source_root}/test/utils/shippable/remote-requirements.txt" --upgrade | ||||
| pip list | ||||
| 
 | ||||
| cd "${source_root}" | ||||
| source hacking/env-setup | ||||
| cd test/integration | ||||
| 
 | ||||
| case "${test_platform}" in | ||||
|     "windows") | ||||
|         inventory_template="${source_root}/test/integration/inventory.winrm.template" | ||||
|         inventory_file="${source_root}/test/integration/inventory.winrm" | ||||
|         ping_module="win_ping" | ||||
|         ping_host="windows" | ||||
|         test_function="test_windows" | ||||
|         ;; | ||||
|     *) | ||||
|         inventory_template="${source_root}/test/integration/inventory.remote.template" | ||||
|         inventory_file="${source_root}/test/integration/inventory.remote" | ||||
|         ping_module="ping" | ||||
|         ping_host="remote" | ||||
|         test_function="test_remote" | ||||
|         ;; | ||||
| esac | ||||
| 
 | ||||
| "${source_root}/test/utils/shippable/ansible-core-ci" --endpoint "${ci_endpoint}" -v \ | ||||
|     get "${instance_id}" \ | ||||
|     --template "${inventory_template}" \ | ||||
|     > "${inventory_file}" \ | ||||
| 
 | ||||
| # hack to make sure instance is responding before beginning tests | ||||
| n=60 | ||||
| for i in $(seq 1 ${n}); do | ||||
|     echo "Verifying host is responding ($i of $n)" | ||||
|     if \ | ||||
|         ANSIBLE_SSH_ARGS='' \ | ||||
|         ANSIBLE_HOST_KEY_CHECKING=False \ | ||||
|         ANSIBLE_FORCE_COLOR="${force_color}" \ | ||||
|         ansible -m "${ping_module}" -i "${inventory_file}" "${ping_host}"; then | ||||
|         break | ||||
|     fi | ||||
|     sleep 5 | ||||
| done | ||||
| 
 | ||||
| test_windows() { | ||||
|     JUNIT_OUTPUT_DIR="${source_root}/shippable/testresults" \ | ||||
|         ANSIBLE_FORCE_COLOR="${force_color}" \ | ||||
|         ANSIBLE_CALLBACK_WHITELIST=junit \ | ||||
|         TEST_FLAGS="${test_flags}" \ | ||||
|         LC_ALL=en_US.utf-8 \ | ||||
|         make "${test_target[@]}" | ||||
| } | ||||
| 
 | ||||
| test_remote() { | ||||
|     endpoint=$("${source_root}/test/utils/shippable/ansible-core-ci" --endpoint "${ci_endpoint}" get \ | ||||
|         "${instance_id}" \ | ||||
|         --template <(echo "@ansible_user@@ansible_host")) | ||||
|     ssh_port=$("${source_root}/test/utils/shippable/ansible-core-ci" --endpoint "${ci_endpoint}" get \ | ||||
|         "${instance_id}" \ | ||||
|         --template <(echo "@ansible_port")) | ||||
| 
 | ||||
| ( | ||||
| cat <<EOF | ||||
| env \ | ||||
| PLATFORM='${test_platform}' \ | ||||
| REPOSITORY_URL='${REPOSITORY_URL:-}' \ | ||||
| REPO_NAME='${REPO_NAME:-}' \ | ||||
| PULL_REQUEST='${PULL_REQUEST:-}' \ | ||||
| BRANCH='${BRANCH:-}' \ | ||||
| COMMIT='${COMMIT:-}' \ | ||||
| FORCE_COLOR='${force_color}' \ | ||||
| TARGET='${test_target[*]}' \ | ||||
| TEST_FLAGS='${test_flags}' \ | ||||
| /bin/sh -e /tmp/remote-integration.sh | ||||
| EOF | ||||
| ) > /tmp/remote-script.sh | ||||
| 
 | ||||
| ( | ||||
| cat <<EOF | ||||
| put "${source_root}/test/utils/shippable/remote-integration.sh" "/tmp/remote-integration.sh" | ||||
| put "/tmp/remote-script.sh" "/tmp/remote-script.sh" | ||||
| EOF | ||||
| ) | sftp -b - -o StrictHostKeyChecking=no -P "${ssh_port}" "${endpoint}" | ||||
| 
 | ||||
|     pre_cleanup=test_remote_cleanup | ||||
| 
 | ||||
|     case "${test_platform}" in | ||||
|         "osx") | ||||
|             become="sudo -i PATH=/usr/local/bin:\$PATH" | ||||
|             ;; | ||||
|         *) | ||||
|             become="su -l root -c" | ||||
|             ;; | ||||
|     esac | ||||
| 
 | ||||
|     ssh -p "${ssh_port}" "${endpoint}" "${become}" "'chmod +x /tmp/remote-script.sh; /tmp/remote-script.sh'" | ||||
| } | ||||
| 
 | ||||
| test_remote_cleanup() { | ||||
|     scp -r -P "${ssh_port}" "${endpoint}:/tmp/shippable" "${source_root}" | ||||
| } | ||||
| 
 | ||||
| "${test_function}" | ||||
|  | @ -1,6 +0,0 @@ | |||
| tox | ||||
| pyyaml | ||||
| jinja2 | ||||
| setuptools | ||||
| mock | ||||
| voluptuous==0.8.8 | ||||
|  | @ -1,32 +0,0 @@ | |||
| #!/bin/bash -eux | ||||
| 
 | ||||
| source_root=$(python -c "from os import path; print(path.abspath(path.join(path.dirname('$0'), '../../..')))") | ||||
| 
 | ||||
| install_deps="${INSTALL_DEPS:-}" | ||||
| 
 | ||||
| cd "${source_root}" | ||||
| 
 | ||||
| if [ "${TOXENV}" = 'py24' ]; then | ||||
|     if [ "${install_deps}" != "" ]; then | ||||
|         add-apt-repository ppa:fkrull/deadsnakes && apt-get update -qq && apt-get install python2.4 -qq | ||||
|     fi | ||||
| 
 | ||||
|     python2.4 -V | ||||
|     python2.4 -m compileall -fq -x 'module_utils/(a10|rax|openstack|cloud|ec2|gce|lxd|docker_common|azure_rm_common|vca|vmware|gcp|gcdns).py' lib/ansible/module_utils | ||||
| else | ||||
|     if [ "${install_deps}" != "" ]; then | ||||
|         pip install -r "${source_root}/test/utils/shippable/sanity-requirements.txt" --upgrade | ||||
|         pip list | ||||
|     fi | ||||
| 
 | ||||
|     xunit_dir="${source_root}/shippable/testresults" | ||||
|     coverage_dir="${source_root}/shippable/codecoverage" | ||||
| 
 | ||||
|     mkdir -p "${xunit_dir}" | ||||
|     mkdir -p "${coverage_dir}" | ||||
| 
 | ||||
|     xunit_file="${xunit_dir}/nosetests-xunit.xml" | ||||
|     coverage_file="${coverage_dir}/nosetests-coverage.xml" | ||||
| 
 | ||||
|     TOX_TESTENV_PASSENV=NOSETESTS NOSETESTS="nosetests --with-xunit --xunit-file='${xunit_file}' --cover-xml --cover-xml-file='${coverage_file}'" tox | ||||
| fi | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue