Blame t/issue_260.t

Packit Service 584ef9
#!/usr/bin/perl
Packit Service 584ef9
# Issue #260 is a terrible bug.
Packit Service 584ef9
# In order to run this test:
Packit Service 584ef9
# * checkout 1.4.15
Packit Service 584ef9
# * change TAIL_REPAIR_TIME from (3 * 3600) to 3
Packit Service 584ef9
# Now it should cause an assert. Patches can be tested to fix it.
Packit Service 584ef9
Packit Service 584ef9
use strict;
Packit Service 584ef9
use Test::More;
Packit Service 584ef9
use FindBin qw($Bin);
Packit Service 584ef9
use lib "$Bin/lib";
Packit Service 584ef9
use MemcachedTest;
Packit Service 584ef9
Packit Service 584ef9
plan skip_all => "Only possible to test #260 under artificial conditions";
Packit Service 584ef9
exit 0;
Packit Service 584ef9
plan tests => 11074;
Packit Service 584ef9
# assuming max slab is 1M and default mem is 64M
Packit Service 584ef9
my $server = new_memcached();
Packit Service 584ef9
my $sock = $server->sock;
Packit Service 584ef9
Packit Service 584ef9
# create a big value for the largest slab
Packit Service 584ef9
my $max = 1024 * 1024;
Packit Service 584ef9
my $big = 'x' x (1024 * 1024 - 250);
Packit Service 584ef9
Packit Service 584ef9
ok(length($big) > 512 * 1024);
Packit Service 584ef9
ok(length($big) < 1024 * 1024);
Packit Service 584ef9
Packit Service 584ef9
# set the big value
Packit Service 584ef9
my $len = length($big);
Packit Service 584ef9
print $sock "set big 0 0 $len\r\n$big\r\n";
Packit Service 584ef9
is(scalar <$sock>, "STORED\r\n", "stored big");
Packit Service 584ef9
mem_get_is($sock, "big", $big);
Packit Service 584ef9
Packit Service 584ef9
# no evictions yet
Packit Service 584ef9
my $stats = mem_stats($sock);
Packit Service 584ef9
is($stats->{"evictions"}, "0", "no evictions to start");
Packit Service 584ef9
Packit Service 584ef9
# set many big items, enough to get evictions
Packit Service 584ef9
for (my $i = 0; $i < 100; $i++) {
Packit Service 584ef9
  print $sock "set item_$i 0 0 $len\r\n$big\r\n";
Packit Service 584ef9
  is(scalar <$sock>, "STORED\r\n", "stored item_$i");
Packit Service 584ef9
}
Packit Service 584ef9
Packit Service 584ef9
# some evictions should have happened
Packit Service 584ef9
my $stats = mem_stats($sock);
Packit Service 584ef9
my $evictions = int($stats->{"evictions"});
Packit Service 584ef9
ok($evictions == 37, "some evictions happened");
Packit Service 584ef9
Packit Service 584ef9
# the first big value should be gone
Packit Service 584ef9
mem_get_is($sock, "big", undef);
Packit Service 584ef9
Packit Service 584ef9
# the earliest items should be gone too
Packit Service 584ef9
for (my $i = 0; $i < $evictions - 1; $i++) {
Packit Service 584ef9
  mem_get_is($sock, "item_$i", undef);
Packit Service 584ef9
}
Packit Service 584ef9
Packit Service 584ef9
# check that the non-evicted are the right ones
Packit Service 584ef9
for (my $i = $evictions - 1; $i < $evictions + 4; $i++) {
Packit Service 584ef9
  mem_get_is($sock, "item_$i", $big);
Packit Service 584ef9
}
Packit Service 584ef9
Packit Service 584ef9
# Now we fill a slab with incrementable items...
Packit Service 584ef9
for (my $i = 0; $i < 10923; $i++) {
Packit Service 584ef9
  print $sock "set sitem_$i 0 0 1\r\n1\r\n";
Packit Service 584ef9
  is(scalar <$sock>, "STORED\r\n", "stored sitem_$i");
Packit Service 584ef9
}
Packit Service 584ef9
Packit Service 584ef9
my $stats = mem_stats($sock);
Packit Service 584ef9
my $evictions = int($stats->{"evictions"});
Packit Service 584ef9
ok($evictions == 38, "one more eviction happened: $evictions");
Packit Service 584ef9
Packit Service 584ef9
# That evicted item was the first one we put in.
Packit Service 584ef9
mem_get_is($sock, "sitem_0", undef);
Packit Service 584ef9
Packit Service 584ef9
sleep 15;
Packit Service 584ef9
Packit Service 584ef9
# Now we increment the item which should be on the tail.
Packit Service 584ef9
# THIS asserts the memcached-debug binary.
Packit Service 584ef9
print $sock "incr sitem_1 1\r\n";
Packit Service 584ef9
is(scalar <$sock>, "2\r\n", "incremented to two");
Packit Service 584ef9
Packit Service 584ef9
#my $stats = mem_stats($sock, "slabs");
Packit Service 584ef9
#is($stats->{"1:free_chunks"}, 0, "free chunks should still be 0");