openstacksdk/.zuul.yaml
Monty Taylor 185e55bd77 Add python-requires entry indicating 3.5 is required
We require 3.5 now but we didn't add the metadata. Add it.

While OpenStack broadly only supports 3.6, openstacksdk
has a wider audience, including nodepool which still uses
3.5. So add the 3.5 unit tests back.

Use lower-constraints for py35 unit tests because the
upper-constraints have versions of things that have
droppped py35 support already.

Depends-On: https://review.opendev.org/#/c/715467/
Change-Id: I680e0bab5ba3af7be5e914ece64c6bd25d1f2191
2020-03-27 12:13:24 -05:00

431 lines
14 KiB
YAML

- job:
name: openstacksdk-tox-py36-tips
parent: openstack-tox-py36
description: |
Run tox python 36 unittests against master of important libs
vars:
tox_install_siblings: true
zuul_work_dir: src/opendev.org/openstack/openstacksdk
# openstacksdk in required-projects so that osc and keystoneauth
# can add the job as well
required-projects:
- openstack/keystoneauth
- openstack/openstacksdk
- openstack/os-client-config
- project-template:
name: openstacksdk-tox-tips
check:
jobs:
- openstacksdk-tox-py36-tips
gate:
jobs:
- openstacksdk-tox-py36-tips
- job:
name: openstacksdk-functional-devstack-minimum
parent: devstack-tox-functional
description: |
Minimum job for devstack-based functional tests
post-run: playbooks/devstack/post.yaml
roles:
# NOTE: We pull in roles from the tempest repo for stackviz processing.
- zuul: opendev.org/openstack/tempest
required-projects:
# These jobs will DTRT when openstacksdk triggers them, but we want to
# make sure stable branches of openstacksdk never get cloned by other
# people, since stable branches of openstacksdk are, well, not actually
# things.
- name: openstack/openstacksdk
override-branch: master
- name: openstack/os-client-config
override-branch: master
timeout: 9000
vars:
devstack_localrc:
Q_ML2_PLUGIN_EXT_DRIVERS: qos,port_security
devstack_services:
# sdk doesn't need vnc access
n-cauth: false
n-novnc: false
# sdk testing uses config drive only
n-api-meta: false
q-meta: false
tox_environment:
# Do we really need to set this? It's cargo culted
PYTHONUNBUFFERED: 'true'
# Is there a way we can query the localconf variable to get these
# rather than setting them explicitly?
OPENSTACKSDK_HAS_DESIGNATE: 0
OPENSTACKSDK_HAS_HEAT: 0
OPENSTACKSDK_HAS_MAGNUM: 0
OPENSTACKSDK_HAS_NEUTRON: 1
OPENSTACKSDK_HAS_SWIFT: 1
tox_install_siblings: false
tox_envlist: functional
zuul_copy_output:
'{{ ansible_user_dir }}/stackviz': logs
zuul_work_dir: src/opendev.org/openstack/openstacksdk
- job:
name: openstacksdk-functional-devstack-base
parent: openstacksdk-functional-devstack-minimum
description: |
Base job for devstack-based functional tests
vars:
devstack_plugins:
neutron: https://opendev.org/openstack/neutron
devstack_local_conf:
post-config:
$CINDER_CONF:
DEFAULT:
osapi_max_limit: 6
- job:
name: openstacksdk-functional-devstack-legacy
parent: openstacksdk-functional-devstack-base
description: |
Run openstacksdk functional tests against a legacy devstack
voting: false
vars:
devstack_localrc:
ENABLE_IDENTITY_V2: true
FLAT_INTERFACE: br_flat
PUBLIC_INTERFACE: br_pub
tox_environment:
OPENSTACKSDK_USE_KEYSTONE_V2: 1
OPENSTACKSDK_HAS_NEUTRON: 0
override-branch: stable/newton
- job:
name: openstacksdk-functional-devstack
parent: openstacksdk-functional-devstack-base
description: |
Run openstacksdk functional tests against a master devstack
required-projects:
- openstack/heat
vars:
devstack_localrc:
DISABLE_AMP_IMAGE_BUILD: true
Q_SERVICE_PLUGIN_CLASSES: qos,trunk
devstack_plugins:
heat: https://opendev.org/openstack/heat
tox_environment:
OPENSTACKSDK_HAS_HEAT: 1
devstack_services:
neutron-qos: true
neutron-trunk: true
neutron-port-forwarding: true
- job:
name: openstacksdk-functional-devstack-networking
parent: openstacksdk-functional-devstack
description: |
Run openstacksdk functional tests against a devstack with advanced
networking services enabled.
required-projects:
- openstack/designate
- openstack/neutron-fwaas
- openstack/octavia
vars:
devstack_local_conf:
post-config:
$OCTAVIA_CONF:
DEFAULT:
debug: true
controller_worker:
amphora_driver: amphora_noop_driver
compute_driver: compute_noop_driver
network_driver: network_noop_driver
certificates:
cert_manager: local_cert_manager
$NEUTRON_CONF:
fwaas:
agent_version: v2
driver: iptables_v2
enabled: true
firewall_l2_driver: ovs
devstack_localrc:
Q_SERVICE_PLUGIN_CLASSES: qos,trunk,firewall_v2
devstack_plugins:
designate: https://opendev.org/openstack/designate
octavia: https://opendev.org/openstack/octavia
neutron-fwaas: https://opendev.org/openstack/neutron-fwaas
devstack_services:
designate: true
octavia: true
o-api: true
o-cw: true
o-hm: true
o-hk: true
neutron-dns: true
neutron-fwaas-v2: true
s-account: false
s-container: false
s-object: false
s-proxy: false
h-eng: false
h-api: false
h-api-cfn: false
tox_environment:
OPENSTACKSDK_HAS_DESIGNATE: 1
OPENSTACKSDK_HAS_SWIFT: 0
OPENSTACKSDK_HAS_HEAT: 0
- job:
name: openstacksdk-functional-devstack-tips
parent: openstacksdk-functional-devstack
description: |
Run openstacksdk functional tests with tips of library dependencies
against a master devstack.
required-projects:
- openstack/keystoneauth
- openstack/openstacksdk
- openstack/os-client-config
vars:
tox_install_siblings: true
- job:
name: openstacksdk-functional-devstack-magnum
parent: openstacksdk-functional-devstack
description: |
Run openstacksdk functional tests against a master devstack with magnum
required-projects:
- openstack/magnum
- openstack/python-magnumclient
vars:
devstack_plugins:
magnum: https://opendev.org/openstack/magnum
devstack_localrc:
MAGNUM_GUEST_IMAGE_URL: https://tarballs.openstack.org/magnum/images/fedora-atomic-f23-dib.qcow2
MAGNUM_IMAGE_NAME: fedora-atomic-f23-dib
devstack_services:
s-account: false
s-container: false
s-object: false
s-proxy: false
tox_environment:
OPENSTACKSDK_HAS_SWIFT: 0
OPENSTACKSDK_HAS_MAGNUM: 1
- job:
name: openstacksdk-functional-devstack-senlin
parent: openstacksdk-functional-devstack
description: |
Run openstacksdk functional tests against a master devstack with senlin
required-projects:
- openstack/senlin
vars:
devstack_plugins:
senlin: https://opendev.org/openstack/senlin
devstack_services:
s-account: false
s-container: false
s-object: false
s-proxy: false
tox_environment:
OPENSTACKSDK_HAS_SWIFT: 0
OPENSTACKSDK_HAS_SENLIN: 1
- job:
name: openstacksdk-functional-devstack-ironic
parent: openstacksdk-functional-devstack-minimum
description: |
Run openstacksdk functional tests against a master devstack with ironic
required-projects:
- openstack/ironic
- openstack/ironic-python-agent-builder
vars:
devstack_localrc:
OVERRIDE_PUBLIC_BRIDGE_MTU: 1400
IRONIC_BAREMETAL_BASIC_OPS: true
IRONIC_BUILD_DEPLOY_RAMDISK: false
IRONIC_CALLBACK_TIMEOUT: 600
IRONIC_DEPLOY_DRIVER: ipmi
IRONIC_RAMDISK_TYPE: tinyipa
IRONIC_VM_COUNT: 6
IRONIC_VM_LOG_DIR: '{{ devstack_base_dir }}/ironic-bm-logs'
IRONIC_VM_SPECS_RAM: 384
devstack_plugins:
ironic: https://opendev.org/openstack/ironic
devstack_services:
c-api: false
c-bak: false
c-sch: false
c-vol: false
cinder: false
s-account: false
s-container: false
s-object: false
s-proxy: false
n-api: false
n-api-meta: false
n-cauth: false
n-cond: false
n-cpu: false
n-novnc: false
n-obj: false
n-sch: false
nova: false
placement-api: false
tox_environment:
OPENSTACKSDK_HAS_IRONIC: 1
# NOTE(dtantsur): this job cannot run many regular tests (e.g. compute
# tests will take too long), so limiting it to baremetal tests only.
OPENSTACKSDK_TESTS_SUBDIR: baremetal
zuul_copy_output:
'{{ devstack_base_dir }}/ironic-bm-logs': logs
- job:
name: openstacksdk-ansible-functional-devstack
parent: openstacksdk-functional-devstack
description: |
Run openstacksdk ansible functional tests against a master devstack
using released version of ansible.
vars:
tox_envlist: ansible
- job:
name: openstacksdk-ansible-devel-functional-devstack
parent: openstacksdk-ansible-functional-devstack
description: |
Run openstacksdk ansible functional tests against a master devstack
using git devel branch version of ansible.
branches: ^(devel|master)$
required-projects:
- name: github.com/ansible/ansible
override-checkout: devel
- name: openstack/openstacksdk
override-checkout: master
- name: openstack/devstack
override-checkout: master
vars:
# test-matrix grabs branch from the zuul branch setting. If the job
# is triggered by ansible, that branch will be devel which doesn't
# make sense to devstack. Override so that we run the right thing.
test_matrix_branch: master
tox_install_siblings: true
- job:
name: openstacksdk-ansible-stable-2.6-functional-devstack
parent: openstacksdk-ansible-functional-devstack
description: |
Run openstacksdk ansible functional tests against a master devstack
using git stable-2.6 branch version of ansible.
branches: ^(stable-2.6|master)$
required-projects:
- name: github.com/ansible/ansible
override-checkout: stable-2.6
- name: openstack/openstacksdk
override-checkout: master
- name: openstack/devstack
override-checkout: master
vars:
# test-matrix grabs branch from the zuul branch setting. If the job
# is triggered by ansible, that branch will be devel which doesn't
# make sense to devstack. Override so that we run the right thing.
test_matrix_branch: master
tox_install_siblings: true
- job:
name: openstacksdk-ansible-stable-2.8-functional-devstack
parent: openstacksdk-ansible-functional-devstack
description: |
Run openstacksdk ansible functional tests against a master devstack
using git stable-2.8 branch version of ansible.
branches: ^(stable-2.8|master)$
required-projects:
- name: github.com/ansible/ansible
override-checkout: stable-2.8
- name: openstack/openstacksdk
override-checkout: master
- name: openstack/devstack
override-checkout: master
vars:
# test-matrix grabs branch from the zuul branch setting. If the job
# is triggered by ansible, that branch will be devel which doesn't
# make sense to devstack. Override so that we run the right thing.
test_matrix_branch: master
tox_install_siblings: true
- job:
name: openstacksdk-functional-devstack-masakari
parent: openstacksdk-functional-devstack-minimum
description: |
Run openstacksdk functional tests against a master devstack with masakari
required-projects:
- openstack/masakari
- openstack/masakari-monitors
vars:
devstack_plugins:
masakari: https://opendev.org/openstack/masakari
devstack_services:
masakari-api: true
masakari-engine: true
tox_environment:
OPENSTACKSDK_HAS_MASAKARI: 1
OPENSTACKSDK_TESTS_SUBDIR: instance_ha
zuul_copy_output:
'{{ devstack_base_dir }}/masakari-logs': logs
- job:
name: metalsmith-integration-openstacksdk-src
parent: metalsmith-integration-glance-netboot-cirros-direct
required-projects:
- openstack/openstacksdk
- job:
name: ironic-inspector-tempest-openstacksdk-src
parent: ironic-inspector-tempest
required-projects:
- openstack/openstacksdk
- project-template:
name: openstacksdk-functional-tips
check:
jobs:
- openstacksdk-functional-devstack-tips
gate:
jobs:
- openstacksdk-functional-devstack-tips
- project:
templates:
- check-requirements
- openstack-lower-constraints-jobs
- openstack-python35-jobs
- openstack-python3-ussuri-jobs
- openstacksdk-functional-tips
- openstacksdk-tox-tips
- os-client-config-tox-tips
- osc-tox-unit-tips
- publish-openstack-docs-pti
- release-notes-jobs-python3
check:
jobs:
- openstacksdk-functional-devstack
- openstacksdk-functional-devstack-networking
- openstacksdk-functional-devstack-senlin
- openstacksdk-functional-devstack-magnum:
voting: false
- openstacksdk-functional-devstack-masakari:
voting: false
- openstacksdk-functional-devstack-ironic:
voting: false
- osc-functional-devstack-tips:
voting: false
# Ironic jobs, non-voting to avoid tight coupling
- ironic-inspector-tempest-openstacksdk-src:
voting: false
- bifrost-integration-tinyipa-ubuntu-bionic:
voting: false
- metalsmith-integration-openstacksdk-src:
voting: false
- ansible-collections-openstack-functional-devstack:
voting: false
gate:
jobs:
- openstacksdk-functional-devstack
- openstacksdk-functional-devstack-networking
- openstacksdk-functional-devstack-senlin