[rfc][icedtea-web] Java -> Javascript object leak tests
Adam Domurad
adomurad at redhat.com
Wed Aug 28 11:58:27 PDT 2013
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
-------------- next part --------------
A non-text attachment was scrubbed...
Name: BoundJavaObjectLeakTests.patch
Type: text/x-patch
Size: 59665 bytes
Desc: not available
Url : http://mail.openjdk.java.net/pipermail/distro-pkg-dev/attachments/20130828/2793080d/BoundJavaObjectLeakTests.patch
More information about the distro-pkg-dev
mailing list