Review Request for CR : 7144861 RMI activation tests are too slow
David Holmes
david.holmes at oracle.com
Wed May 9 03:53:03 UTC 2012
On 9/05/2012 12:53 PM, Stuart Marks wrote:
> On 5/7/12 10:32 PM, David Holmes wrote:
>> As a general principle library code that catches IE and doesn't
>> rethrow it
>> should re-assert the interrupt state.
>>
>> But this isn't library code it is a stand-alone test framework as I
>> understand
>> it. So if the framework doesn't use interruption at all then the
>> response is
>> somewhat arbitrary. As you point out this code is all over the place with
>> regard to IE handling at present. The clean solution would assume
>> interrupts
>> were used to signify cancellation and code accordingly, but doing that
>> consistently all through may be a larger cleanup than Olivier wants to
>> try now.
>
> This is indeed test code, but just as library code should be decoupled
> from the caller, test code should be decoupled from its framework. So I
> think the general principle applies.
>
> I'm not asking that the all code be audited to make sure handles IE
> properly everywhere. But Olivier's changes did touch some code that
> handles IE, which naturally raises the question of the proper way to
> handle IE. Reasserting the interrupt bit and continuing around the loop
> just causes it to spin until the loop is exhausted, which doesn't seem
> sensible.
Right - that certainly has to be changed.
> Returning early seems sensible. Applying the rule says that
> the code should reassert the interrupt bit before returning.
If interruptible code is looping around an interruptible method that
must be re-executed then the usual approach is to re-assert the
interrupt outside the loop eg:
boolean wasInterrupted = false;
while (cond) {
try {
interruptibleOp();
}
catch (InterruptedException ie) {
wasInterrupted = true;
continue;
}
}
if (wasInterrupted)
Thread.currentThread().interrupt();
In this case however this seems more like a fail-fast situation so
immediate return seems in order - though the fact the test was
interrupted does have to be reported to the test harness somehow.
David
-----
> An alternative would be to have the code rethrow or propagate IE, but
> this requires additional refactoring and probably adding throws clauses
> to methods, so it's probably not warranted.
>
> My recommendation to Olivier is to run through the files in the
> changeset and modify the catch blocks as follows:
>
> catch (InterruptedException ie) {
> Thread.currentThread().interrupt();
> // maybe print a log message
> return; // or break, as appropriate
> }
>
> s'marks
More information about the core-libs-dev
mailing list