Gtk2-Ex-DateSpinner
view release on metacpan or search on metacpan
t/CellRenderer.t view on Meta::CPAN
my $renderer = Gtk2::Ex::DateSpinner::CellRenderer->new (editable => 1);
my $event = Gtk2::Gdk::Event->new ('button-press');
my $rect = Gtk2::Gdk::Rectangle->new (0, 0, 100, 100);
my $editable = $renderer->start_editing
($event, $toplevel, "0", $rect, $rect, ['selected']);
isa_ok ($editable, 'Gtk2::CellEditable',
'start_editing return');
$toplevel->add ($editable);
$toplevel->remove ($editable);
MyTestHelpers::main_iterations(); # for idle handler hack
require Scalar::Util;
Scalar::Util::weaken ($editable);
is ($editable, undef, 'editable should be garbage collected when weakened');
$toplevel->destroy;
}
exit 0;
t/MyTestHelpers.pm view on Meta::CPAN
# Don't want to load Exporter here since that could hide a problem of a
# module missing a "use Exporter". Though Test.pm and Test::More (via
# Test::Builder::Module) both use it anyway.
#
# use Exporter;
# use vars qw(@ISA @EXPORT_OK %EXPORT_TAGS);
# @ISA = ('Exporter');
# @EXPORT_OK = qw(findrefs
# main_iterations
# warn_suppress_gtk_icon
# glib_gtk_versions
# any_signal_connections
# nowarnings);
# %EXPORT_TAGS = (all => \@EXPORT_OK);
sub DEBUG { 0 }
#-----------------------------------------------------------------------------
t/MyTestHelpers.pm view on Meta::CPAN
MyTestHelpers::diag ("search ", $proberef);
MyTestHelpers::findrefs($proberef);
}
}
#-----------------------------------------------------------------------------
# Gtk/Glib helpers
# Gtk 2.16 can go into a hard loop on events_pending() / main_iteration_do()
# if dbus is not running, or something like that. In any case limiting the
# iterations is good for test safety.
#
sub main_iterations {
my $count = 0;
if (DEBUG) { MyTestHelpers::diag ("main_iterations() ..."); }
while (Gtk2->events_pending) {
$count++;
Gtk2->main_iteration_do (0);
if ($count >= 500) {
MyTestHelpers::diag ("main_iterations(): oops, bailed out after $count events/iterations");
return;
}
}
MyTestHelpers::diag ("main_iterations(): ran $count events/iterations");
}
# warn_suppress_gtk_icon() is a $SIG{__WARN__} handler which suppresses spam
# from Gtk trying to make you buy the hi-colour icon theme. Eg,
#
# {
# local $SIG{'__WARN__'} = \&MyTestHelpers::warn_suppress_gtk_icon;
# $something = SomeThing->new;
# }
#
t/MyTestHelpers.pm view on Meta::CPAN
# in Gtk 2.0 gdk_flush() is a sync actually
Gtk2::Gdk->flush;
}
my $count = 0;
while (! $done) {
if (DEBUG >= 2) { MyTestHelpers::diag ("wait_for_event() iteration $count"); }
Gtk2->main_iteration;
$count++;
}
MyTestHelpers::diag ("wait_for_event(): '$signame' ran $count events/iterations\n");
$widget->signal_handler_disconnect ($sig_id);
Glib::Source->remove ($timer_id);
}
#-----------------------------------------------------------------------------
# X11::Protocol helpers
sub X11_chosen_screen_number {
t/test-weaken.t view on Meta::CPAN
my $editable = $renderer->start_editing
($event, $toplevel, "0", $rect, $rect, ['selected']);
isa_ok ($editable, 'Gtk2::CellEditable', 'start_editing return');
$toplevel->add ($editable);
return $editable;
},
destructor => sub {
my ($editable) = @_;
$toplevel->remove ($editable);
# iterate for idle handler hack for Gtk2 1.202
MyTestHelpers::main_iterations();
},
contents => \&Test::Weaken::Gtk2::contents_container,
});
is ($leaks, undef, 'CellRenderer garbage collection -- after start_editing');
if ($leaks) {
eval { diag "Test-Weaken ", explain($leaks) }; # explain in Test::More 0.82
}
$toplevel->destroy;
}
( run in 0.847 second using v1.01-cache-2.11-cpan-71847e10f99 )