[rfc][icedtea-web] Java -> Javascript object leak tests

Adam Domurad adomurad at redhat.com
Thu Aug 29 08:49:02 PDT 2013


On 08/28/2013 02:58 PM, Adam Domurad wrote:
> Hi all. The fixes will be posted soon, but I am putting this here so the
> reviewer can have a head-start.
>
> These tests currently fail.
>
> Bundled also are some C++ unit test infrastructure improvements:
>
> * Ability to query Java objects stored in PluginObjectStore for the C++
> unit tests. MemoryLeakDetector was augmented to use this to calculate
> Javascript-bound Java object leaks.
> * The tests now fail if there is a leak of any of the three kinds:
>   - NPAPI (eg browser_functions.memalloc)
>   - C++ (new/delete)
>   - Bound Java object leak (reference to Javascript-bound Java object in
> PluginObjectStore never freed)
> * Minor output improvements
>
> ChangeLog:
> 2013-XX-XX  Adam Domurad  <adomurad at redhat.com>
>
>          Add Java-object leak unit tests & reproducer. Treat unit test
> leak as
>          failure.
>          * plugin/icedteanp/java/sun/applet/PluginObjectStore.java
>          (getStoredClassCount): New, allow for querying amount of currently
>          bound plugin Java classes.
>          (getStoredInstanceCount): New, allow for querying amount of
> currently
>          bound plugin Java objects.
>          * tests/cpp-unit-tests/java_query.cc: Uses reflection to access
>          PluginObjectStore (getStoredInstanceCount) and
> (getStoredClassCount).
>          * tests/cpp-unit-tests/java_query.h: Same, as well introduce
>          JavaValueID, which keeps track of Java object references.
>          * tests/cpp-unit-tests/IcedTeaJavaRequestProcessorTest.cc: Make
> use of
>          JavaValueID wherever possible.
>          * tests/cpp-unit-tests/IcedTeaNPPluginTest.cc: Update to new
>          MemoryLeakDetector interface.
>          * tests/cpp-unit-tests/IcedTeaScriptablePluginObjectTest.cc: Same.
>          * tests/cpp-unit-tests/MemoryLeakDetector.h: Unify warning
> messages
>          with leak detection.
>          * tests/cpp-unit-tests/main.cc: More forceful memory leak
> detection:
>          Treat any of the 3 kinds of memory detection as failure.
>          *
> tests/reproducers/simple/JavascriptMemoryLeak/resources/JavascriptMemoryLeak.html:
>
>          Test if binding large objects continuously causes
> OutOfMemoryError.
>          *
> tests/reproducers/simple/JavascriptMemoryLeak/resources/JavascriptMemoryLeak.js:
>
>          Same.
>          *
> tests/reproducers/simple/JavascriptMemoryLeak/srcs/JavascriptMemoryLeak.java:
>
>          Same.
>          *
> tests/reproducers/simple/JavascriptMemoryLeak/testcases/JavascriptMemoryLeakTest.java:
>
>          Same.
>
> With this patch on HEAD, 36/42 unit tests should pass (6 failures), and
> the reproducer should fail.
>
> Happy hacking,
> -Adam


These test fixes came up during creation of the patch.

To be applied after the tests patch.

Cheers,
-Adam
-------------- next part --------------
A non-text attachment was scrubbed...
Name: test-fixes.patch
Type: text/x-patch
Size: 5343 bytes
Desc: not available
Url : http://mail.openjdk.java.net/pipermail/distro-pkg-dev/attachments/20130829/c01b6b62/test-fixes.patch 


More information about the distro-pkg-dev mailing list