CI matrix update (#226)

* CI matrix update

* Fix test_mysql_user

* Fix CI

* Fix CI

* Fix CI

* Fix CI

* Fix CI
This commit is contained in:
Andrew Klychkov 2021-10-12 12:24:28 +03:00 committed by GitHub
parent 4f205ef540
commit fc984b28aa
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
10 changed files with 57 additions and 43 deletions

View file

@ -28,6 +28,7 @@ jobs:
- stable-2.9 - stable-2.9
- stable-2.10 - stable-2.10
- stable-2.11 - stable-2.11
- stable-2.12
- devel - devel
steps: steps:
@ -61,9 +62,11 @@ jobs:
- stable-2.9 - stable-2.9
- stable-2.10 - stable-2.10
- stable-2.11 - stable-2.11
#- devel - stable-2.12
- devel
python: python:
- 3.6 - 3.6
- 3.8
connector: connector:
- pymysql==0.7.10 - pymysql==0.7.10
- pymysql==0.9.3 - pymysql==0.9.3
@ -71,6 +74,17 @@ jobs:
exclude: exclude:
- mysql: 8.0.22 - mysql: 8.0.22
connector: pymysql==0.7.10 connector: pymysql==0.7.10
- python: 3.8
ansible: stable-2.9
- python: 3.8
ansible: stable-2.10
- python: 3.8
ansible: stable-2.11
- python: 3.6
ansible: stable-2.12
- python: 3.6
ansible: devel
steps: steps:
- name: Check out code - name: Check out code
@ -116,6 +130,7 @@ jobs:
- stable-2.9 - stable-2.9
- stable-2.10 - stable-2.10
- stable-2.11 - stable-2.11
- stable-2.12
- devel - devel
steps: steps:

View file

@ -28,6 +28,27 @@
- name: "{{ role_name }} | install | install python packages" - name: "{{ role_name }} | install | install python packages"
pip: pip:
name: "{{ python_packages }}" name: "{{ python_packages }}"
register: connector
- name: Debug connector var content
debug:
msg: '{{ connector }}'
- name: Extract connector.name.0 content
set_fact:
connector_name: "{{ connector.name.0 }}"
- name: Debug connector_name content
debug:
msg: '{{ connector_name }}'
- name: Extract connector version
set_fact:
connector_ver: "{{ connector_name.split('=')[2].strip() }}"
- name: Debug connector_ver var content
debug:
msg: '{{ connector_ver }}'
- name: "{{ role_name }} | install | install packages required by mysql" - name: "{{ role_name }} | install | install packages required by mysql"
apt: apt:

View file

@ -11,27 +11,26 @@
- name: Add fake port to config file - name: Add fake port to config file
shell: 'echo "port = {{ fake_port }}" >> {{ config_file }}' shell: 'echo "port = {{ fake_port }}" >> {{ config_file }}'
- name: Get pymysql version
shell: pip show pymysql | awk '/Version/ {print $2}'
register: pymysql_version
- name: Add blank line - name: Add blank line
shell: 'echo "" >> {{ config_file }}' shell: 'echo "" >> {{ config_file }}'
when: (pymysql_version.stdout | default('1000', true)) is version('0.9.3', '>=') when:
- (connector.name.0 is search('pymysql') and connector_ver is version('0.9.3', '>=')) or connector.name.0 is not search('pymysql')
- name: Create include_dir - name: Create include_dir
file: file:
path: '{{ include_dir }}' path: '{{ include_dir }}'
state: directory state: directory
mode: '0777' mode: '0777'
when: (pymysql_version.stdout | default('1000', true)) is version('0.9.3', '>=') when:
- (connector.name.0 is search('pymysql') and connector_ver is version('0.9.3', '>=')) or connector.name.0 is not search('pymysql')
- name: Add include_dir - name: Add include_dir
lineinfile: lineinfile:
path: '{{ config_file }}' path: '{{ config_file }}'
line: '!includedir {{ include_dir }}' line: '!includedir {{ include_dir }}'
insertafter: EOF insertafter: EOF
when: (pymysql_version.stdout | default('1000', true)) is version('0.9.3', '>=') when:
- (connector.name.0 is search('pymysql') and connector_ver is version('0.9.3', '>=')) or connector.name.0 is not search('pymysql')
- name: Create database using fake port to connect to, must fail - name: Create database using fake port to connect to, must fail
mysql_db: mysql_db:

View file

@ -9,9 +9,6 @@
block: block:
# ============================================================ # ============================================================
- shell: pip show pymysql | awk '/Version/ {print $2}'
register: pymysql_version
- name: get server certificate - name: get server certificate
copy: copy:
content: "{{ lookup('pipe', \"openssl s_client -starttls mysql -connect localhost:3307 -showcerts 2>/dev/null </dev/null | sed -ne '/-BEGIN CERTIFICATE-/,/-END CERTIFICATE-/p'\") }}" content: "{{ lookup('pipe', \"openssl s_client -starttls mysql -connect localhost:3307 -showcerts 2>/dev/null </dev/null | sed -ne '/-BEGIN CERTIFICATE-/,/-END CERTIFICATE-/p'\") }}"
@ -49,12 +46,12 @@
- assert: - assert:
that: that:
- result is failed - result is failed
when: pymysql_version.stdout != "" when: connector.name.0 is search('pymysql')
- assert: - assert:
that: that:
- result is succeeded - result is succeeded
when: pymysql_version.stdout == "" when: connector.name.0 is not search('pymysql')
- name: attempt connection with newly created user ignoring hostname - name: attempt connection with newly created user ignoring hostname
mysql_db: mysql_db:

View file

@ -9,9 +9,6 @@
block: block:
# ============================================================ # ============================================================
- shell: pip show pymysql | awk '/Version/ {print $2}'
register: pymysql_version
- name: get server certificate - name: get server certificate
copy: copy:
content: "{{ lookup('pipe', \"openssl s_client -starttls mysql -connect localhost:3307 -showcerts 2>/dev/null </dev/null | sed -ne '/-BEGIN CERTIFICATE-/,/-END CERTIFICATE-/p'\") }}" content: "{{ lookup('pipe', \"openssl s_client -starttls mysql -connect localhost:3307 -showcerts 2>/dev/null </dev/null | sed -ne '/-BEGIN CERTIFICATE-/,/-END CERTIFICATE-/p'\") }}"
@ -47,12 +44,12 @@
- assert: - assert:
that: that:
- result is failed - result is failed
when: pymysql_version.stdout != "" when: connector.name.0 is search('pymysql')
- assert: - assert:
that: that:
- result is succeeded - result is succeeded
when: pymysql_version.stdout == "" when: connector.name.0 is not search('pymysql')
- name: attempt connection with newly created user ignoring hostname - name: attempt connection with newly created user ignoring hostname
mysql_info: mysql_info:

View file

@ -9,9 +9,6 @@
block: block:
# ============================================================ # ============================================================
- shell: pip show pymysql | awk '/Version/ {print $2}'
register: pymysql_version
- name: get server certificate - name: get server certificate
copy: copy:
content: "{{ lookup('pipe', \"openssl s_client -starttls mysql -connect localhost:3307 -showcerts 2>/dev/null </dev/null | sed -ne '/-BEGIN CERTIFICATE-/,/-END CERTIFICATE-/p'\") }}" content: "{{ lookup('pipe', \"openssl s_client -starttls mysql -connect localhost:3307 -showcerts 2>/dev/null </dev/null | sed -ne '/-BEGIN CERTIFICATE-/,/-END CERTIFICATE-/p'\") }}"
@ -47,12 +44,12 @@
- assert: - assert:
that: that:
- result is failed - result is failed
when: pymysql_version.stdout != "" when: connector.name.0 is search('pymysql')
- assert: - assert:
that: that:
- result is succeeded - result is succeeded
when: pymysql_version.stdout == "" when: connector.name.0 is not search('pymysql')
- name: attempt connection with newly created user ignoring hostname - name: attempt connection with newly created user ignoring hostname
mysql_query: mysql_query:

View file

@ -9,9 +9,6 @@
block: block:
# ============================================================ # ============================================================
- shell: pip show pymysql | awk '/Version/ {print $2}'
register: pymysql_version
- name: get server certificate - name: get server certificate
copy: copy:
content: "{{ lookup('pipe', \"openssl s_client -starttls mysql -connect localhost:3307 -showcerts 2>/dev/null </dev/null | sed -ne '/-BEGIN CERTIFICATE-/,/-END CERTIFICATE-/p'\") }}" content: "{{ lookup('pipe', \"openssl s_client -starttls mysql -connect localhost:3307 -showcerts 2>/dev/null </dev/null | sed -ne '/-BEGIN CERTIFICATE-/,/-END CERTIFICATE-/p'\") }}"
@ -48,12 +45,12 @@
- assert: - assert:
that: that:
- result is failed - result is failed
when: pymysql_version.stdout != "" when: connector.name.0 is search('pymysql')
- assert: - assert:
that: that:
- result is succeeded - result is succeeded
when: pymysql_version.stdout == "" when: connector.name.0 is not search('pymysql')
- name: attempt connection with newly created user ignoring hostname - name: attempt connection with newly created user ignoring hostname
mysql_replication: mysql_replication:

View file

@ -9,9 +9,6 @@
block: block:
# ============================================================ # ============================================================
- shell: pip show pymysql | awk '/Version/ {print $2}'
register: pymysql_version
- name: get server certificate - name: get server certificate
copy: copy:
content: "{{ lookup('pipe', \"openssl s_client -starttls mysql -connect localhost:3307 -showcerts 2>/dev/null </dev/null | sed -ne '/-BEGIN CERTIFICATE-/,/-END CERTIFICATE-/p'\") }}" content: "{{ lookup('pipe', \"openssl s_client -starttls mysql -connect localhost:3307 -showcerts 2>/dev/null </dev/null | sed -ne '/-BEGIN CERTIFICATE-/,/-END CERTIFICATE-/p'\") }}"
@ -50,12 +47,12 @@
- assert: - assert:
that: that:
- result is failed - result is failed
when: pymysql_version.stdout != "" when: connector.name.0 is search('pymysql')
- assert: - assert:
that: that:
- result is succeeded - result is succeeded
when: pymysql_version.stdout == "" when: connector.name.0 is not search('pymysql')
- name: attempt connection with newly created user ignoring hostname - name: attempt connection with newly created user ignoring hostname
mysql_user: mysql_user:

View file

@ -9,9 +9,6 @@
block: block:
# ============================================================ # ============================================================
- shell: pip show pymysql | awk '/Version/ {print $2}'
register: pymysql_version
- name: get server certificate - name: get server certificate
copy: copy:
content: "{{ lookup('pipe', \"openssl s_client -starttls mysql -connect localhost:3307 -showcerts 2>/dev/null </dev/null | sed -ne '/-BEGIN CERTIFICATE-/,/-END CERTIFICATE-/p'\") }}" content: "{{ lookup('pipe', \"openssl s_client -starttls mysql -connect localhost:3307 -showcerts 2>/dev/null </dev/null | sed -ne '/-BEGIN CERTIFICATE-/,/-END CERTIFICATE-/p'\") }}"
@ -48,12 +45,12 @@
- assert: - assert:
that: that:
- result is failed - result is failed
when: pymysql_version.stdout != "" when: connector.name.0 is search('pymysql')
- assert: - assert:
that: that:
- result is succeeded - result is succeeded
when: pymysql_version.stdout == "" when: connector.name.0 is not search('pymysql')
- name: attempt connection with newly created user ignoring hostname - name: attempt connection with newly created user ignoring hostname
mysql_variables: mysql_variables:

View file

@ -151,9 +151,6 @@
# ============================================================ # ============================================================
# Verify mysql_variable fails when setting an incorrect value (out of range) # Verify mysql_variable fails when setting an incorrect value (out of range)
# #
- shell: pip show pymysql | awk '/Version/ {print $2}'
register: pymysql_version
- name: set mysql variable value to a number out of range - name: set mysql variable value to a number out of range
mysql_variables: mysql_variables:
<<: *mysql_params <<: *mysql_params
@ -163,10 +160,10 @@
ignore_errors: true ignore_errors: true
- include: assert_var.yml changed=true output={{ oor_result }} var_name=max_connect_errors var_value=1 - include: assert_var.yml changed=true output={{ oor_result }} var_name=max_connect_errors var_value=1
when: pymysql_version.stdout == "" when: connector.name.0 is not search('pymysql')
- include: assert_fail_msg.yml output={{ oor_result }} msg='Truncated incorrect' - include: assert_fail_msg.yml output={{ oor_result }} msg='Truncated incorrect'
when: pymysql_version.stdout != "" when: connector.name.0 is search('pymysql')
# ============================================================ # ============================================================
# Verify mysql_variable fails when setting an incorrect value (incorrect type) # Verify mysql_variable fails when setting an incorrect value (incorrect type)