123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134 |
- start_server {tags {"repl"}} {
- start_server {} {
- test {First server should have role slave after SLAVEOF} {
- r -1 slaveof [srv 0 host] [srv 0 port]
- wait_for_condition 50 100 {
- [s -1 master_link_status] eq {up}
- } else {
- fail "Replication not started."
- }
- }
- if {$::accurate} {set numops 50000} else {set numops 5000}
- test {MASTER and SLAVE consistency with expire} {
- createComplexDataset r $numops useexpire
- after 4000 ;# Make sure everything expired before taking the digest
- r keys * ;# Force DEL syntesizing to slave
- after 1000 ;# Wait another second. Now everything should be fine.
- if {[r debug digest] ne [r -1 debug digest]} {
- set csv1 [csvdump r]
- set csv2 [csvdump {r -1}]
- set fd [open /tmp/repldump1.txt w]
- puts -nonewline $fd $csv1
- close $fd
- set fd [open /tmp/repldump2.txt w]
- puts -nonewline $fd $csv2
- close $fd
- puts "Master - Replica inconsistency"
- puts "Run diff -u against /tmp/repldump*.txt for more info"
- }
- assert_equal [r debug digest] [r -1 debug digest]
- }
- test {Slave is able to evict keys created in writable slaves} {
- r -1 select 5
- assert {[r -1 dbsize] == 0}
- r -1 config set slave-read-only no
- r -1 set key1 1 ex 5
- r -1 set key2 2 ex 5
- r -1 set key3 3 ex 5
- assert {[r -1 dbsize] == 3}
- after 6000
- r -1 dbsize
- } {0}
- }
- }
- start_server {tags {"repl"}} {
- start_server {} {
- test {First server should have role slave after SLAVEOF} {
- r -1 slaveof [srv 0 host] [srv 0 port]
- wait_for_condition 50 100 {
- [s -1 master_link_status] eq {up}
- } else {
- fail "Replication not started."
- }
- }
- set numops 20000 ;# Enough to trigger the Script Cache LRU eviction.
- # While we are at it, enable AOF to test it will be consistent as well
- # after the test.
- r config set appendonly yes
- test {MASTER and SLAVE consistency with EVALSHA replication} {
- array set oldsha {}
- for {set j 0} {$j < $numops} {incr j} {
- set key "key:$j"
- # Make sure to create scripts that have different SHA1s
- set script "return redis.call('incr','$key')"
- set sha1 [r eval "return redis.sha1hex(\"$script\")" 0]
- set oldsha($j) $sha1
- r eval $script 0
- set res [r evalsha $sha1 0]
- assert {$res == 2}
- # Additionally call one of the old scripts as well, at random.
- set res [r evalsha $oldsha([randomInt $j]) 0]
- assert {$res > 2}
- # Trigger an AOF rewrite while we are half-way, this also
- # forces the flush of the script cache, and we will cover
- # more code as a result.
- if {$j == $numops / 2} {
- catch {r bgrewriteaof}
- }
- }
- wait_for_condition 50 100 {
- [r dbsize] == $numops &&
- [r -1 dbsize] == $numops &&
- [r debug digest] eq [r -1 debug digest]
- } else {
- set csv1 [csvdump r]
- set csv2 [csvdump {r -1}]
- set fd [open /tmp/repldump1.txt w]
- puts -nonewline $fd $csv1
- close $fd
- set fd [open /tmp/repldump2.txt w]
- puts -nonewline $fd $csv2
- close $fd
- puts "Master - Replica inconsistency"
- puts "Run diff -u against /tmp/repldump*.txt for more info"
- }
- set old_digest [r debug digest]
- r config set appendonly no
- r debug loadaof
- set new_digest [r debug digest]
- assert {$old_digest eq $new_digest}
- }
- test {SLAVE can reload "lua" AUX RDB fields of duplicated scripts} {
- # Force a Slave full resynchronization
- r debug change-repl-id
- r -1 client kill type master
- # Check that after a full resync the slave can still load
- # correctly the RDB file: such file will contain "lua" AUX
- # sections with scripts already in the memory of the master.
- wait_for_condition 500 100 {
- [s -1 master_link_status] eq {up}
- } else {
- fail "Replication not started."
- }
- wait_for_condition 50 100 {
- [r debug digest] eq [r -1 debug digest]
- } else {
- fail "DEBUG DIGEST mismatch after full SYNC with many scripts"
- }
- }
- }
- }
|