mirror of
https://github.com/fluencelabs/redis
synced 2025-04-03 16:21:03 +00:00
Failing test related to AOF rewrite buffers
This commit is contained in:
parent
bdbf3acff5
commit
3aa4b00970
35
tests/integration/aof-race.tcl
Normal file
35
tests/integration/aof-race.tcl
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
set defaults { appendonly {yes} appendfilename {appendonly.aof} }
|
||||||
|
set server_path [tmpdir server.aof]
|
||||||
|
set aof_path "$server_path/appendonly.aof"
|
||||||
|
|
||||||
|
proc start_server_aof {overrides code} {
|
||||||
|
upvar defaults defaults srv srv server_path server_path
|
||||||
|
set config [concat $defaults $overrides]
|
||||||
|
start_server [list overrides $config] $code
|
||||||
|
}
|
||||||
|
|
||||||
|
tags {"aof"} {
|
||||||
|
# Specific test for a regression where internal buffers were not properly
|
||||||
|
# cleaned after a child responsible for an AOF rewrite exited. This buffer
|
||||||
|
# was subsequently appended to the new AOF, resulting in duplicate commands.
|
||||||
|
start_server_aof [list dir $server_path] {
|
||||||
|
set client [redis [srv host] [srv port]]
|
||||||
|
set bench [open "|src/redis-benchmark -q -p [srv port] -c 20 -n 20000 incr foo" "r+"]
|
||||||
|
after 100
|
||||||
|
|
||||||
|
# Benchmark should be running by now: start background rewrite
|
||||||
|
$client bgrewriteaof
|
||||||
|
|
||||||
|
# Read until benchmark pipe reaches EOF
|
||||||
|
while {[string length [read $bench]] > 0} {}
|
||||||
|
|
||||||
|
# Check contents of foo
|
||||||
|
assert_equal 20000 [$client get foo]
|
||||||
|
}
|
||||||
|
|
||||||
|
# Restart server to replay AOF
|
||||||
|
start_server_aof [list dir $server_path] {
|
||||||
|
set client [redis [srv host] [srv port]]
|
||||||
|
assert_equal 20000 [$client get foo]
|
||||||
|
}
|
||||||
|
}
|
@ -29,6 +29,7 @@ set ::all_tests {
|
|||||||
integration/replication-2
|
integration/replication-2
|
||||||
integration/replication-3
|
integration/replication-3
|
||||||
integration/aof
|
integration/aof
|
||||||
|
integration/aof-race
|
||||||
unit/pubsub
|
unit/pubsub
|
||||||
unit/slowlog
|
unit/slowlog
|
||||||
unit/scripting
|
unit/scripting
|
||||||
|
Loading…
x
Reference in New Issue
Block a user