Merge branch 'main' into lie_test_require_ssl

This commit is contained in:
Laurent Indermuehle 2024-04-11 19:26:18 +02:00
commit 902392e861
No known key found for this signature in database
GPG key ID: 93FA944C9F34DD09
21 changed files with 59 additions and 63 deletions

View file

@ -1,6 +1,6 @@
--- ---
name: Plugins CI name: Plugins CI
on: on: # yamllint disable-line rule:truthy
push: push:
paths: paths:
- 'plugins/**' - 'plugins/**'
@ -18,15 +18,16 @@ on:
jobs: jobs:
sanity: sanity:
name: "Sanity (Ansible: ${{ matrix.ansible }})" name: "Sanity (Ansible: ${{ matrix.ansible }})"
runs-on: ubuntu-20.04 runs-on: ubuntu-22.04
strategy: strategy:
matrix: matrix:
ansible: ansible:
- stable-2.14
- stable-2.15 - stable-2.15
- stable-2.16 - stable-2.16
- stable-2.17
- devel - devel
steps: steps:
# https://github.com/ansible-community/ansible-test-gh-action
- name: Perform sanity testing - name: Perform sanity testing
uses: ansible-community/ansible-test-gh-action@release/v1 uses: ansible-community/ansible-test-gh-action@release/v1
with: with:
@ -36,14 +37,14 @@ jobs:
integration: integration:
name: "Integration (Python: ${{ matrix.python }}, Ansible: ${{ matrix.ansible }}, DB: ${{ matrix.db_engine_name }} ${{ matrix.db_engine_version }}, connector: ${{ matrix.connector_name }} ${{ matrix.connector_version }})" name: "Integration (Python: ${{ matrix.python }}, Ansible: ${{ matrix.ansible }}, DB: ${{ matrix.db_engine_name }} ${{ matrix.db_engine_version }}, connector: ${{ matrix.connector_name }} ${{ matrix.connector_version }})"
runs-on: ubuntu-20.04 runs-on: ubuntu-22.04
strategy: strategy:
fail-fast: false fail-fast: false
matrix: matrix:
ansible: ansible:
- stable-2.14
- stable-2.15 - stable-2.15
- stable-2.16 - stable-2.16
- stable-2.17
- devel - devel
db_engine_name: db_engine_name:
- mysql - mysql
@ -111,9 +112,6 @@ jobs:
- db_engine_version: 5.7.40 - db_engine_version: 5.7.40
python: '3.10' python: '3.10'
- db_engine_version: 5.7.40
ansible: stable-2.14
- db_engine_version: 5.7.40 - db_engine_version: 5.7.40
ansible: stable-2.15 ansible: stable-2.15
@ -126,9 +124,6 @@ jobs:
- db_engine_version: 8.0.31 - db_engine_version: 8.0.31
python: '3.8' python: '3.8'
- db_engine_version: 8.0.31
python: '3.8'
- db_engine_version: 10.4.27 - db_engine_version: 10.4.27
python: '3.10' python: '3.10'
@ -174,23 +169,20 @@ jobs:
- python: '3.10' - python: '3.10'
connector_version: 2.0.3 connector_version: 2.0.3
- python: '3.8'
ansible: stable-2.14
- python: '3.8'
ansible: stable-2.15
- python: '3.8' - python: '3.8'
ansible: stable-2.16 ansible: stable-2.16
- python: '3.8'
ansible: stable-2.17
- python: '3.8' - python: '3.8'
ansible: devel ansible: devel
- python: '3.9' - python: '3.9'
ansible: stable-2.15 ansible: stable-2.16
- python: '3.9' - python: '3.9'
ansible: stable-2.16 ansible: stable-2.17
- python: '3.9' - python: '3.9'
ansible: devel ansible: devel
@ -284,16 +276,12 @@ jobs:
fi fi
- name: Set docker_image - name: Set docker_image
run: > run: |-
docker_image_multiline=(" echo "docker_image=ghcr.io/ansible-collections/community.mysql\
ghcr.io/ansible-collections/community.mysql\
/test-container-${{ env.db_client }}\ /test-container-${{ env.db_client }}\
-py${{ env.python_version_flat }}\ -py${{ env.python_version_flat }}\
-${{ matrix.connector_name }}${{ env.connector_version_flat }}\ -${{ matrix.connector_name }}${{ env.connector_version_flat }}\
:latest") :latest" >> $GITHUB_ENV
echo "docker_image=$(printf '%s' $docker_image_multiline)"
>> $GITHUB_ENV
- name: >- - name: >-
Perform integration testing against Perform integration testing against
@ -332,7 +320,7 @@ jobs:
testing-type: integration testing-type: integration
units: units:
runs-on: ubuntu-20.04 runs-on: ubuntu-22.04
name: Units (Ⓐ${{ matrix.ansible }}) name: Units (Ⓐ${{ matrix.ansible }})
strategy: strategy:
# As soon as the first unit test fails, # As soon as the first unit test fails,
@ -340,20 +328,20 @@ jobs:
fail-fast: true fail-fast: true
matrix: matrix:
ansible: ansible:
- stable-2.14
- stable-2.15 - stable-2.15
- stable-2.16 - stable-2.16
- stable-2.17
- devel - devel
python: python:
- 3.8 - 3.8
- 3.9 - 3.9
exclude: exclude:
- python: '3.8'
ansible: stable-2.14
- python: '3.8' - python: '3.8'
ansible: stable-2.15 ansible: stable-2.15
- python: '3.8' - python: '3.8'
ansible: stable-2.16 ansible: stable-2.16
- python: '3.8'
ansible: stable-2.17
- python: '3.8' - python: '3.8'
ansible: devel ansible: devel

View file

@ -1,6 +1,6 @@
--- ---
name: Roles CI name: Roles CI
on: on: # yamllint disable-line rule:truthy
push: push:
paths: paths:
- 'roles/**' - 'roles/**'
@ -15,7 +15,7 @@ on:
jobs: jobs:
molecule: molecule:
name: "Molecule (Python: ${{ matrix.python }}, Ansible: ${{ matrix.ansible }}, MySQL: ${{ matrix.mysql }})" name: "Molecule (Python: ${{ matrix.python }}, Ansible: ${{ matrix.ansible }}, MySQL: ${{ matrix.mysql }})"
runs-on: ubuntu-20.04 runs-on: ubuntu-22.04
env: env:
PY_COLORS: 1 PY_COLORS: 1
ANSIBLE_FORCE_COLOR: 1 ANSIBLE_FORCE_COLOR: 1
@ -24,26 +24,36 @@ jobs:
mysql: mysql:
- 2.0.12 - 2.0.12
ansible: ansible:
- stable-2.13
- stable-2.14
- stable-2.15 - stable-2.15
- stable-2.16
- stable-2.17
- devel - devel
python: python:
- 3.8 - '3.8'
- 3.9 - '3.9'
- '3.10'
exclude: exclude:
- python: 3.8 - python: 3.8
ansible: stable-2.17
- python: 3.9
ansible: stable-2.17
- python: 3.8
ansible: devel
- python: 3.9
ansible: devel ansible: devel
steps: steps:
- name: Check out code - name: Check out code
uses: actions/checkout@v2 uses: actions/checkout@v3
with: with:
path: ansible_collections/community/mysql path: ansible_collections/community/mysql
- name: Set up Python ${{ matrix.python }} - name: Set up Python ${{ matrix.python }}
uses: actions/setup-python@v2 uses: actions/setup-python@v4
with: with:
python-version: ${{ matrix.python }} python-version: ${{ matrix.python }}

View file

@ -1,7 +1,7 @@
--- ---
name: Build Docker Image for ansible-test name: Build Docker Image for ansible-test
on: on: # yamllint disable-line rule:truthy
workflow_call: workflow_call:
inputs: inputs:
registry: registry:

View file

@ -1,7 +1,7 @@
--- ---
name: Docker Image CI mariadb-py310-mysqlclient211 name: Docker Image CI mariadb-py310-mysqlclient211
on: on: # yamllint disable-line rule:truthy
push: push:
paths: paths:
- 'test-containers/mariadb-py310-mysqlclient211/**' - 'test-containers/mariadb-py310-mysqlclient211/**'

View file

@ -1,7 +1,7 @@
--- ---
name: Docker Image CI mariadb-py310-pymysql102 name: Docker Image CI mariadb-py310-pymysql102
on: on: # yamllint disable-line rule:truthy
push: push:
paths: paths:
- 'test-containers/mariadb-py310-pymysql102/**' - 'test-containers/mariadb-py310-pymysql102/**'

View file

@ -1,7 +1,7 @@
--- ---
name: Docker Image CI mariadb-py38-mysqlclient201 name: Docker Image CI mariadb-py38-mysqlclient201
on: on: # yamllint disable-line rule:truthy
push: push:
paths: paths:
- 'test-containers/mariadb-py38-mysqlclient201/**' - 'test-containers/mariadb-py38-mysqlclient201/**'

View file

@ -1,7 +1,7 @@
--- ---
name: Docker Image CI mariadb-py38-pymysql093 name: Docker Image CI mariadb-py38-pymysql093
on: on: # yamllint disable-line rule:truthy
push: push:
paths: paths:
- 'test-containers/mariadb-py38-pymysql093/**' - 'test-containers/mariadb-py38-pymysql093/**'

View file

@ -1,7 +1,7 @@
--- ---
name: Docker Image CI mariadb-py39-mysqlclient203 name: Docker Image CI mariadb-py39-mysqlclient203
on: on: # yamllint disable-line rule:truthy
push: push:
paths: paths:
- 'test-containers/mariadb-py39-mysqlclient203/**' - 'test-containers/mariadb-py39-mysqlclient203/**'

View file

@ -1,7 +1,7 @@
--- ---
name: Docker Image CI mariadb-py39-pymysql093 name: Docker Image CI mariadb-py39-pymysql093
on: on: # yamllint disable-line rule:truthy
push: push:
paths: paths:
- 'test-containers/mariadb-py39-pymysql093/**' - 'test-containers/mariadb-py39-pymysql093/**'

View file

@ -1,7 +1,7 @@
--- ---
name: Docker Image CI my57-py38-mysqlclient201 name: Docker Image CI my57-py38-mysqlclient201
on: on: # yamllint disable-line rule:truthy
push: push:
paths: paths:
- 'test-containers/my57-py38-mysqlclient201/**' - 'test-containers/my57-py38-mysqlclient201/**'

View file

@ -1,7 +1,7 @@
--- ---
name: Docker Image CI my57-py38-pymysql0711 name: Docker Image CI my57-py38-pymysql0711
on: on: # yamllint disable-line rule:truthy
push: push:
paths: paths:
- 'test-containers/my57-py38-pymysql0711/**' - 'test-containers/my57-py38-pymysql0711/**'

View file

@ -1,7 +1,7 @@
--- ---
name: Docker Image CI my57-py38-pymysql093 name: Docker Image CI my57-py38-pymysql093
on: on: # yamllint disable-line rule:truthy
push: push:
paths: paths:
- 'test-containers/my57-py38-pymysql093/**' - 'test-containers/my57-py38-pymysql093/**'

View file

@ -1,7 +1,7 @@
--- ---
name: Docker Image CI mysql-py310-mysqlclient211 name: Docker Image CI mysql-py310-mysqlclient211
on: on: # yamllint disable-line rule:truthy
push: push:
paths: paths:
- 'test-containers/mysql-py310-mysqlclient211/**' - 'test-containers/mysql-py310-mysqlclient211/**'

View file

@ -1,7 +1,7 @@
--- ---
name: Docker Image CI mysql-py310-pymysql102 name: Docker Image CI mysql-py310-pymysql102
on: on: # yamllint disable-line rule:truthy
push: push:
paths: paths:
- 'test-containers/mysql-py310-pymysql102/**' - 'test-containers/mysql-py310-pymysql102/**'

View file

@ -1,7 +1,7 @@
--- ---
name: Docker Image CI mysql-py38-mysqlclient201 name: Docker Image CI mysql-py38-mysqlclient201
on: on: # yamllint disable-line rule:truthy
push: push:
paths: paths:
- 'test-containers/mysql-py38-mysqlclient201/**' - 'test-containers/mysql-py38-mysqlclient201/**'

View file

@ -1,7 +1,7 @@
--- ---
name: Docker Image CI mysql-py38-pymysql093 name: Docker Image CI mysql-py38-pymysql093
on: on: # yamllint disable-line rule:truthy
push: push:
paths: paths:
- 'test-containers/mysql-py38-pymysql093/**' - 'test-containers/mysql-py38-pymysql093/**'

View file

@ -1,7 +1,7 @@
--- ---
name: Docker Image CI mysql-py39-mysqlclient203 name: Docker Image CI mysql-py39-mysqlclient203
on: on: # yamllint disable-line rule:truthy
push: push:
paths: paths:
- 'test-containers/mysql-py39-mysqlclient203/**' - 'test-containers/mysql-py39-mysqlclient203/**'

View file

@ -1,7 +1,7 @@
--- ---
name: Docker Image CI mysql-py39-pymysql093 name: Docker Image CI mysql-py39-pymysql093
on: on: # yamllint disable-line rule:truthy
push: push:
paths: paths:
- 'test-containers/mysql-py39-pymysql093/*' - 'test-containers/mysql-py39-pymysql093/*'

View file

@ -99,9 +99,9 @@ Here is the table for the support timeline:
### ansible-core ### ansible-core
- stable-2.14
- stable-2.15 - stable-2.15
- stable-2.16 - stable-2.16
- stable-2.17
- current development version - current development version
### Databases ### Databases

View file

@ -49,11 +49,9 @@ The Makefile accept the following options
- `ansible` - `ansible`
- Mandatory: true - Mandatory: true
- Choices: - Choices:
- "stable-2.12"
- "stable-2.13"
- "stable-2.14"
- "stable-2.15" - "stable-2.15"
- "stable-2.16" - "stable-2.16"
- "stable-2.17"
- "devel" - "devel"
- Description: Version of ansible to install in a venv to run ansible-test - Description: Version of ansible to install in a venv to run ansible-test

View file

@ -76,14 +76,14 @@
that: that:
- "'SSL' in reqs" - "'SSL' in reqs"
vars: vars:
- reqs: "{{((old_result.results[0] is skipped | ternary(new_result, old_result)).results | selectattr('item', 'contains', user_name_1) | first).stdout.split('REQUIRE')[1].split(separator)[0].strip()}}" reqs: "{{ ((old_result.results[0] is skipped | ternary(new_result, old_result)).results | selectattr('item', 'contains', user_name_1) | first).stdout.split('REQUIRE')[1].split(separator)[0].strip() }}"
- name: Tls reqs | Assert user2 TLS requirements - name: Tls reqs | Assert user2 TLS requirements
assert: assert:
that: that:
- "'X509' in reqs" - "'X509' in reqs"
vars: vars:
- reqs: "{{((old_result.results[0] is skipped | ternary(new_result, old_result)).results | selectattr('item', 'contains', user_name_2) | first).stdout.split('REQUIRE')[1].split(separator)[0].strip()}}" reqs: "{{ ((old_result.results[0] is skipped | ternary(new_result, old_result)).results | selectattr('item', 'contains', user_name_2) | first).stdout.split('REQUIRE')[1].split(separator)[0].strip() }}"
- name: Tls reqs | Assert user3 TLS requirements - name: Tls reqs | Assert user3 TLS requirements
assert: assert:
@ -92,7 +92,7 @@
- "'/CN=org/O=MyDom, Inc./C=US/ST=Oregon/L=Portland' in (reqs | select('contains', 'ISSUER') | first)" - "'/CN=org/O=MyDom, Inc./C=US/ST=Oregon/L=Portland' in (reqs | select('contains', 'ISSUER') | first)"
- "'ECDHE-ECDSA-AES256-SHA384' in (reqs | select('contains', 'CIPHER') | first)" - "'ECDHE-ECDSA-AES256-SHA384' in (reqs | select('contains', 'CIPHER') | first)"
vars: vars:
- reqs: "{{((old_result.results[0] is skipped | ternary(new_result, old_result)).results | selectattr('item', 'contains', user_name_3) | first).stdout.split('REQUIRE')[1].split(separator)[0].replace(\"' \", \"':\").split(\":\")}}" reqs: "{{ ((old_result.results[0] is skipped | ternary(new_result, old_result)).results | selectattr('item', 'contains', user_name_3) | first).stdout.split('REQUIRE')[1].split(separator)[0].replace(\"' \", \"':\").split(\":\") }}"
# CentOS 6 uses an older version of jinja that does not provide the selectattr filter. # CentOS 6 uses an older version of jinja that does not provide the selectattr filter.
when: ansible_distribution != 'CentOS' or ansible_distribution_major_version != '6' when: ansible_distribution != 'CentOS' or ansible_distribution_major_version != '6'
@ -129,7 +129,7 @@
assert: assert:
that: "'SSL' in reqs" that: "'SSL' in reqs"
vars: vars:
- reqs: "{{(old_result is skipped | ternary(new_result, old_result)).stdout.split('REQUIRE')[1].split(separator)[0].strip()}}" reqs: "{{ (old_result is skipped | ternary(new_result, old_result)).stdout.split('REQUIRE')[1].split(separator)[0].strip() }}"
- name: Tls reqs | Modify user with TLS requirements state=present (expect changed=true) - name: Tls reqs | Modify user with TLS requirements state=present (expect changed=true)
mysql_user: mysql_user:
@ -157,7 +157,7 @@
assert: assert:
that: "'X509' in reqs" that: "'X509' in reqs"
vars: vars:
- reqs: "{{(old_result is skipped | ternary(new_result, old_result)).stdout.split('REQUIRE')[1].split(separator)[0].strip()}}" reqs: "{{ (old_result is skipped | ternary(new_result, old_result)).stdout.split('REQUIRE')[1].split(separator)[0].strip() }}"
- name: Tls reqs | Remove TLS requirements from user (expect changed=true) - name: Tls reqs | Remove TLS requirements from user (expect changed=true)
mysql_user: mysql_user: