2012-03-23 15:22:25 +01:00
|
|
|
set server_path [tmpdir "server.rdb-encoding-test"]
|
|
|
|
|
2012-03-23 20:20:43 +01:00
|
|
|
# Copy RDB with different encodings in server path
|
2012-03-23 15:22:25 +01:00
|
|
|
exec cp tests/assets/encodings.rdb $server_path
|
|
|
|
|
|
|
|
start_server [list overrides [list "dir" $server_path "dbfilename" "encodings.rdb"]] {
|
|
|
|
test "RDB encoding loading test" {
|
|
|
|
r select 0
|
|
|
|
csvdump r
|
2015-08-05 14:05:34 +02:00
|
|
|
} {"0","compressible","string","aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
"0","hash","hash","a","1","aa","10","aaa","100","b","2","bb","20","bbb","200","c","3","cc","30","ccc","300","ddd","400","eee","5000000000",
|
|
|
|
"0","hash_zipped","hash","a","1","b","2","c","3",
|
|
|
|
"0","list","list","1","2","3","a","b","c","100000","6000000000","1","2","3","a","b","c","100000","6000000000","1","2","3","a","b","c","100000","6000000000",
|
|
|
|
"0","list_zipped","list","1","2","3","a","b","c","100000","6000000000",
|
|
|
|
"0","number","string","10"
|
|
|
|
"0","set","set","1","100000","2","3","6000000000","a","b","c",
|
|
|
|
"0","set_zipped_1","set","1","2","3","4",
|
|
|
|
"0","set_zipped_2","set","100000","200000","300000","400000",
|
|
|
|
"0","set_zipped_3","set","1000000000","2000000000","3000000000","4000000000","5000000000","6000000000",
|
|
|
|
"0","string","string","Hello World"
|
|
|
|
"0","zset","zset","a","1","b","2","c","3","aa","10","bb","20","cc","30","aaa","100","bbb","200","ccc","300","aaaa","1000","cccc","123456789","bbbb","5000000000",
|
|
|
|
"0","zset_zipped","zset","a","1","b","2","c","3",
|
2012-03-23 15:22:25 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-03-12 19:55:33 +01:00
|
|
|
set server_path [tmpdir "server.rdb-startup-test"]
|
|
|
|
|
|
|
|
start_server [list overrides [list "dir" $server_path]] {
|
|
|
|
test {Server started empty with non-existing RDB file} {
|
|
|
|
r debug digest
|
|
|
|
} {0000000000000000000000000000000000000000}
|
2013-03-13 10:04:33 +01:00
|
|
|
# Save an RDB file, needed for the next test.
|
|
|
|
r save
|
|
|
|
}
|
|
|
|
|
|
|
|
start_server [list overrides [list "dir" $server_path]] {
|
|
|
|
test {Server started empty with empty RDB file} {
|
|
|
|
r debug digest
|
|
|
|
} {0000000000000000000000000000000000000000}
|
|
|
|
}
|
|
|
|
|
2018-06-19 16:29:15 +02:00
|
|
|
start_server [list overrides [list "dir" $server_path]] {
|
|
|
|
test {Test RDB stream encoding} {
|
|
|
|
for {set j 0} {$j < 1000} {incr j} {
|
|
|
|
if {rand() < 0.9} {
|
|
|
|
r xadd stream * foo $j
|
|
|
|
} else {
|
|
|
|
r xadd stream * bar $j
|
|
|
|
}
|
|
|
|
}
|
2018-06-27 15:32:18 +03:00
|
|
|
r xgroup create stream mygroup 0
|
2018-06-26 14:14:35 +03:00
|
|
|
r xreadgroup GROUP mygroup Alice COUNT 1 STREAMS stream >
|
2018-06-19 16:29:15 +02:00
|
|
|
set digest [r debug digest]
|
|
|
|
r debug reload
|
|
|
|
set newdigest [r debug digest]
|
|
|
|
assert {$digest eq $newdigest}
|
|
|
|
r del stream
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-03-13 10:04:33 +01:00
|
|
|
# Helper function to start a server and kill it, just to check the error
|
|
|
|
# logged.
|
|
|
|
set defaults {}
|
|
|
|
proc start_server_and_kill_it {overrides code} {
|
|
|
|
upvar defaults defaults srv srv server_path server_path
|
|
|
|
set config [concat $defaults $overrides]
|
|
|
|
set srv [start_server [list overrides $config]]
|
|
|
|
uplevel 1 $code
|
|
|
|
kill_server $srv
|
|
|
|
}
|
|
|
|
|
|
|
|
# Make the RDB file unreadable
|
|
|
|
file attributes [file join $server_path dump.rdb] -permissions 0222
|
|
|
|
|
2013-04-23 14:08:42 +02:00
|
|
|
# Detect root account (it is able to read the file even with 002 perm)
|
|
|
|
set isroot 0
|
|
|
|
catch {
|
|
|
|
open [file join $server_path dump.rdb]
|
|
|
|
set isroot 1
|
|
|
|
}
|
|
|
|
|
2013-03-13 10:04:33 +01:00
|
|
|
# Now make sure the server aborted with an error
|
2013-04-23 14:08:42 +02:00
|
|
|
if {!$isroot} {
|
|
|
|
start_server_and_kill_it [list "dir" $server_path] {
|
|
|
|
test {Server should not start if RDB file can't be open} {
|
|
|
|
wait_for_condition 50 100 {
|
|
|
|
[string match {*Fatal error loading*} \
|
2017-02-22 13:08:21 +01:00
|
|
|
[exec tail -1 < [dict get $srv stdout]]]
|
2013-04-23 14:08:42 +02:00
|
|
|
} else {
|
|
|
|
fail "Server started even if RDB was unreadable!"
|
|
|
|
}
|
|
|
|
}
|
2013-03-13 10:04:33 +01:00
|
|
|
}
|
2013-03-12 19:55:33 +01:00
|
|
|
}
|
2013-03-13 11:12:45 +01:00
|
|
|
|
2013-04-22 11:25:44 +02:00
|
|
|
# Fix permissions of the RDB file.
|
2013-03-13 11:12:45 +01:00
|
|
|
file attributes [file join $server_path dump.rdb] -permissions 0666
|
2013-04-22 11:25:44 +02:00
|
|
|
|
|
|
|
# Corrupt its CRC64 checksum.
|
2013-03-13 11:12:45 +01:00
|
|
|
set filesize [file size [file join $server_path dump.rdb]]
|
|
|
|
set fd [open [file join $server_path dump.rdb] r+]
|
|
|
|
fconfigure $fd -translation binary
|
|
|
|
seek $fd -8 end
|
|
|
|
puts -nonewline $fd "foobar00"; # Corrupt the checksum
|
|
|
|
close $fd
|
|
|
|
|
|
|
|
# Now make sure the server aborted with an error
|
|
|
|
start_server_and_kill_it [list "dir" $server_path] {
|
2013-04-23 14:08:42 +02:00
|
|
|
test {Server should not start if RDB is corrupted} {
|
|
|
|
wait_for_condition 50 100 {
|
2016-07-04 12:41:25 +02:00
|
|
|
[string match {*CRC error*} \
|
2017-02-22 13:08:21 +01:00
|
|
|
[exec tail -10 < [dict get $srv stdout]]]
|
2013-04-23 14:08:42 +02:00
|
|
|
} else {
|
|
|
|
fail "Server started even if RDB was corrupted!"
|
|
|
|
}
|
2013-03-13 11:12:45 +01:00
|
|
|
}
|
|
|
|
}
|
2019-09-26 15:16:34 +03:00
|
|
|
|
|
|
|
start_server {} {
|
|
|
|
test {Test FLUSHALL aborts bgsave} {
|
|
|
|
r config set rdb-key-save-delay 1000
|
|
|
|
r debug populate 1000
|
|
|
|
r bgsave
|
|
|
|
assert_equal [s rdb_bgsave_in_progress] 1
|
|
|
|
r flushall
|
|
|
|
after 200
|
|
|
|
assert_equal [s rdb_bgsave_in_progress] 0
|
|
|
|
# make sure the server is still writable
|
|
|
|
r set x xx
|
|
|
|
}
|
|
|
|
}
|