2010-08-31 11:17:06 +02:00
|
|
|
start_server {tags {"other"}} {
|
2011-07-11 12:56:00 +02:00
|
|
|
if {$::force_failure} {
|
|
|
|
# This is used just for test suite development purposes.
|
|
|
|
test {Failing test} {
|
|
|
|
format err
|
|
|
|
} {ok}
|
|
|
|
}
|
|
|
|
|
2010-05-14 17:31:11 +02:00
|
|
|
test {SAVE - make sure there are all the types as values} {
|
|
|
|
# Wait for a background saving in progress to terminate
|
|
|
|
waitForBgsave r
|
|
|
|
r lpush mysavelist hello
|
|
|
|
r lpush mysavelist world
|
|
|
|
r set myemptykey {}
|
|
|
|
r set mynormalkey {blablablba}
|
|
|
|
r zadd mytestzset 10 a
|
|
|
|
r zadd mytestzset 20 b
|
|
|
|
r zadd mytestzset 30 c
|
|
|
|
r save
|
|
|
|
} {OK}
|
|
|
|
|
2011-07-10 23:25:48 +02:00
|
|
|
tags {slow} {
|
2011-07-11 12:15:35 +02:00
|
|
|
if {$::accurate} {set iterations 10000} else {set iterations 1000}
|
2010-06-03 00:16:10 +02:00
|
|
|
foreach fuzztype {binary alpha compr} {
|
|
|
|
test "FUZZ stresser with data model $fuzztype" {
|
|
|
|
set err 0
|
2011-07-11 12:15:35 +02:00
|
|
|
for {set i 0} {$i < $iterations} {incr i} {
|
2010-06-03 00:16:10 +02:00
|
|
|
set fuzz [randstring 0 512 $fuzztype]
|
|
|
|
r set foo $fuzz
|
|
|
|
set got [r get foo]
|
|
|
|
if {$got ne $fuzz} {
|
|
|
|
set err [list $fuzz $got]
|
|
|
|
break
|
|
|
|
}
|
2010-05-14 17:31:11 +02:00
|
|
|
}
|
2010-06-03 00:16:10 +02:00
|
|
|
set _ $err
|
|
|
|
} {0}
|
|
|
|
}
|
2010-05-14 17:31:11 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
test {BGSAVE} {
|
|
|
|
waitForBgsave r
|
|
|
|
r flushdb
|
|
|
|
r save
|
|
|
|
r set x 10
|
|
|
|
r bgsave
|
|
|
|
waitForBgsave r
|
|
|
|
r debug reload
|
|
|
|
r get x
|
|
|
|
} {10}
|
|
|
|
|
|
|
|
test {SELECT an out of range DB} {
|
|
|
|
catch {r select 1000000} err
|
|
|
|
set _ $err
|
|
|
|
} {*invalid*}
|
|
|
|
|
2011-07-10 23:25:48 +02:00
|
|
|
tags {consistency} {
|
2010-07-27 14:42:11 +02:00
|
|
|
if {![catch {package require sha1}]} {
|
2011-07-11 12:15:35 +02:00
|
|
|
if {$::accurate} {set numops 10000} else {set numops 1000}
|
2010-07-27 14:42:11 +02:00
|
|
|
test {Check consistency of different data types after a reload} {
|
|
|
|
r flushdb
|
2011-07-11 12:15:35 +02:00
|
|
|
createComplexDataset r $numops
|
2010-07-27 14:42:11 +02:00
|
|
|
set dump [csvdump r]
|
|
|
|
set sha1 [r debug digest]
|
|
|
|
r debug reload
|
|
|
|
set sha1_after [r debug digest]
|
|
|
|
if {$sha1 eq $sha1_after} {
|
|
|
|
set _ 1
|
|
|
|
} else {
|
|
|
|
set newdump [csvdump r]
|
|
|
|
puts "Consistency test failed!"
|
|
|
|
puts "You can inspect the two dumps in /tmp/repldump*.txt"
|
2010-05-14 17:31:11 +02:00
|
|
|
|
2010-07-27 14:42:11 +02:00
|
|
|
set fd [open /tmp/repldump1.txt w]
|
|
|
|
puts $fd $dump
|
|
|
|
close $fd
|
|
|
|
set fd [open /tmp/repldump2.txt w]
|
|
|
|
puts $fd $newdump
|
|
|
|
close $fd
|
|
|
|
|
|
|
|
set _ 0
|
|
|
|
}
|
|
|
|
} {1}
|
|
|
|
|
|
|
|
test {Same dataset digest if saving/reloading as AOF?} {
|
|
|
|
r bgrewriteaof
|
|
|
|
waitForBgrewriteaof r
|
|
|
|
r debug loadaof
|
|
|
|
set sha1_after [r debug digest]
|
|
|
|
if {$sha1 eq $sha1_after} {
|
|
|
|
set _ 1
|
|
|
|
} else {
|
|
|
|
set newdump [csvdump r]
|
|
|
|
puts "Consistency test failed!"
|
|
|
|
puts "You can inspect the two dumps in /tmp/aofdump*.txt"
|
|
|
|
|
|
|
|
set fd [open /tmp/aofdump1.txt w]
|
|
|
|
puts $fd $dump
|
|
|
|
close $fd
|
|
|
|
set fd [open /tmp/aofdump2.txt w]
|
|
|
|
puts $fd $newdump
|
|
|
|
close $fd
|
|
|
|
|
|
|
|
set _ 0
|
|
|
|
}
|
|
|
|
} {1}
|
|
|
|
}
|
2010-05-14 17:31:11 +02:00
|
|
|
}
|
|
|
|
|
2011-11-11 15:11:50 +01:00
|
|
|
test {EXPIRES after a reload (snapshot + append only file rewrite)} {
|
2010-05-14 17:31:11 +02:00
|
|
|
r flushdb
|
|
|
|
r set x 10
|
|
|
|
r expire x 1000
|
2011-07-10 23:25:48 +02:00
|
|
|
r save
|
|
|
|
r debug reload
|
2010-05-14 17:31:11 +02:00
|
|
|
set ttl [r ttl x]
|
|
|
|
set e1 [expr {$ttl > 900 && $ttl <= 1000}]
|
2011-07-10 23:25:48 +02:00
|
|
|
r bgrewriteaof
|
|
|
|
waitForBgrewriteaof r
|
|
|
|
r debug loadaof
|
2010-05-14 17:31:11 +02:00
|
|
|
set ttl [r ttl x]
|
|
|
|
set e2 [expr {$ttl > 900 && $ttl <= 1000}]
|
|
|
|
list $e1 $e2
|
|
|
|
} {1 1}
|
|
|
|
|
2011-11-11 15:11:50 +01:00
|
|
|
test {EXPIRES after AOF reload (without rewrite)} {
|
|
|
|
r flushdb
|
|
|
|
r config set appendonly yes
|
|
|
|
r set x somevalue
|
|
|
|
r expire x 1000
|
|
|
|
r setex y 2000 somevalue
|
|
|
|
r set z somevalue
|
|
|
|
r expireat z [expr {[clock seconds]+3000}]
|
|
|
|
|
|
|
|
# Milliseconds variants
|
|
|
|
r set px somevalue
|
|
|
|
r pexpire px 1000000
|
|
|
|
r psetex py 2000000 somevalue
|
|
|
|
r set pz somevalue
|
|
|
|
r pexpireat pz [expr {([clock seconds]+3000)*1000}]
|
|
|
|
|
|
|
|
# Reload and check
|
2011-12-21 09:24:14 +01:00
|
|
|
waitForBgrewriteaof r
|
2012-01-26 16:45:08 +01:00
|
|
|
# We need to wait two seconds to avoid false positives here, otherwise
|
|
|
|
# the DEBUG LOADAOF command may read a partial file.
|
|
|
|
# Another solution would be to set the fsync policy to no, since this
|
|
|
|
# prevents write() to be delayed by the completion of fsync().
|
|
|
|
after 2000
|
2011-11-11 15:11:50 +01:00
|
|
|
r debug loadaof
|
|
|
|
set ttl [r ttl x]
|
|
|
|
assert {$ttl > 900 && $ttl <= 1000}
|
|
|
|
set ttl [r ttl y]
|
|
|
|
assert {$ttl > 1900 && $ttl <= 2000}
|
|
|
|
set ttl [r ttl z]
|
|
|
|
assert {$ttl > 2900 && $ttl <= 3000}
|
|
|
|
set ttl [r ttl px]
|
|
|
|
assert {$ttl > 900 && $ttl <= 1000}
|
|
|
|
set ttl [r ttl py]
|
|
|
|
assert {$ttl > 1900 && $ttl <= 2000}
|
|
|
|
set ttl [r ttl pz]
|
|
|
|
assert {$ttl > 2900 && $ttl <= 3000}
|
|
|
|
r config set appendonly no
|
|
|
|
}
|
|
|
|
|
2011-07-10 23:25:48 +02:00
|
|
|
tags {protocol} {
|
2011-01-09 19:42:56 +01:00
|
|
|
test {PIPELINING stresser (also a regression for the old epoll bug)} {
|
|
|
|
set fd2 [socket $::host $::port]
|
|
|
|
fconfigure $fd2 -encoding binary -translation binary
|
|
|
|
puts -nonewline $fd2 "SELECT 9\r\n"
|
|
|
|
flush $fd2
|
|
|
|
gets $fd2
|
2010-05-14 17:31:11 +02:00
|
|
|
|
2011-01-09 19:42:56 +01:00
|
|
|
for {set i 0} {$i < 100000} {incr i} {
|
|
|
|
set q {}
|
|
|
|
set val "0000${i}0000"
|
|
|
|
append q "SET key:$i $val\r\n"
|
|
|
|
puts -nonewline $fd2 $q
|
|
|
|
set q {}
|
|
|
|
append q "GET key:$i\r\n"
|
|
|
|
puts -nonewline $fd2 $q
|
|
|
|
}
|
|
|
|
flush $fd2
|
2010-05-14 17:31:11 +02:00
|
|
|
|
2011-01-09 19:42:56 +01:00
|
|
|
for {set i 0} {$i < 100000} {incr i} {
|
|
|
|
gets $fd2 line
|
|
|
|
gets $fd2 count
|
|
|
|
set count [string range $count 1 end]
|
|
|
|
set val [read $fd2 $count]
|
|
|
|
read $fd2 2
|
|
|
|
}
|
|
|
|
close $fd2
|
|
|
|
set _ 1
|
|
|
|
} {1}
|
|
|
|
}
|
2010-05-14 17:31:11 +02:00
|
|
|
|
|
|
|
test {MUTLI / EXEC basics} {
|
|
|
|
r del mylist
|
|
|
|
r rpush mylist a
|
|
|
|
r rpush mylist b
|
|
|
|
r rpush mylist c
|
|
|
|
r multi
|
|
|
|
set v1 [r lrange mylist 0 -1]
|
|
|
|
set v2 [r ping]
|
|
|
|
set v3 [r exec]
|
|
|
|
list $v1 $v2 $v3
|
|
|
|
} {QUEUED QUEUED {{a b c} PONG}}
|
|
|
|
|
|
|
|
test {DISCARD} {
|
|
|
|
r del mylist
|
|
|
|
r rpush mylist a
|
|
|
|
r rpush mylist b
|
|
|
|
r rpush mylist c
|
|
|
|
r multi
|
|
|
|
set v1 [r del mylist]
|
|
|
|
set v2 [r discard]
|
|
|
|
set v3 [r lrange mylist 0 -1]
|
|
|
|
list $v1 $v2 $v3
|
|
|
|
} {QUEUED OK {a b c}}
|
|
|
|
|
2010-05-27 16:08:44 +02:00
|
|
|
test {Nested MULTI are not allowed} {
|
|
|
|
set err {}
|
|
|
|
r multi
|
|
|
|
catch {[r multi]} err
|
|
|
|
r exec
|
|
|
|
set _ $err
|
|
|
|
} {*ERR MULTI*}
|
|
|
|
|
2011-02-23 09:39:29 +01:00
|
|
|
test {MULTI where commands alter argc/argv} {
|
|
|
|
r sadd myset a
|
|
|
|
r multi
|
|
|
|
r spop myset
|
|
|
|
list [r exec] [r exists myset]
|
|
|
|
} {a 0}
|
|
|
|
|
2010-05-27 16:08:44 +02:00
|
|
|
test {WATCH inside MULTI is not allowed} {
|
|
|
|
set err {}
|
|
|
|
r multi
|
|
|
|
catch {[r watch x]} err
|
|
|
|
r exec
|
|
|
|
set _ $err
|
|
|
|
} {*ERR WATCH*}
|
|
|
|
|
2010-05-14 17:31:11 +02:00
|
|
|
test {APPEND basics} {
|
|
|
|
list [r append foo bar] [r get foo] \
|
|
|
|
[r append foo 100] [r get foo]
|
|
|
|
} {3 bar 6 bar100}
|
|
|
|
|
|
|
|
test {APPEND basics, integer encoded values} {
|
|
|
|
set res {}
|
|
|
|
r del foo
|
|
|
|
r append foo 1
|
|
|
|
r append foo 2
|
|
|
|
lappend res [r get foo]
|
|
|
|
r set foo 1
|
|
|
|
r append foo 2
|
|
|
|
lappend res [r get foo]
|
|
|
|
} {12 12}
|
|
|
|
|
|
|
|
test {APPEND fuzzing} {
|
|
|
|
set err {}
|
|
|
|
foreach type {binary alpha compr} {
|
|
|
|
set buf {}
|
|
|
|
r del x
|
|
|
|
for {set i 0} {$i < 1000} {incr i} {
|
|
|
|
set bin [randstring 0 10 $type]
|
|
|
|
append buf $bin
|
|
|
|
r append x $bin
|
|
|
|
}
|
|
|
|
if {$buf != [r get x]} {
|
|
|
|
set err "Expected '$buf' found '[r get x]'"
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
set _ $err
|
|
|
|
} {}
|
|
|
|
|
|
|
|
# Leave the user with a clean DB before to exit
|
|
|
|
test {FLUSHDB} {
|
|
|
|
set aux {}
|
|
|
|
r select 9
|
|
|
|
r flushdb
|
|
|
|
lappend aux [r dbsize]
|
|
|
|
r select 10
|
|
|
|
r flushdb
|
|
|
|
lappend aux [r dbsize]
|
|
|
|
} {0 0}
|
|
|
|
|
|
|
|
test {Perform a final SAVE to leave a clean DB on disk} {
|
2011-07-11 15:44:38 +02:00
|
|
|
waitForBgsave r
|
2010-05-14 17:31:11 +02:00
|
|
|
r save
|
|
|
|
} {OK}
|
|
|
|
}
|