[Catalyst-commits] r13598 - in Catalyst-Runtime/5.80/trunk: .
lib/Catalyst
t0m at dev.catalyst.perl.org
t0m at dev.catalyst.perl.org
Thu Sep 23 15:04:17 GMT 2010
Author: t0m
Date: 2010-09-23 16:04:17 +0100 (Thu, 23 Sep 2010)
New Revision: 13598
Modified:
Catalyst-Runtime/5.80/trunk/Changes
Catalyst-Runtime/5.80/trunk/lib/Catalyst/Test.pm
Log:
Bug fix for ctx_request, via matso++
Modified: Catalyst-Runtime/5.80/trunk/Changes
===================================================================
--- Catalyst-Runtime/5.80/trunk/Changes 2010-09-23 01:24:52 UTC (rev 13597)
+++ Catalyst-Runtime/5.80/trunk/Changes 2010-09-23 15:04:17 UTC (rev 13598)
@@ -3,6 +3,9 @@
Bug fixes:
- use Class::MOP in Catalyst::Utils.
+ - Do not keep a reference to a closed over context in ctx_request, allowing
+ the caller to dispose of the request context at their leisure.
+
5.80027 2010-09-01 22:14:00
Bug fixes:
Modified: Catalyst-Runtime/5.80/trunk/lib/Catalyst/Test.pm
===================================================================
--- Catalyst-Runtime/5.80/trunk/lib/Catalyst/Test.pm 2010-09-23 01:24:52 UTC (rev 13597)
+++ Catalyst-Runtime/5.80/trunk/lib/Catalyst/Test.pm 2010-09-23 15:04:17 UTC (rev 13598)
@@ -44,7 +44,7 @@
### place holder for $c after the request finishes; reset every time
### requests are done.
- my $c;
+ my $ctx_closed_over;
### hook into 'dispatch' -- the function gets called after all plugins
### have done their work, and it's an easy place to capture $c.
@@ -52,7 +52,7 @@
my $meta = Class::MOP::get_metaclass_by_name($class);
$meta->make_mutable;
$meta->add_after_method_modifier( "dispatch", sub {
- $c = shift;
+ $ctx_closed_over = shift;
});
$meta->make_immutable( replace_constructor => 1 );
Class::C3::reinitialize(); # Fixes RT#46459, I've failed to write a test for how/why, but it does.
@@ -60,8 +60,18 @@
### we've already stopped it from doing remote requests above.
my $res = $request->( @_ );
+ # Make sure not to leave a reference $ctx hanging around.
+ # This means that the context will go out of scope as soon as the
+ # caller disposes of it, rather than waiting till the next time
+ # that ctx_request is called. This can be important if your $ctx
+ # ends up with a reference to a shared resource or lock (for example)
+ # which you want to clean up in test teardown - if the $ctx is still
+ # closed over then you're stuffed...
+ my $ctx = $ctx_closed_over;
+ undef $ctx_closed_over;
+
### return both values
- return ( $res, $c );
+ return ( $res, $ctx );
};
return {
More information about the Catalyst-commits
mailing list