mirror of
https://github.com/ansible-collections/community.mysql.git
synced 2025-04-05 02:00:31 -07:00
* Enable mysql_native_password for MySQL 8.2+ * Fix connection to MySQL 8 since Ubuntu 20.04 update * Cut mysqlclient form the documentation * Cut tests for Python 3.12 not supported by ansible-test * Upgrade integration controller to ubuntu2204 by removing python ansible-test uses python 3.10 if we specify ubuntu2204. Thus we lose the ability to chose specific version of python to test. But integrations tests are optional for a collection. And we don't catch a issue with Python that often (ever ? I don't recall seen one). This allow us to test MySQL 8.4, so it's a win. * Cut tests for EoL MariaDB 10.4 * Reduce number of test in the matrix * Cut support for intermediate LTS * Fix python command not found with ansible-devel and add the debug This is puzzling me. Why when using ansible devel the python command changes? I know ansible-test install python after starting ubuntu22.04 so the way python is install must changes. * Disable retry-on-error When reading log we tend to look at the bottom, but doing so we find often a idempotent error that are nothing to do with the first error. Disabling this can greatly speedup tests and makes logs more readable. Plus, now GHA jumps automatically at the latest error message. So with this modification, we will always jump to the latest real error message. * Enhance jobs title readability We can't expand the left column on GHA, so the shorter, the better. Use Ⓐ instead of Ansible.
335 lines
10 KiB
YAML
335 lines
10 KiB
YAML
---
|
|
name: Plugins CI
|
|
on: # yamllint disable-line rule:truthy
|
|
push:
|
|
paths:
|
|
- 'plugins/**'
|
|
- 'tests/**'
|
|
- '.github/workflows/ansible-test-plugins.yml'
|
|
pull_request:
|
|
paths:
|
|
- 'plugins/**'
|
|
- 'tests/**'
|
|
- '.github/workflows/ansible-test-plugins.yml'
|
|
schedule:
|
|
- cron: '0 6 * * *'
|
|
|
|
|
|
jobs:
|
|
sanity:
|
|
name: "Sanity (Ⓐ${{ matrix.ansible }})"
|
|
runs-on: ubuntu-22.04
|
|
strategy:
|
|
matrix:
|
|
ansible:
|
|
- stable-2.15
|
|
- stable-2.16
|
|
- stable-2.17
|
|
- devel
|
|
steps:
|
|
# https://github.com/ansible-community/ansible-test-gh-action
|
|
- name: Perform sanity testing
|
|
uses: ansible-community/ansible-test-gh-action@release/v1
|
|
with:
|
|
ansible-core-version: ${{ matrix.ansible }}
|
|
testing-type: sanity
|
|
pull-request-change-detection: true
|
|
|
|
# Use this to chose which version of Python vs Ansible to test:
|
|
# https://docs.ansible.com/ansible/latest/reference_appendices/release_and_maintenance.html#ansible-core-control-node-python-support
|
|
integration:
|
|
name: "Integration (Ⓐ${{ matrix.ansible }}, DB: ${{ matrix.db_engine_name }} ${{ matrix.db_engine_version }}, connector: ${{ matrix.connector_name }} ${{ matrix.connector_version }})"
|
|
runs-on: ubuntu-22.04
|
|
strategy:
|
|
fail-fast: false
|
|
matrix:
|
|
ansible:
|
|
- stable-2.15
|
|
- stable-2.16
|
|
- stable-2.17
|
|
- devel
|
|
db_engine_name:
|
|
- mysql
|
|
- mariadb
|
|
db_engine_version:
|
|
- '8.0.38'
|
|
- '8.4.1'
|
|
- '10.5.25'
|
|
- '10.11.8'
|
|
connector_name:
|
|
- pymysql
|
|
- mysqlclient
|
|
connector_version:
|
|
- '0.9.3'
|
|
- '1.0.2'
|
|
- '1.1.1'
|
|
- '2.0.1'
|
|
- '2.0.3'
|
|
- '2.1.1'
|
|
|
|
include:
|
|
|
|
# RHEL8 context
|
|
- connector_name: pymysql
|
|
connector_version: '0.10.1'
|
|
ansible: stable-2.16
|
|
db_engine_name: mariadb
|
|
db_engine_version: '10.11.8'
|
|
|
|
# RHEL9 context
|
|
# - connector_name: pymysql
|
|
# connector_version: '1.1.1'
|
|
# ansible: stable-2.17
|
|
# db_engine_name: mariadb
|
|
# db_engine_version: '10.11.8'
|
|
# This tests is already included in the matrix, no need repeating
|
|
|
|
exclude:
|
|
|
|
- db_engine_name: mysql
|
|
db_engine_version: '10.5.25'
|
|
|
|
- db_engine_name: mysql
|
|
db_engine_version: '10.11.8'
|
|
|
|
- db_engine_name: mariadb
|
|
db_engine_version: '8.0.38'
|
|
|
|
- db_engine_name: mariadb
|
|
db_engine_version: '8.4.1'
|
|
|
|
- connector_name: pymysql
|
|
connector_version: '2.0.1'
|
|
|
|
- connector_name: pymysql
|
|
connector_version: '2.0.3'
|
|
|
|
- connector_name: pymysql
|
|
connector_version: '2.1.1'
|
|
|
|
- connector_name: mysqlclient
|
|
connector_version: '0.9.3'
|
|
|
|
- connector_name: mysqlclient
|
|
connector_version: '1.0.2'
|
|
|
|
- connector_name: mysqlclient
|
|
connector_version: '1.1.1'
|
|
|
|
- db_engine_version: '8.0.38'
|
|
ansible: stable-2.17
|
|
|
|
- db_engine_version: '10.5.25'
|
|
ansible: stable-2.17
|
|
|
|
- db_engine_version: '8.0.38'
|
|
ansible: devel
|
|
|
|
- db_engine_version: '10.5.25'
|
|
ansible: devel
|
|
|
|
- db_engine_version: '8.4.1'
|
|
connector_version: '0.9.3'
|
|
|
|
- db_engine_version: '8.4.1'
|
|
connector_version: '1.0.2'
|
|
|
|
- db_engine_version: '8.4.1'
|
|
connector_version: '2.0.1'
|
|
|
|
- db_engine_version: '8.4.1'
|
|
connector_version: '2.0.3'
|
|
|
|
- db_engine_version: '10.11.8'
|
|
connector_version: '0.9.3'
|
|
|
|
- db_engine_version: '10.11.8'
|
|
connector_version: '1.0.2'
|
|
|
|
- db_engine_version: '10.11.8'
|
|
connector_version: '2.0.1'
|
|
|
|
- db_engine_version: '10.11.8'
|
|
connector_version: '2.0.1'
|
|
|
|
- db_engine_version: '10.11.8'
|
|
ansible: stable-2.15
|
|
|
|
- db_engine_version: '8.4.1'
|
|
ansible: stable-2.15
|
|
|
|
- connector_version: '1.1.1'
|
|
db_engine_version: '8.0.38'
|
|
|
|
- connector_version: '1.1.1'
|
|
db_engine_version: '10.5.25'
|
|
|
|
services:
|
|
db_primary:
|
|
image: docker.io/library/${{ matrix.db_engine_name }}:${{ matrix.db_engine_version }}
|
|
env:
|
|
MARIADB_ROOT_PASSWORD: msandbox
|
|
MYSQL_ROOT_PASSWORD: msandbox
|
|
ports:
|
|
- 3307:3306
|
|
# We write our own health-cmd because the mariadb container does not
|
|
# provide a healthcheck
|
|
options: >-
|
|
--health-cmd "mysqladmin ping -P 3306 -pmsandbox |grep alive || exit 1"
|
|
--health-start-period 10s
|
|
--health-interval 10s
|
|
--health-timeout 5s
|
|
--health-retries 6
|
|
|
|
db_replica1:
|
|
image: docker.io/library/${{ matrix.db_engine_name }}:${{ matrix.db_engine_version }}
|
|
env:
|
|
MARIADB_ROOT_PASSWORD: msandbox
|
|
MYSQL_ROOT_PASSWORD: msandbox
|
|
ports:
|
|
- 3308:3306
|
|
options: >-
|
|
--health-cmd "mysqladmin ping -P 3306 -pmsandbox |grep alive || exit 1"
|
|
--health-start-period 10s
|
|
--health-interval 10s
|
|
--health-timeout 5s
|
|
--health-retries 6
|
|
|
|
db_replica2:
|
|
image: docker.io/library/${{ matrix.db_engine_name }}:${{ matrix.db_engine_version }}
|
|
env:
|
|
MARIADB_ROOT_PASSWORD: msandbox
|
|
MYSQL_ROOT_PASSWORD: msandbox
|
|
ports:
|
|
- 3309:3306
|
|
options: >-
|
|
--health-cmd "mysqladmin ping -P 3306 -pmsandbox |grep alive || exit 1"
|
|
--health-start-period 10s
|
|
--health-interval 10s
|
|
--health-timeout 5s
|
|
--health-retries 6
|
|
|
|
steps:
|
|
|
|
# No need to check for service health. GitHub Action took care of it.
|
|
|
|
- name: Restart MySQL server with settings for replication
|
|
run: |
|
|
db_ver="${{ matrix.db_engine_version }}"
|
|
maj="${db_ver%.*.*}"
|
|
maj_min="${db_ver%.*}"
|
|
min="${maj_min#*.}"
|
|
if [[ "${{ matrix.db_engine_name }}" == "mysql" && "$maj" -eq 8 && "$min" -ge 2 ]]; then
|
|
prima_conf='[mysqld]\\nserver-id=1\\nlog-bin=/var/lib/mysql/primary-bin\\nmysql-native-password=1'
|
|
repl1_conf='[mysqld]\\nserver-id=2\\nlog-bin=/var/lib/mysql/replica1-bin\\nmysql-native-password=1'
|
|
repl2_conf='[mysqld]\\nserver-id=3\\nlog-bin=/var/lib/mysql/replica2-bin\\nmysql-native-password=1'
|
|
else
|
|
prima_conf='[mysqld]\\nserver-id=1\\nlog-bin=/var/lib/mysql/primary-bin'
|
|
repl1_conf='[mysqld]\\nserver-id=2\\nlog-bin=/var/lib/mysql/replica1-bin'
|
|
repl2_conf='[mysqld]\\nserver-id=3\\nlog-bin=/var/lib/mysql/replica2-bin'
|
|
fi
|
|
docker exec -e cnf=$prima_conf ${{ job.services.db_primary.id }} bash -c 'echo -e ${cnf//\\n/\n} > /etc/mysql/conf.d/replication.cnf'
|
|
docker exec -e cnf=$repl1_conf ${{ job.services.db_replica1.id }} bash -c 'echo -e ${cnf//\\n/\n} > /etc/mysql/conf.d/replication.cnf'
|
|
docker exec -e cnf=$repl2_conf ${{ job.services.db_replica2.id }} bash -c 'echo -e ${cnf//\\n/\n} > /etc/mysql/conf.d/replication.cnf'
|
|
docker restart -t 30 ${{ job.services.db_primary.id }}
|
|
docker restart -t 30 ${{ job.services.db_replica1.id }}
|
|
docker restart -t 30 ${{ job.services.db_replica2.id }}
|
|
|
|
- name: Wait for the primary to be healthy
|
|
run: >
|
|
while ! /usr/bin/docker inspect
|
|
--format="{{if .Config.Healthcheck}}{{print .State.Health.Status}}{{end}}"
|
|
${{ job.services.db_primary.id }}
|
|
| grep healthy && [[ "$SECONDS" -lt 120 ]]; do sleep 1; done
|
|
|
|
- name: >-
|
|
Perform integration testing against
|
|
Ansible version ${{ matrix.ansible }}
|
|
uses: ansible-community/ansible-test-gh-action@release/v1
|
|
with:
|
|
ansible-core-version: ${{ matrix.ansible }}
|
|
docker-image: ubuntu2204
|
|
pre-test-cmd: >-
|
|
echo Setting db_engine_name to "${{ matrix.db_engine_name }}"...;
|
|
echo -n "${{ matrix.db_engine_name }}"
|
|
> tests/integration/db_engine_name;
|
|
|
|
echo Setting db_engine_version to \
|
|
"${{ matrix.db_engine_version }}"...;
|
|
echo -n "${{ matrix.db_engine_version }}"
|
|
> tests/integration/db_engine_version;
|
|
|
|
echo Setting Connector name to "${{ matrix.connector_name }}"...;
|
|
echo -n "${{ matrix.connector_name }}"
|
|
> tests/integration/connector_name;
|
|
|
|
echo Setting Connector name to "${{ matrix.connector_version }}"...;
|
|
echo -n "${{ matrix.connector_version }}"
|
|
> tests/integration/connector_version;
|
|
|
|
echo Setting Ansible version to "${{ matrix.ansible }}"...;
|
|
echo -n "${{ matrix.ansible }}"
|
|
> tests/integration/ansible
|
|
testing-type: integration
|
|
integration-retry-on-error: false
|
|
|
|
units:
|
|
runs-on: ubuntu-22.04
|
|
name: Units (Ⓐ${{ matrix.ansible }}, Python${{ matrix.python }})
|
|
strategy:
|
|
# As soon as the first unit test fails,
|
|
# cancel the others to free up the CI queue
|
|
fail-fast: true
|
|
matrix:
|
|
ansible:
|
|
- stable-2.15
|
|
- stable-2.16
|
|
- stable-2.17
|
|
- devel
|
|
python:
|
|
- '3.8'
|
|
- '3.9'
|
|
- '3.10'
|
|
- '3.11'
|
|
exclude:
|
|
- python: '3.8'
|
|
ansible: stable-2.16
|
|
|
|
- python: '3.8'
|
|
ansible: stable-2.17
|
|
|
|
- python: '3.8'
|
|
ansible: devel
|
|
|
|
- python: '3.9'
|
|
ansible: stable-2.15
|
|
|
|
- python: '3.9'
|
|
ansible: stable-2.17
|
|
|
|
- python: '3.9'
|
|
ansible: devel
|
|
|
|
- python: '3.10'
|
|
ansible: stable-2.15
|
|
|
|
- python: '3.10'
|
|
ansible: stable-2.16
|
|
|
|
- python: '3.11'
|
|
ansible: stable-2.15
|
|
|
|
- python: '3.11'
|
|
ansible: stable-2.16
|
|
|
|
steps:
|
|
- name: >-
|
|
Perform unit testing against
|
|
Ansible version ${{ matrix.ansible }} and
|
|
python version ${{ matrix.python }}
|
|
uses: ansible-community/ansible-test-gh-action@release/v1
|
|
with:
|
|
ansible-core-version: ${{ matrix.ansible }}
|
|
target-python-version: ${{ matrix.python }}
|
|
testing-type: units
|
|
pull-request-change-detection: true
|