File: test-journal.pl

package info (click to toggle)
libguestfs 1%3A1.28.1-1
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 65,676 kB
  • ctags: 42,708
  • sloc: ansic: 374,827; ml: 40,236; sh: 19,721; java: 8,493; perl: 8,244; makefile: 5,740; cs: 5,602; haskell: 5,088; python: 2,591; erlang: 2,197; xml: 1,494; ruby: 271; pascal: 218; yacc: 123; lex: 110; cpp: 10
file content (87 lines) | stat: -rwxr-xr-x 2,861 bytes parent folder | download
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
#!/usr/bin/perl
# libguestfs
# Copyright (C) 2013 Red Hat Inc.
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.

# Test journal using test data from ../guests/guest-aux/-
# fedora-journal.tar.xz which is incorporated into the Fedora test
# image in ../guests/fedora.img.

use strict;
use warnings;

use Sys::Guestfs;

exit 77 if $ENV{SKIP_TEST_JOURNAL_PL};

my $g = Sys::Guestfs->new ();
$g->add_drive ("../guests/fedora.img", readonly => 1, format => "raw");
$g->launch ();

# If journal feature is not available, bail.
unless ($g->feature_available (["journal"])) {
    warn "$0: skipping test because journal feature is not available\n";
    exit 77;
}

# Mount the root filesystem.
$g->mount_ro ("/dev/VG/Root", "/");

# Open the journal.
$g->journal_open ("/var/log/journal");

eval {
    # Count the number of journal entries by iterating over them.
    # Save the first few.
    my $count = 0;
    my @entries = ();
    while ($g->journal_next ()) {
        $count++;
        my @fields = $g->journal_get ();
        # Turn the fields into a hash of field name -> data.
        my %fields = ();
        $fields{$_->{attrname}} = $_->{attrval} foreach @fields;
        push @entries, \%fields if $count <= 5;
    }

    die "incorrect # journal entries (got $count, expecting 2459)"
        unless $count == 2459;

    # Check a few fields.
    foreach ([0, "PRIORITY", "6"],
             [0, "MESSAGE_ID", "ec387f577b844b8fa948f33cad9a75e6"],
             [1, "_TRANSPORT", "driver"],
             [1, "_UID", "0"],
             [2, "_BOOT_ID", "1678ffea9ef14d87a96fa4aecd575842"],
             [2, "_HOSTNAME", "f20rawhidex64.home.annexia.org"],
             [4, "SYSLOG_IDENTIFIER", "kernel"]) {
        my %fields = %{$entries[$_->[0]]};
        my $fieldname = $_->[1];
        die "field ", $fieldname, " does not exist"
            unless exists $fields{$fieldname};
        my $expected = $_->[2];
        my $actual = $fields{$fieldname};
        die "unexpected data: got ", $fieldname, "=", $actual,
        ", expected ", $fieldname, "=", $expected unless $actual eq $expected;
    }
};
my $error = $@;
$g->journal_close ();
$g->shutdown ();
$g->close ();

die $error if $error;
exit 0