| 12
 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
 110
 111
 112
 113
 114
 115
 116
 117
 118
 119
 120
 121
 122
 123
 124
 125
 126
 127
 128
 129
 130
 131
 132
 133
 134
 135
 136
 137
 138
 139
 140
 141
 142
 143
 144
 145
 146
 147
 148
 149
 150
 151
 152
 153
 154
 155
 156
 157
 158
 159
 160
 161
 162
 163
 164
 165
 166
 167
 168
 169
 170
 171
 172
 173
 174
 175
 176
 177
 178
 179
 180
 181
 182
 183
 184
 185
 186
 187
 188
 189
 190
 191
 192
 193
 194
 195
 196
 197
 198
 199
 200
 201
 202
 203
 204
 205
 206
 207
 208
 209
 210
 211
 212
 213
 214
 
 | package Clutter::TestHelper;
use strict;
use warnings;
use Test::More;
use Carp;
our $VERSION = '0.01';
sub import
{
    shift;
    my %opts = (@_);
    plan skip_all => $opts{skip_all}
        if $opts{skip_all};
    croak "test must be provided at import"
        unless exists $opts{tests};
    if ($opts{at_least_version}) {
        my ($rmajor, $rminor, $rmicro, $text) = @{$opts{at_least_version}};
        plan skip_all => $text
            unless Clutter->CHECK_VERSION($rmajor, $rminor, $rmicro);
    }
    if ($opts{sub_module}) {
        my @modules = Clutter->SUPPORTED_MODULES();
        my $no_skip = 0;
        foreach my $m (@modules) {
            $no_skip = 1 if $opts{sub_module} eq $m;
        }
        plan skip_all => "no support for $opts{sub_module}"
            unless $no_skip;
    }
    if (!Clutter->init()) {
        plan skip_all => 'Clutter->init failed';
    }
    else {
        plan tests => $opts{tests};
    }
    # forcibly turn on warnings and strictness in the caller
    $^W = 1;
    @_ = ();
    goto &strict::import;
}
package main;
# we obviously need Clutter
use Clutter;
# and Test::More
use Test::More;
# enforce the use of these constants in the tests
use Glib qw( TRUE FALSE );
1;
__END__
=head1 NAME
Clutter::TestHelper - Simple wrapper module for testing Clutter
=head1 SYNOPSIS
  use Clutter::TestHelper tests => 10;
=head1 DESCRIPTION
A simple wrapper module around L<Test::More> that makes Clutter test suite
easier to write. When importing the module, L<Clutter> is also imported and
initialised. In case the initialisation process fails, likely to happen if
the C<DISPLAY> environment variable is not set, all the planned tests are
just skipped.
=head1 OPTIONS
=over
=item tests => $number
The number of tests to be performed
=item at_least_version => [ $major, $minor, $micro, $reason ]
A reference to a list that is checked with Clutter->CHECK_VERSION
=item skip_all
Simply skip all tests
=item sub_module => $module_name
Skip all tests if Clutter was not compiled against I<module_name>.
=back
=head1 AUTHORS
Emmanuele Bassi  E<lt>ebassi (AT) openedhand (DOT) comE<gt>
This module heavily borrows from the equivalent L<Gtk2::TestHelper> module
written by the Gtk2-Perl team.
=head1 COPYRIGHT
Copyright (C) 2007  OpenedHand, Ltd.
Released under the terms of Clutter itself.
=cut
package Clutter::TestHelper;
use strict;
use warnings;
use Test::More;
use Carp;
our $VERSION = '0.01';
sub import
{
    shift;
    my %opts = (@_);
    plan skip_all => $opts{skip_all} if $opts{skip_all};
    croak "test must be provided at import" unless exists $opts{tests};
    if ($opts{at_least_version}) {
        my ($rmajor, $rminor, $rmicro, $text) = @{$opts{at_least_version}};
        plan skip_all => $text
            unless Clutter->CHECK_VERSION($rmajor, $rminor, $rmicro);
    }
    if (!Clutter->init()) {
        plan skip_all => 'Clutter->init failed';
    }
    else {
        plan tests => $opts{tests};
    }
    # forcibly turn on warnings and strictness in the caller
    $^W = 1;
    @_ = ();
    goto &strict::import;
}
package main;
use Clutter;
use Test::More;
use Glib qw( TRUE FALSE );
1;
__END__
=head1 NAME
Clutter::TestHelper - Simple wrapper module for testing Clutter
=head1 SYNOPSIS
  use Clutter::TestHelper tests => 10;
=head1 DESCRIPTION
A simple wrapper module around L<Test::More> that makes Clutter test suite
easier to write. When importing the module, L<Clutter> is also imported and
initialised. In case the initialisation process fails, likely to happen if
the C<DISPLAY> environment variable is not set, all the planned tests are
just skipped.
=head1 OPTIONS
=over
=item tests
The number of tests to be performed
=item at_least_version
A reference to a list that is checked with Clutter->CHECK_VERSION
=item skip_all
Simply skip all tests
=back
=head1 AUTHORS
Emmanuele Bassi  E<lt>ebassi (AT) openedhand (DOT) comE<gt>
This module heavily borrows from the equivalent L<Gtk2::TestHelper> module
written by the Gtk2-Perl team.
=head1 COPYRIGHT
Copyright (C) 2007  OpenedHand, Ltd.
Released under the terms of Clutter itself.
=cut
 |