~ubuntu-branches/ubuntu/saucy/drizzle/saucy-proposed

« back to all changes in this revision

Viewing changes to tests/kewpie/randgen/unit/TestMySQLServer.pm

  • Committer: Package Import Robot
  • Author(s): Clint Byrum
  • Date: 2012-06-19 10:46:49 UTC
  • mfrom: (1.1.6)
  • mto: This revision was merged to the branch mainline in revision 29.
  • Revision ID: package-import@ubuntu.com-20120619104649-e2l0ggd4oz3um0f4
Tags: upstream-7.1.36-stable
ImportĀ upstreamĀ versionĀ 7.1.36-stable

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# Copyright (C) 2010 Sun Microsystems, Inc. All rights reserved.  Use
 
2
# is subject to license terms.
 
3
#
 
4
# This program is free software; you can redistribute it and/or modify
 
5
# it under the terms of the GNU General Public License as published by
 
6
# the Free Software Foundation; version 2 of the License.
 
7
#
 
8
# This program is distributed in the hope that it will be useful, but
 
9
# WITHOUT ANY WARRANTY; without even the implied warranty of
 
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
 
11
# General Public License for more details.
 
12
#
 
13
# You should have received a copy of the GNU General Public License
 
14
# along with this program; if not, write to the Free Software
 
15
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301
 
16
# USA
 
17
 
 
18
package TestMySQLServer;
 
19
 
 
20
use base qw(Test::Unit::TestCase);
 
21
use lib 'lib','lib/DBServer';
 
22
use Cwd;
 
23
use GenTest;
 
24
use DBServer::DBServer;
 
25
use DBServer::MySQL::MySQLd;
 
26
use GenTest::Executor;
 
27
use GenTest::Properties;
 
28
use GenTest::Reporter;
 
29
use GenTest::Reporter::Backtrace;
 
30
 
 
31
use Data::Dumper;
 
32
use File::Path qw(mkpath rmtree);
 
33
 
 
34
sub new {
 
35
    my $self = shift()->SUPER::new(@_);
 
36
    # your state for fixture here
 
37
    return $self;
 
38
}
 
39
 
 
40
sub set_up {
 
41
}
 
42
 
 
43
my @pids;
 
44
 
 
45
sub tear_down {
 
46
    if (osWindows) {
 
47
        ## Need to ,kill leftover processes if there are some
 
48
        foreach my $p (@pids) {
 
49
            Win32::Process::KillProcess($p,-1);
 
50
        }
 
51
    } else {
 
52
        ## Need to ,kill leftover processes if there are some
 
53
        kill 9 => @pids;
 
54
    }
 
55
    rmtree("unit/tmp");
 
56
}
 
57
 
 
58
sub test_create_server {
 
59
    my $self = shift;
 
60
 
 
61
    my $vardir= cwd()."/unit/tmp";
 
62
 
 
63
    my $portbase = 20 + ($ENV{TEST_PORTBASE}?int($ENV{TEST_PORTBASE}):22120);
 
64
 
 
65
    $self->assert(defined $ENV{RQG_MYSQL_BASE},"RQG_MYSQL_BASE not defined");
 
66
 
 
67
    my $server = DBServer::MySQL::MySQLd->new(basedir => $ENV{RQG_MYSQL_BASE},
 
68
                                              vardir => $vardir,
 
69
                                              port => $portbase);
 
70
    $self->assert_not_null($server);
 
71
 
 
72
    my ($major, $minor, $build) = $server->versionNumbers;
 
73
 
 
74
    say("Major: $major, Minor: $minor, Build: $build");
 
75
    
 
76
    $self->assert(-f $vardir."/data/mysql/db.MYD","No ".$vardir."/data/mysql/db.MYD");
 
77
    
 
78
    $server->startServer;
 
79
    push @pids,$server->serverpid;
 
80
    
 
81
    my $dsn = $server->dsn("mysql");
 
82
    $self->assert_not_null($dsn);
 
83
    
 
84
    my $executor = GenTest::Executor->newFromDSN($dsn);
 
85
    $self->assert_not_null($executor);
 
86
    $executor->init();
 
87
    
 
88
    my $result = $executor->execute("show tables");
 
89
    $self->assert_not_null($result);
 
90
    $self->assert_equals($result->status, 0);
 
91
    
 
92
    say(join(',',map{$_->[0]} @{$result->data}));
 
93
    
 
94
    $self->assert(-f $vardir."/mysql.pid") if not osWindows();
 
95
    $self->assert(-f $vardir."/mysql.err");
 
96
 
 
97
    $server->stopServer;
 
98
 
 
99
    sayFile($server->errorlog);
 
100
 
 
101
    $server = DBServer::MySQL::MySQLd->new(basedir => $ENV{RQG_MYSQL_BASE},
 
102
                                           vardir => $vardir,
 
103
                                           port => $portbase,
 
104
                                           start_dirty => 1);
 
105
    
 
106
    $self->assert_not_null($server);
 
107
 
 
108
    $server->startServer;
 
109
    push @pids,$server->serverpid;
 
110
    $server->stopServer;
 
111
 
 
112
    sayFile($server->errorlog);
 
113
}
 
114
 
 
115
sub test_crash_and_core {
 
116
    if (not osWindows()) { ## crash is not yet implemented for windows
 
117
        my $self = shift;
 
118
 
 
119
        my $vardir= cwd()."/unit/tmp";
 
120
        
 
121
        my $portbase = 60 + ($ENV{TEST_PORTBASE}?int($ENV{TEST_PORTBASE}):22120);
 
122
        
 
123
        $self->assert(defined $ENV{RQG_MYSQL_BASE},"RQG_MYSQL_BASE not defined");
 
124
        
 
125
        my $server = DBServer::MySQL::MySQLd->new(basedir => $ENV{RQG_MYSQL_BASE},
 
126
                                                  vardir => $vardir,
 
127
                                                  port => $portbase);
 
128
        $self->assert_not_null($server);
 
129
        
 
130
        $self->assert(-f $vardir."/data/mysql/db.MYD","No ".$vardir."/data/mysql/db.MYD");
 
131
        
 
132
        $server->startServer;
 
133
        push @pids,$server->serverpid;
 
134
        
 
135
        my $dsn = $server->dsn("mysql");
 
136
        $self->assert_not_null($dsn);
 
137
        
 
138
        my $executor = GenTest::Executor->newFromDSN($dsn);
 
139
        $self->assert_not_null($executor);
 
140
        $executor->init();
 
141
    
 
142
        my $result = $executor->execute("show tables");
 
143
        $self->assert_not_null($result);
 
144
        $self->assert_equals($result->status, 0);
 
145
        
 
146
        say(join(',',map{$_->[0]} @{$result->data}));
 
147
        
 
148
        $self->assert(-f $vardir."/mysql.pid") if not osWindows();
 
149
        $self->assert(-f $vardir."/mysql.err");
 
150
        
 
151
        my $backtrace = GenTest::Reporter::Backtrace->new(
 
152
            dsn => $server->dsn,
 
153
            properties => GenTest::Properties->new()
 
154
        );
 
155
        
 
156
        sleep(1);
 
157
        
 
158
        $server->crash;
 
159
        
 
160
        sleep(1);
 
161
 
 
162
        sayFile($server->errorlog);
 
163
 
 
164
        say("Core: ". $server->corefile);
 
165
 
 
166
        $backtrace->report();
 
167
    }
 
168
        
 
169
}
 
170
 
 
171
1;