RFR 8152893 : StackWalker#getCallerClass is not filtering hidden/ reflection frames when walker is configured to show hidden /reflection frames
Mandy Chung
mandy.chung at oracle.com
Fri Jun 3 01:54:37 UTC 2016
> On Jun 2, 2016, at 4:23 PM, Brent Christian <brent.christian at oracle.com> wrote:
>
> Hi,
>
> The docs for StackWalker.getCallerClass() state, "Reflection frames, MethodHandle and hidden frames are filtered regardless of the SHOW_REFLECT_FRAMES and SHOW_HIDDEN_FRAMES options."
>
> However getCallerClass() is sensitive to the SHOW_*_FRAMES options, and calling getCallerClass() on a StackWalker with those options can return classes that should be filtered out, e.g.:
> sun.reflect.NativeMethodAccessorImpl
> and
> Test$InnerClass$$Lambda$1/1018937824
>
> StackStreamFactory.CallerClassFinder needs to skip reflection frames when consuming frames, a 1-line fix. I updated the test to cover this issue and added a lambda case, and also did some light grammar/punctuation improvements on the getCallerClass JavaDoc.
>
> The webrev is here:
> http://cr.openjdk.java.net/~bchristi/8152893/webrev.00/
Looks fine. Thanks for doing the touchup on javadoc.
Nit: on GetCallerClassTest.java:
178 Class<?> c = (Class<?>) walker.getCallerClass();
The cast should not be needed. Any reason there?
184 } catch (Throwable e) {
I suspect this copied from the reflectiveGetCallerClass. Anyway, would it be simpler doing this:
Runnable lambdaRunnable = () -> {
GetCallerClassTest.staticGetCallerClass(walker, this.getClass(), expectUOE);
};
lambdaRunnable.run();
Mandy
More information about the core-libs-dev
mailing list