File: trace_filehandle.t

package info (click to toggle)
liblog-trace-perl 1.070-1
  • links: PTS, VCS
  • area: main
  • in suites: lenny
  • size: 180 kB
  • ctags: 42
  • sloc: perl: 859; makefile: 44
file content (72 lines) | stat: -rw-r--r-- 1,854 bytes parent folder | download | duplicates (4)
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
#!/usr/local/bin/perl -w
# $Id: trace_filehandle.t,v 1.5 2004/12/15 15:47:35 johna Exp $
use strict;
use Test::More tests => 7;

# Find local libs unless running under Test::Harness
BEGIN { unshift @INC, -d 't' ? 'lib' : '../lib' unless grep /\bblib\b/, @INC }
require_ok('Log::Trace');

my $test_file = __FILE__;
my $timestamp = qr|\d{4}(?:-\d\d){2} \d\d(?::\d\d){2}(?:\.\d{6})?|;

my $message;
tie *TEST_HANDLE, 'CapturingFileHandle';

import Log::Trace print => \*TEST_HANDLE;
$message = 'Testing output to a filehandle';
TRACE($message);
is (<TEST_HANDLE>, "$message\n", 'message traced to supplied filehandle');

import Log::Trace print => \*TEST_HANDLE, {Level => 1};
$message = $0;
TRACE({Level => 1}, $message);
is (<TEST_HANDLE>, "$message\n", 'level 1 trace to filehandle ok');

TRACE({Level => 99}, $message);
is (<TEST_HANDLE>, undef, 'level 99 message not traced ok');

import Log::Trace print => \*TEST_HANDLE, {Verbose => 0};
TRACE(join '', reverse 0..9);
is (<TEST_HANDLE>, "9876543210\n", 'verbose:0 is also not verbose');

import Log::Trace print => \*TEST_HANDLE, {Verbose => 1};
TRACE(join '', ('a'..'f'));
like (<TEST_HANDLE>, qr/\Amain::__ANON__ \(\d+\) :: abcdef\n\Z/,
      'verbose:1 adds some caller information');

import Log::Trace print => \*TEST_HANDLE, {Verbose => 2};
TRACE(join '', ('a'..'f'));
like (<TEST_HANDLE>, qr/\A\Q$test_file\E: main::__ANON__ \(\d+\) \[$timestamp\] abcdef\n\Z/,
      'verbose:2 adds timstamp and file info');

sub TRACE {}


# A basic tied handle
package CapturingFileHandle;

sub TIEHANDLE {
   bless \do {my $string = ''}, shift;
}

sub PRINT {
    my $self = shift;
    $$self .= shift;
}

sub READLINE {
    my $self = shift;
    if (my $data = $$self) {
        $self->reset;
        return $data
    } else {
        return;
    }
}

sub reset {
    my $self = shift;
    $$self = '';
}