diff options
author | antirez <antirez@gmail.com> | 2015-02-10 14:47:45 +0100 |
---|---|---|
committer | antirez <antirez@gmail.com> | 2015-02-10 14:48:22 +0100 |
commit | d4047f72613eeb5249839a2aedb50c772f8a27ea (patch) | |
tree | 92a4606850d4ad0cd06c49ced9f9028032f7b1f4 | |
parent | 61290d819dc295cb250fea889d37335ab29359fa (diff) | |
download | redis-d4047f72613eeb5249839a2aedb50c772f8a27ea.tar.gz |
Faster memory efficiency test.
This test on Linux was extremely slow, since in Tcl we can't enable
easily tcp-nodelay, so the busy loop used to take *a lot* with bigger
writes. Fixed using pipelining.
-rw-r--r-- | tests/unit/memefficiency.tcl | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/tests/unit/memefficiency.tcl b/tests/unit/memefficiency.tcl index 14e135ced..7ca9a705b 100644 --- a/tests/unit/memefficiency.tcl +++ b/tests/unit/memefficiency.tcl @@ -1,15 +1,20 @@ proc test_memory_efficiency {range} { r flushall + set rd [redis_deferring_client] set base_mem [s used_memory] set written 0 for {set j 0} {$j < 10000} {incr j} { set key key:$j set val [string repeat A [expr {int(rand()*$range)}]] - r set $key $val + $rd set $key $val incr written [string length $key] incr written [string length $val] incr written 2 ;# A separator is the minimum to store key-value data. } + for {set j 0} {$j < 10000} {incr j} { + $rd read ; # Discard replies + } + set current_mem [s used_memory] set used [expr {$current_mem-$base_mem}] set efficiency [expr {double($written)/$used}] |