~percona-dev/percona-server/5.1.57-fix-bug723050

« back to all changes in this revision

Viewing changes to HandlerSocket-Plugin-for-MySQL/regtest/test_01_lib/test15.pl

  • Committer: Alexey Kopytov
  • Date: 2011-04-20 08:52:35 UTC
  • mfrom: (222.1.3 5.1.56-tmp)
  • Revision ID: akopytov@gmail.com-20110420085235-vh7g8vx04y4m6cno
MergeĀ fromĀ lp:percona-server

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
#!/usr/bin/perl
 
2
 
 
3
# vim:sw=2:ai
 
4
 
 
5
# test for various numeric types
 
6
 
 
7
BEGIN {
 
8
        push @INC, "../common/";
 
9
};
 
10
 
 
11
use strict;
 
12
use warnings;
 
13
use bigint;
 
14
use hstest;
 
15
 
 
16
my $numeric_types = [
 
17
        [ 'TINYINT', -128, 127 ],
 
18
        [ 'TINYINT UNSIGNED', 0, 255 ],
 
19
        [ 'SMALLINT', -32768, 32768 ],
 
20
        [ 'SMALLINT UNSIGNED', 0, 65535 ],
 
21
        [ 'MEDIUMINT', -8388608, 8388607 ],
 
22
        [ 'MEDIUMINT UNSIGNED', 0, 16777215 ],
 
23
        [ 'INT', -2147483648, 2147483647 ],
 
24
        [ 'INT UNSIGNED', 0, 4294967295 ],
 
25
        [ 'BIGINT', -9223372036854775808, 9223372036854775807 ],
 
26
        [ 'BIGINT UNSIGNED', 0, 18446744073709551615 ],
 
27
        [ 'FLOAT', -32768, 32768 ],
 
28
        [ 'DOUBLE', -2147483648, 2147483647 ],
 
29
];
 
30
 
 
31
my $table = 'hstesttbl';
 
32
my $dbh;
 
33
for my $rec (@$numeric_types) {
 
34
  my ($typ, $minval, $maxval) = @$rec;
 
35
  my @vals = ();
 
36
  push(@vals, 0);
 
37
  push(@vals, 1);
 
38
  push(@vals, $maxval);
 
39
  if ($minval != 0) {
 
40
    push(@vals, -1);
 
41
    push(@vals, $minval);
 
42
  }
 
43
  my $v1 = $minval;
 
44
  my $v2 = $maxval;
 
45
  for (my $i = 0; $i < 5; ++$i) {
 
46
    $v1 /= 3;
 
47
    $v2 /= 3;
 
48
    if ($v1 != 0) {
 
49
      push(@vals, int($v1));
 
50
    }
 
51
    push(@vals, int($v2));
 
52
  }
 
53
  @vals = sort { $a <=> $b } @vals;
 
54
  print("TYPE $typ\n");
 
55
  test_one($typ, \@vals);
 
56
  print("\n");
 
57
}
 
58
 
 
59
sub test_one {
 
60
  my ($typ, $values) = @_;
 
61
  $dbh = hstest::init_testdb();
 
62
  $dbh->do(
 
63
    "create table $table (" .
 
64
    "k $typ primary key, " .
 
65
    "v1 varchar(512), " .
 
66
    "v2 $typ, " .
 
67
    "index i1(v1), index i2(v2, v1)) " .
 
68
    "engine = myisam default charset = binary");
 
69
  my $hs = hstest::get_hs_connection(undef, 9999);
 
70
  my $dbname = $hstest::conf{dbname};
 
71
  $hs->open_index(1, $dbname, $table, '', 'k,v1,v2');
 
72
  $hs->open_index(2, $dbname, $table, 'i1', 'k,v1,v2');
 
73
  $hs->open_index(3, $dbname, $table, 'i2', 'k,v1,v2');
 
74
  for my $k (@$values) {
 
75
    my $kstr = 's' . $k;
 
76
    $hs->execute_single(1, '+', [ $k, $kstr, $k ], 0, 0);
 
77
  }
 
78
  dump_table();
 
79
  for my $k (@$values) {
 
80
    my $kstr = 's' . $k;
 
81
    my ($rk, $rv1, $rv2);
 
82
    my $r;
 
83
    $r = $hs->execute_single(1, '=', [ $k ], 1, 0);
 
84
    shift(@$r);
 
85
    ($rk, $rv1, $rv2) = @$r;
 
86
    print "PK[$k] $rk $rv1 $rv2\n";
 
87
    $r = $hs->execute_single(2, '=', [ $kstr ], 1, 0);
 
88
    shift(@$r);
 
89
    ($rk, $rv1, $rv2) = @$r;
 
90
    print "I1[$kstr] $rk $rv1 $rv2\n";
 
91
    $r = $hs->execute_single(3, '=', [ $k, $kstr ], 1, 0);
 
92
    shift(@$r);
 
93
    ($rk, $rv1, $rv2) = @$r;
 
94
    print "I2[$k, $kstr] $rk $rv1 $rv2\n";
 
95
    $r = $hs->execute_single(3, '=', [ $k ], 1, 0);
 
96
    shift(@$r);
 
97
    ($rk, $rv1, $rv2) = @$r;
 
98
    print "I2p[$k] $rk $rv1 $rv2\n";
 
99
  }
 
100
}
 
101
 
 
102
sub dump_table {
 
103
  print "DUMP_TABLE_BEGIN\n";
 
104
  my $aref = $dbh->selectall_arrayref("select k,v1,v2 from $table order by k");
 
105
  for my $row (@$aref) {
 
106
    my ($k, $v1, $v2) = @$row;
 
107
    $v1 = "[null]" if !defined($v1);
 
108
    $v2 = "[null]" if !defined($v2);
 
109
    print "$k $v1 $v2\n";
 
110
    # print "MISMATCH\n" if ($valmap{$k} ne $v);
 
111
  }
 
112
  print "DUMP_TABLE_END\n";
 
113
}
 
114