Blame installcheck/amstatus.pl

Packit Service 392537
# Copyright (c) 2008-2012 Zmanda, Inc.  All Rights Reserved.
Packit Service 392537
# Copyright (c) 2013-2016 Carbonite, Inc.  All Rights Reserved.
Packit Service 392537
#
Packit Service 392537
# This program is free software; you can redistribute it and/or
Packit Service 392537
# modify it under the terms of the GNU General Public License
Packit Service 392537
# as published by the Free Software Foundation; either version 2
Packit Service 392537
# of the License, or (at your option) any later version.
Packit Service 392537
#
Packit Service 392537
# This program is distributed in the hope that it will be useful, but
Packit Service 392537
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
Packit Service 392537
# or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
Packit Service 392537
# for more details.
Packit Service 392537
#
Packit Service 392537
# You should have received a copy of the GNU General Public License along
Packit Service 392537
# with this program; if not, write to the Free Software Foundation, Inc.,
Packit Service 392537
# 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
Packit Service 392537
#
Packit Service 392537
# Contact information: Carbonite Inc., 756 N Pastoria Ave
Packit Service 392537
# Sunnyvale, CA 94086, USA, or: http://www.zmanda.com
Packit Service 392537
Packit Service 392537
use Test::More tests => 20;
Packit Service 392537
use strict;
Packit Service 392537
use warnings;
Packit Service 392537
Packit Service 392537
use lib '@amperldir@';
Packit Service 392537
use Installcheck;
Packit Service 392537
use Installcheck::Run qw( run run_get );
Packit Service 392537
use Installcheck::Catalogs;
Packit Service 392537
use Amanda::Debug;
Packit Service 392537
use Amanda::Paths;
Packit Service 392537
use Amanda::Constants;
Packit Service 392537
Packit Service 392537
Amanda::Debug::dbopen("installcheck");
Packit Service 392537
Installcheck::log_test_output();
Packit Service 392537
Packit Service 392537
my $cat;
Packit Service 392537
my $testconf = Installcheck::Run::setup();
Packit Service 392537
$testconf->write();
Packit Service 392537
Packit Service 392537
## try number formating
Packit Service 392537
Packit Service 392537
$cat = Installcheck::Catalogs::load('number');
Packit Service 392537
$cat->install();
Packit Service 392537
Packit Service 392537
ok(run('amstatus', 'TESTCONF', '-odisplayunit=k'),
Packit Service 392537
    "plain amstatus runs without error with -odisplayunit=k");
Packit Service 392537
like($Installcheck::Run::stdout,
Packit Service 392537
    qr{localhost.localdomain:/bootAMGTAR\s*[0-9]{14}\s*0\s*155584k\s*flushed\s*\(11:41:56\)
Packit Service 392537
localhost.localdomain:/bootAMGTAR\s*[0-9]{14}\s*0\s*155584k\s*dump done, written\s*\(11:55:09\)
Packit Service 392537
localhost.localdomain:1000g\s*[0-9]{14}\s*0\s*1048580000k\s*dump to tape done\s*\(11:42:07\)
Packit Service 392537
localhost.localdomain:100g\s*[0-9]{14}\s*0\s*104858000k\s*dump to tape done\s*\(11:42:22\)
Packit Service 392537
localhost.localdomain:100m\s*[0-9]{14}\s*0\s*102410k\s*flushed\s*\(11:41:56\)
Packit Service 392537
localhost.localdomain:100m\s*[0-9]{14}\s*0\s*102410k\s*dump done, written\s*\(11:55:03\)
Packit Service 392537
localhost.localdomain:100t\s*[0-9]{14}\s*0\s*104857700000k\s*dump to tape done\s*\(11:49:22\)
Packit Service 392537
localhost.localdomain:10g\s*[0-9]{14}\s*0\s*10486016k\s*dump to tape done\s*\(11:54:59\)
Packit Service 392537
localhost.localdomain:10m\s*[0-9]{14}\s*0\s*10250k\s*dump done, written\s*\(11:41:58\)
Packit Service 392537
localhost.localdomain:10t\s*[0-9]{14}\s*0\s*10485770000k\s*dump to tape done\s*\(11:53:14\)
Packit Service 392537
localhost.localdomain:1g\s*[0-9]{14}\s*0\s*1048755k\s*dump to tape done\s*\(11:42:54\)
Packit Service 392537
localhost.localdomain:2ga\s*[0-9]{14}\s*0\s*2097160k\s*dump to tape done\s*\(11:43:35\)
Packit Service 392537
localhost.localdomain:5ga\s*[0-9]{14}\s*0\s*5242890k\s*dump to tape done\s*\(11:45:36\)},
Packit Service 392537
    "output is reasonable with -odisplayunit=k");
Packit Service 392537
Packit Service 392537
ok(run('amstatus', 'TESTCONF', '-odisplayunit=m'),
Packit Service 392537
    "plain amstatus runs without error with -odisplayunit=m");
Packit Service 392537
like($Installcheck::Run::stdout,
Packit Service 392537
    qr{localhost.localdomain:/bootAMGTAR\s*[0-9]{14}\s*0\s*151m\s*flushed\s*\(11:41:56\)
Packit Service 392537
localhost.localdomain:/bootAMGTAR\s*[0-9]{14}\s*0\s*151m\s*dump done, written\s*\(11:55:09\)
Packit Service 392537
localhost.localdomain:1000g\s*[0-9]{14}\s*0\s*1024003m\s*dump to tape done\s*\(11:42:07\)
Packit Service 392537
localhost.localdomain:100g\s*[0-9]{14}\s*0\s*102400m\s*dump to tape done\s*\(11:42:22\)
Packit Service 392537
localhost.localdomain:100m\s*[0-9]{14}\s*0\s*100m\s*flushed\s*\(11:41:56\)
Packit Service 392537
localhost.localdomain:100m\s*[0-9]{14}\s*0\s*100m\s*dump done, written\s*\(11:55:03\)
Packit Service 392537
localhost.localdomain:100t\s*[0-9]{14}\s*0\s*102400097m\s*dump to tape done\s*\(11:49:22\)
Packit Service 392537
localhost.localdomain:10g\s*[0-9]{14}\s*0\s*10240m\s*dump to tape done\s*\(11:54:59\)
Packit Service 392537
localhost.localdomain:10m\s*[0-9]{14}\s*0\s*10m\s*dump done, written\s*\(11:41:58\)
Packit Service 392537
localhost.localdomain:10t\s*[0-9]{14}\s*0\s*10240009m\s*dump to tape done\s*\(11:53:14\)
Packit Service 392537
localhost.localdomain:1g\s*[0-9]{14}\s*0\s*1024m\s*dump to tape done\s*\(11:42:54\)
Packit Service 392537
localhost.localdomain:2ga\s*[0-9]{14}\s*0\s*2048m\s*dump to tape done\s*\(11:43:35\)
Packit Service 392537
localhost.localdomain:5ga\s*[0-9]{14}\s*0\s*5120m\s*dump to tape done\s*\(11:45:36\)},
Packit Service 392537
    "output is reasonable with -odisplayunit=m");
Packit Service 392537
Packit Service 392537
ok(run('amstatus', 'TESTCONF', '-odisplayunit=g'),
Packit Service 392537
    "plain amstatus runs without error with -odisplayunit=g");
Packit Service 392537
like($Installcheck::Run::stdout,
Packit Service 392537
    qr{localhost.localdomain:/bootAMGTAR\s*[0-9]{14}\s*0\s*0g\s*flushed\s*\(11:41:56\)
Packit Service 392537
localhost.localdomain:/bootAMGTAR\s*[0-9]{14}\s*0\s*0g\s*dump done, written\s*\(11:55:09\)
Packit Service 392537
localhost.localdomain:1000g\s*[0-9]{14}\s*0\s*1000g\s*dump to tape done\s*\(11:42:07\)
Packit Service 392537
localhost.localdomain:100g\s*[0-9]{14}\s*0\s*100g\s*dump to tape done\s*\(11:42:22\)
Packit Service 392537
localhost.localdomain:100m\s*[0-9]{14}\s*0\s*0g\s*flushed\s*\(11:41:56\)
Packit Service 392537
localhost.localdomain:100m\s*[0-9]{14}\s*0\s*0g\s*dump done, written\s*\(11:55:03\)
Packit Service 392537
localhost.localdomain:100t\s*[0-9]{14}\s*0\s*100000g\s*dump to tape done\s*\(11:49:22\)
Packit Service 392537
localhost.localdomain:10g\s*[0-9]{14}\s*0\s*10g\s*dump to tape done\s*\(11:54:59\)
Packit Service 392537
localhost.localdomain:10m\s*[0-9]{14}\s*0\s*0g\s*dump done, written\s*\(11:41:58\)
Packit Service 392537
localhost.localdomain:10t\s*[0-9]{14}\s*0\s*10000g\s*dump to tape done\s*\(11:53:14\)
Packit Service 392537
localhost.localdomain:1g\s*[0-9]{14}\s*0\s*1g\s*dump to tape done\s*\(11:42:54\)
Packit Service 392537
localhost.localdomain:2ga\s*[0-9]{14}\s*0\s*2g\s*dump to tape done\s*\(11:43:35\)
Packit Service 392537
localhost.localdomain:5ga\s*[0-9]{14}\s*0\s*5g\s*dump to tape done\s*\(11:45:36\)},
Packit Service 392537
    "output is reasonable with -odisplayunit=g");
Packit Service 392537
Packit Service 392537
ok(run('amstatus', 'TESTCONF', '-odisplayunit=t'),
Packit Service 392537
    "plain amstatus runs without error with -odisplayunit=t");
Packit Service 392537
like($Installcheck::Run::stdout,
Packit Service 392537
    qr{localhost.localdomain:/bootAMGTAR\s*[0-9]{14}\s*0\s*0t\s*flushed\s*\(11:41:56\)
Packit Service 392537
localhost.localdomain:/bootAMGTAR\s*[0-9]{14}\s*0\s*0t\s*dump done, written\s*\(11:55:09\)
Packit Service 392537
localhost.localdomain:1000g\s*[0-9]{14}\s*0\s*0t\s*dump to tape done\s*\(11:42:07\)
Packit Service 392537
localhost.localdomain:100g\s*[0-9]{14}\s*0\s*0t\s*dump to tape done\s*\(11:42:22\)
Packit Service 392537
localhost.localdomain:100m\s*[0-9]{14}\s*0\s*0t\s*flushed\s*\(11:41:56\)
Packit Service 392537
localhost.localdomain:100m\s*[0-9]{14}\s*0\s*0t\s*dump done, written\s*\(11:55:03\)
Packit Service 392537
localhost.localdomain:100t\s*[0-9]{14}\s*0\s*97t\s*dump to tape done\s*\(11:49:22\)
Packit Service 392537
localhost.localdomain:10g\s*[0-9]{14}\s*0\s*0t\s*dump to tape done\s*\(11:54:59\)
Packit Service 392537
localhost.localdomain:10m\s*[0-9]{14}\s*0\s*0t\s*dump done, written\s*\(11:41:58\)
Packit Service 392537
localhost.localdomain:10t\s*[0-9]{14}\s*0\s*9t\s*dump to tape done\s*\(11:53:14\)
Packit Service 392537
localhost.localdomain:1g\s*[0-9]{14}\s*0\s*0t\s*dump to tape done\s*\(11:42:54\)
Packit Service 392537
localhost.localdomain:2ga\s*[0-9]{14}\s*0\s*0t\s*dump to tape done\s*\(11:43:35\)
Packit Service 392537
localhost.localdomain:5ga\s*[0-9]{14}\s*0\s*0t\s*dump to tape done\s*\(11:45:36\)},
Packit Service 392537
    "output is reasonable with -odisplayunit=t");
Packit Service 392537
Packit Service 392537
## try a few various options with a pretty normal logfile
Packit Service 392537
Packit Service 392537
$cat = Installcheck::Catalogs::load('normal');
Packit Service 392537
$cat->install();
Packit Service 392537
Packit Service 392537
ok(run('amstatus', 'TESTCONF'),
Packit Service 392537
    "plain amstatus runs without error");
Packit Service 392537
like($Installcheck::Run::stdout,
Packit Service 392537
    qr{clienthost:/some/dir [0-9]{14}\s*0\s*100k\s*dump done, written\s*\(13:01:53\)},
Packit Service 392537
    "output is reasonable");
Packit Service 392537
Packit Service 392537
ok(run('amstatus', 'TESTCONF', '--summary'),
Packit Service 392537
    "amstatus --summary runs without error");
Packit Service 392537
unlike($Installcheck::Run::stdout,
Packit Service 392537
    qr{clienthost:/some/dir\s*0\s*100k\s*finished\s*\(13:01:53\)},
Packit Service 392537
    "output does not contain the finished dump");
Packit Service 392537
like($Installcheck::Run::stdout,
Packit Service 392537
    qr{taped\s+:\s+1\s+},
Packit Service 392537
    "output contains summary info");
Packit Service 392537
Packit Service 392537
## now test a file with spaces and other funny characters in filenames
Packit Service 392537
Packit Service 392537
$cat = Installcheck::Catalogs::load('quoted');
Packit Service 392537
$cat->install();
Packit Service 392537
Packit Service 392537
ok(run('amstatus', 'TESTCONF'),
Packit Service 392537
    "amstatus runs without error with quoted disknames");
Packit Service 392537
like($Installcheck::Run::stdout,
Packit Service 392537
    # note that amstatus' output is quoted, so backslashes are doubled
Packit Service 392537
    qr{clienthost:"C:\\\\Some Dir\\\\" [0-9]{14}\s*0\s*100k\s*dump done, written\s*\(13:01:53\)},
Packit Service 392537
    "output is correct");
Packit Service 392537
Packit Service 392537
## now test a chunker partial result
Packit Service 392537
Packit Service 392537
$cat = Installcheck::Catalogs::load('chunker-partial');
Packit Service 392537
$cat->install();
Packit Service 392537
Packit Service 392537
ok(!run('amstatus', 'TESTCONF'),
Packit Service 392537
    "amstatus return error with chunker partial");
Packit Service 392537
is($Installcheck::Run::exit_code, 4,
Packit Service 392537
    "correct exit code for chunker partial");
Packit Service 392537
like($Installcheck::Run::stdout,
Packit Service 392537
    qr{localhost:/etc [0-9]{14} 0\s*80917k dump failed: \[/usr/sbin/tar returned error\], written \( 7:49:53\)},
Packit Service 392537
    "output is correct");
Packit Service 392537
Packit Service 392537
## now test a taper-parallel-write > 1
Packit Service 392537
Packit Service 392537
$cat = Installcheck::Catalogs::load('taper-parallel-write');
Packit Service 392537
$cat->install();
Packit Service 392537
Packit Service 392537
ok(run('amstatus', 'TESTCONF'),
Packit Service 392537
    "amstatus with taper-parallel-write runs without error");
Packit Service 392537
like($Installcheck::Run::stdout,
Packit Service 392537
    qr{\s*tape 3\s*:\s*1\s*142336k\s*142336k \(  5.82\%\) amstatus_test_3-AA-003 \(1 parts\)},
Packit Service 392537
    "output is correct");