Files
percona-toolkit/t/pt-query-digest/since_until.t
2017-01-16 15:02:05 -03:00

156 lines
4.0 KiB
Perl

#!/usr/bin/env perl
BEGIN {
die "The PERCONA_TOOLKIT_BRANCH environment variable is not set.\n"
unless $ENV{PERCONA_TOOLKIT_BRANCH} && -d $ENV{PERCONA_TOOLKIT_BRANCH};
unshift @INC, "$ENV{PERCONA_TOOLKIT_BRANCH}/lib";
};
use strict;
use warnings FATAL => 'all';
use English qw(-no_match_vars);
use Test::More;
use PerconaTest;
use Sandbox;
require "$trunk/bin/pt-query-digest";
my $dp = new DSNParser(opts=>$dsn_opts);
my $sb = new Sandbox(basedir => '/tmp', DSNParser => $dp);
my $dbh = $sb->get_dbh_for('master');
my @args = (qw(--report-format query_report --limit 10));
my $sample_in = "$trunk/t/lib/samples/slowlogs";
my $sample_out = "t/pt-query-digest/sample";
my $run_with = "$trunk/bin/pt-query-digest --report-format=query_report --limit 10 $trunk/t/lib/samples/slowlogs/";
# #############################################################################
# Issue 154: Add --since and --until options to mk-query-digest
# #############################################################################
# --since
ok(
no_diff(
sub { pt_query_digest::main(@args,
"$sample_in/slow033.txt", qw(--since 2009-07-28)
)},
"t/pt-query-digest/samples/slow033-since-yyyy-mm-dd.txt",
stderr => 1,
),
'--since 2009-07-28'
);
ok(
no_diff(
sub { pt_query_digest::main(@args,
"$sample_in/slow033.txt", qw(--since 090727),
)},
"t/pt-query-digest/samples/slow033-since-yymmdd.txt",
stderr => 1,
),
'--since 090727'
);
# This test will eventually fail due to dates
ok(
no_diff(
sub { pt_query_digest::main(@args,
"$sample_in/slow033.txt", qw(--since 2555d),
)},
"t/pt-query-digest/samples/slow033-since-Nd.txt",
stderr => 1,
),
'--since 2555d (6 years ago)'
);
# --until
ok(
no_diff(
sub { pt_query_digest::main(@args,
"$sample_in/slow033.txt", qw(--until 2009-07-27),
)},
"t/pt-query-digest/samples/slow033-until-date.txt",
stderr => 1,
),
'--until 2009-07-27'
);
ok(
no_diff(
sub { pt_query_digest::main(@args,
"$sample_in/slow033.txt", qw(--until 090727),
)},
"t/pt-query-digest/samples/slow033-until-date.txt",
stderr => 1,
),
'--until 090727'
);
# The result file is correct: it's the one that has all quries from slow033.txt.
ok(
no_diff(
sub { pt_query_digest::main(@args,
"$sample_in/slow033.txt", qw(--until 1d),
)},
"t/pt-query-digest/samples/slow033-untl-1d.txt",
stderr => 1,
),
'--until 1d'
);
# And one very precise --since --until.
ok(
no_diff(
sub { pt_query_digest::main(@args,
"$sample_in/slow033.txt",
"--since", "2009-07-26 11:19:28",
"--until", "090727 11:30:00",
)},
"t/pt-query-digest/samples/slow033-precise-since-until.txt",
stderr => 1,
),
'--since "2009-07-26 11:19:28" --until "090727 11:30:00"'
);
SKIP: {
skip 'Cannot connect to sandbox master', 2 unless $dbh;
my $dsn = $sb->dsn_for('master');
# The result file is correct: it's the one that has all quries from
# slow033.txt.
ok(
no_diff(
sub { pt_query_digest::main(@args, $dsn,
"$sample_in/slow033.txt",
"--since", "\'2009-07-08\' - INTERVAL 7 DAY",
)},
"t/pt-query-digest/samples/slow033-since-2009-07-08.txt",
stderr => 1,
),
'--since "\'2009-07-08\' - INTERVAL 7 DAY"',
);
ok(
no_diff(
sub { pt_query_digest::main(@args, $dsn,
"$sample_in/slow033.txt",
"--until", "\'2009-07-28\' - INTERVAL 1 DAY",
)},
"t/pt-query-digest/samples/slow033-until-date.txt",
stderr => 1,
),
'--until "\'2009-07-28\' - INTERVAL 1 DAY"',
);
$dbh->disconnect();
};
# #############################################################################
# Done.
# #############################################################################
ok($sb->ok(), "Sandbox servers") or BAIL_OUT(__FILE__ . " broke the sandbox");
done_testing;