-
Notifications
You must be signed in to change notification settings - Fork 683
/
Copy pathdocker-compose-test.yml
96 lines (85 loc) · 1.98 KB
/
docker-compose-test.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
x-mysql: &mysql
environment:
MYSQL_ALLOW_EMPTY_PASSWORD: true
command: >
mysqld
--log-bin=mysql-bin.log
--server-id 1
--binlog-format=row
--gtid_mode=on
--enforce-gtid-consistency=on
x-mariadb: &mariadb
environment:
MARIADB_ALLOW_EMPTY_ROOT_PASSWORD: 1
command: >
--server-id=1
--default-authentication-plugin=mysql_native_password
--log-bin=master-bin
--binlog-format=row
services:
percona-5.7:
<<: *mysql
image: percona:5.7
networks:
- default
percona-8.0:
<<: *mysql
image: percona:8.0
platform: linux/amd64
networks:
- default
mariadb-10.6:
<<: *mariadb
image: mariadb:10.6
volumes:
- type: bind
source: ./.mariadb
target: /opt/key_file
- type: bind
source: ./.mariadb/my.cnf
target: /etc/mysql/my.cnf
networks:
- default
pymysqlreplication:
build:
context: .
dockerfile: test.Dockerfile
args:
MYSQL_5_7: percona-5.7
MYSQL_8_0: percona-8.0
MYSQL_8_0_PORT: 3306
MARIADB_10_6: mariadb-10.6
MARIADB_10_6_PORT: 3306
command:
- /bin/sh
- -ce
- |
echo "wait mysql server"
check_servers_up() {
for s in percona-5.7 percona-8.0 mariadb-10.6; do
mariadb -h "$$s" --user=root --execute "SELECT version();" || {
echo "$$h not ready"
return 1
}
done
return 0
}
while ! check_servers_up; do
sleep 1
done
echo "run pytest"
for db in mysql-5 mariadb-10 mysql-8; do
echo "testing with $$db"
pytest -vv -k "not test_no_trailing_rotate_event and not test_end_log_pos" --db "$$db"
echo "tested with $$db"
done
working_dir: /pymysqlreplication
networks:
- default
depends_on:
- percona-5.7
- percona-8.0
- mariadb-10.6
networks:
default:
driver: bridge