| 
									
										
										
										
											2019-09-12 15:56:54 +08:00
										 |  |  | source tests/support/cli.tcl | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-09 20:13:24 +08:00
										 |  |  | start_server {tags {"wait network external:skip"}} { | 
					
						
							| 
									
										
										
										
											2016-11-18 20:10:29 +08:00
										 |  |  | start_server {} { | 
					
						
							|  |  |  |     set slave [srv 0 client] | 
					
						
							|  |  |  |     set slave_host [srv 0 host] | 
					
						
							|  |  |  |     set slave_port [srv 0 port] | 
					
						
							| 
									
										
										
										
											2021-01-12 15:46:24 +08:00
										 |  |  |     set slave_pid [srv 0 pid] | 
					
						
							| 
									
										
										
										
											2016-11-18 20:10:29 +08:00
										 |  |  |     set master [srv -1 client] | 
					
						
							|  |  |  |     set master_host [srv -1 host] | 
					
						
							|  |  |  |     set master_port [srv -1 port] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     test {Setup slave} { | 
					
						
							|  |  |  |         $slave slaveof $master_host $master_port | 
					
						
							|  |  |  |         wait_for_condition 50 100 { | 
					
						
							|  |  |  |             [s 0 master_link_status] eq {up} | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             fail "Replication not started." | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     test {WAIT should acknowledge 1 additional copy of the data} { | 
					
						
							|  |  |  |         $master set foo 0 | 
					
						
							|  |  |  |         $master incr foo | 
					
						
							|  |  |  |         $master incr foo | 
					
						
							|  |  |  |         $master incr foo | 
					
						
							|  |  |  |         assert {[$master wait 1 5000] == 1} | 
					
						
							|  |  |  |         assert {[$slave get foo] == 3} | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     test {WAIT should not acknowledge 2 additional copies of the data} { | 
					
						
							|  |  |  |         $master incr foo | 
					
						
							|  |  |  |         assert {[$master wait 2 1000] <= 1} | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     test {WAIT should not acknowledge 1 additional copy if slave is blocked} { | 
					
						
							| 
									
										
										
										
											2021-01-12 15:46:24 +08:00
										 |  |  |         exec kill -SIGSTOP $slave_pid | 
					
						
							| 
									
										
										
										
											2016-11-18 20:10:29 +08:00
										 |  |  |         $master set foo 0 | 
					
						
							|  |  |  |         $master incr foo | 
					
						
							|  |  |  |         $master incr foo | 
					
						
							|  |  |  |         $master incr foo | 
					
						
							| 
									
										
										
										
											2021-01-12 15:46:24 +08:00
										 |  |  |         assert {[$master wait 1 1000] == 0} | 
					
						
							|  |  |  |         exec kill -SIGCONT $slave_pid | 
					
						
							|  |  |  |         assert {[$master wait 1 1000] == 1} | 
					
						
							| 
									
										
										
										
											2016-11-18 20:10:29 +08:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-01-08 15:36:54 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     test {WAIT implicitly blocks on client pause since ACKs aren't sent} { | 
					
						
							| 
									
										
										
										
											2021-01-12 15:46:24 +08:00
										 |  |  |         exec kill -SIGSTOP $slave_pid | 
					
						
							| 
									
										
										
										
											2021-01-08 15:36:54 +08:00
										 |  |  |         $master multi | 
					
						
							|  |  |  |         $master incr foo | 
					
						
							|  |  |  |         $master client pause 10000 write | 
					
						
							|  |  |  |         $master exec | 
					
						
							|  |  |  |         assert {[$master wait 1 1000] == 0} | 
					
						
							|  |  |  |         $master client unpause | 
					
						
							| 
									
										
										
										
											2021-01-12 15:46:24 +08:00
										 |  |  |         exec kill -SIGCONT $slave_pid | 
					
						
							| 
									
										
										
										
											2021-01-08 15:36:54 +08:00
										 |  |  |         assert {[$master wait 1 1000] == 1} | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-11-18 20:10:29 +08:00
										 |  |  | }} |