File: gr_certifier_garbage_collection_counter_overflow.test

package info (click to toggle)
mysql-8.0 8.0.43-3
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 1,273,924 kB
  • sloc: cpp: 4,684,605; ansic: 412,450; pascal: 108,398; java: 83,641; perl: 30,221; cs: 27,067; sql: 26,594; sh: 24,181; python: 21,816; yacc: 17,169; php: 11,522; xml: 7,388; javascript: 7,076; makefile: 2,194; lex: 1,075; awk: 670; asm: 520; objc: 183; ruby: 97; lisp: 86
file content (117 lines) | stat: -rw-r--r-- 4,360 bytes parent folder | download
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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
###############################################################################
# This test verifies certification info garbage collection metrics.
#
# Test:
# 0. The test requires two servers: M1.
# 1. Start Group Replication and force a garbage collect
#    high number on write set of certification info.
# 2. Run some transactions on the group to increase
#    garbage collection size.
# 3. Remove certification info higher gtid set ref and
#    enable debug point that will simulate a one time
#    overflow on garbage collect counter.
# 4. As certification garbage collect simulates an overflow
#    it will not delete values from certification info.
# 5. Assert there are 3000 rows on certification info.
# 6. Remove debug point, already unset in the code
# 7. Execute one more transaction to update stable set and
#    garbage collect will clean certification info.
# 8. Cleanup
###############################################################################

--source include/have_debug.inc
--source include/big_test.inc
--source include/not_valgrind.inc
--source include/not_asan.inc
--source include/have_group_replication_plugin.inc
--let $rpl_skip_group_replication_start= 1
--source include/group_replication.inc


--echo
--echo ############################################################
--echo # 1. Start Group Replication and force a garbage collect
--echo #    high number on write set of certification info.

--source include/start_and_bootstrap_group_replication.inc

--let $debug_point=group_replication_ci_rows_counter_high
--source include/add_debug_point.inc


--echo
--echo ############################################################
--echo # 2. Run some transactions on the group to increase
--echo #    garbage collection size.

CREATE TABLE t1 (c1 INT NOT NULL PRIMARY KEY, c2 INT UNIQUE KEY NOT NULL, c3 INT UNIQUE KEY NOT NULL);
--disable_query_log
--let $cnt=1000
while($cnt)
{
    --eval INSERT INTO t1 VALUES ($cnt, $cnt, $cnt)
    --dec $cnt
}
--enable_query_log


--echo
--echo ############################################################
--echo # 3. Remove certification info higher gtid set ref and
--echo #    enable debug point that will simulate a one time
--echo #    overflow on garbage collect counter.

--let $debug_point=group_replication_ci_rows_counter_high
--source include/remove_debug_point.inc

--let $debug_point=group_replication_garbage_collect_counter_overflow
--source include/add_debug_point.inc


--echo
--echo ############################################################
--echo # 4. As certification garbage collect simulates an overflow
--echo #    it will not delete values from certification info.

--let $gtid_executed = `SELECT @@GLOBAL.gtid_executed`
--let $wait_timeout= 150
--let $wait_condition= SELECT received_transaction_set="$gtid_executed" FROM performance_schema.replication_connection_status WHERE channel_name="group_replication_applier";
--source include/wait_condition.inc


--echo
--echo ############################################################
--echo # 5. Assert there are 3000 rows on certification info.

--let $count_transactions_validating= query_get_value(SELECT Count_transactions_rows_validating from performance_schema.replication_group_member_stats where member_id in (SELECT @@server_uuid), Count_transactions_rows_validating, 1)
--let $assert_text= 'Count_transactions_rows_validating must be 3000'
--let $assert_cond= $count_transactions_validating = 3000
--source include/assert.inc


--echo
--echo ############################################################
--echo # 6. Remove debug point, already unset in the code

--let $debug_point=group_replication_garbage_collect_counter_overflow
--source include/remove_debug_point.inc


--echo
--echo ############################################################
--echo # 7. Execute one more transaction to update stable set and
--echo #    garbage collect will clean certification info.

INSERT INTO t1 VALUES (1001, 1001, 1001);

--let $wait_timeout= 150
--let $wait_condition= SELECT Count_transactions_rows_validating=3 FROM performance_schema.replication_group_member_stats WHERE member_id IN (SELECT @@server_uuid)
--source include/wait_condition.inc


--echo
--echo #################################################################
--echo # 8. Cleanup

DROP TABLE t1;
--source include/group_replication_end.inc