File: json.t

package info (click to toggle)
percona-toolkit 3.2.1-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bullseye, forky, sid, trixie
  • size: 68,916 kB
  • sloc: perl: 241,287; sql: 22,868; sh: 19,746; javascript: 6,799; makefile: 353; awk: 38; python: 30; sed: 1
file content (109 lines) | stat: -rw-r--r-- 3,375 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
#!/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";
   $ENV{PTTEST_PRETTY_JSON} = 0;
};

use strict;
use warnings FATAL => 'all';
use English qw(-no_match_vars);
use Test::More;

use PerconaTest;
require "$trunk/bin/pt-query-digest";

no warnings 'once';
local $JSONReportFormatter::sorted_json = 1;
local $JSONReportFormatter::pretty_json = 0;

my @args    = qw(--output json);
my $sample  = "$trunk/t/lib/samples";
my $results = "t/pt-query-digest/samples/json";

my $escaped_trunk = $trunk;
$escaped_trunk =~ s/\//\\\\\//g;

#1
ok(
   no_diff(
      sub { pt_query_digest::main(@args, "$sample/slowlogs/empty") },
      "t/pt-query-digest/samples/empty_json_report.txt",
   ),
   'json output for empty log'
) or diag($test_diff);

#2
ok(
   no_diff(
      sub { pt_query_digest::main(@args, "$sample/slowlogs/slow002.txt") },
      "$results/slow002.txt",
      sed => [ q/'s!"name":".*slow002.txt"!"name":"slow002.txt"!'/ ],
   ),
   'json output for slow002'
) or diag($test_diff);

#3
ok(
   no_diff(
      sub { pt_query_digest::main(qw(--no-vertical-format), @args,
                                  "$sample/slowlogs/slow002.txt") },
      "$results/slow002_no_vertical.txt",
      sed => [ q/'s!"name":".*slow002.txt"!"name":"slow002.txt"!'/ ],
   ),
   'json output for slow002 with --no-vertical-format'
) or diag($test_diff);

ok(
   no_diff(
      sub { pt_query_digest::main(qw(--output json-anon),
         "$sample/slowlogs/slow002.txt") },
      "$results/slow002-anon.txt",
      sed => [ q/'s!"name":".*slow002.txt"!"name":"slow002.txt"!'/ ],
   ),
   'json-anon output for slow002'
) or diag($test_diff);
ok(
   no_diff(
      sub { pt_query_digest::main(qw(--output json-anon --no-vertical-format),
         "$sample/slowlogs/slow002.txt") },
      "$results/slow002-anon_no_vertical.txt",
      sed => [ q/'s!"name":".*slow002.txt"!"name":"slow002.txt"!'/ ],
   ),
   'json-anon output for slow002 with --no-vertical-format'
) or diag($test_diff);

# --type tcpdump

ok(
   no_diff(
      sub { pt_query_digest::main(qw(--type tcpdump --limit 10 --watch-server 127.0.0.1:12345),
                                  @args, "$sample/tcpdump/tcpdump021.txt") },
      "$results/tcpdump021.txt",
      sed => [ q/'s!"name":".*tcpdump021.txt"!"name":"tcpdump021.txt"!'/ ],
   ),
   'json output for for tcpdump021',
) or diag($test_diff);

# #############################################################################
# pt-query-digest support for Percona Server slow log rate limiting
# https://blueprints.launchpad.net/percona-toolkit/+spec/pt-query-digest-rate-limit
# #############################################################################
ok(
   no_diff(
      sub { pt_query_digest::main(@args,
               "$trunk/t/lib/samples/slowlogs/slow059.txt",
               qw(--output json))
      },
      "t/pt-query-digest/samples/slow059_report02.txt",
      sed => [ q/'s!"name":".*slow059.txt"!"name":"slow059.txt"!'/ ],
   ),
   'json output for slow059'
) or diag($test_diff);

# #############################################################################
# Done.
# #############################################################################
done_testing;