[icedtea-web][rfc] Refactor a JS<->Java function, add browser-table mocking to C++ unit tests

Adam Domurad adomurad at redhat.com
Thu Nov 29 10:37:07 PST 2012


Hi all. This refactoring will help in the fix for the JSObject bug [1]

Firstly, to aid in testing this I added a simple mechanism for mocking 
browser callbacks:

Testing framework ChangeLog:
2012-11-XX  Adam Domurad  <adomurad at redhat.com>

     Added a simple mechanism for mocking functions in the browser function
     table. Can be exapanded as needed.
     * tests/cpp-unit-tests/main.cc: Call setup function, warn on browser
     function based memory leak.
     * tests/cpp-unit-tests/browser_mock.cc: New, implements simple
     error-checking mocks of browser callbacks.
     * tests/cpp-unit-tests/browser_mock.h: New, interface to mocking
     functions.

A further idea for testing these functions (which rely on 
JavaRequestProcessor) is to have a different version of this class when 
compiling for unit tests. This would effectively 'mock' the class 
without having to modify the extensibility of the actual class (eg can 
make everything virtual but thats intrusive).

The refactoring introduces two convenience methods, and breaks up 
IcedTeaPluginUtilities::javaResultToNPVariant into multiple, more 
manageable parts. This will make it easier to apply the fix (which 
requires a special case for sun.plugin.JSObject like the one done on 
java.lang.String). This refactoring is in jsfunc-refactor.patch, and 
(since the patch doesn't read well) copied into newjsfunc-snippet.cpp.

Refactoring ChangeLog:
2012-11-XX  Adam Domurad  <adomurad at redhat.com>

     Breaks up IcedTeaPluginUtilities::javaResultToNPVariant into multiple,
     more manageable parts.
     * plugin/icedteanp/IcedTeaPluginUtils.cc: Make three helper functions
     for the different cases. Two new helper functions for converting from
     std::string to NPString and NPVariant.
     * plugin/icedteanp/IcedTeaPluginUtils.h: Two new helper functions.
     * tests/cpp-unit-tests/IcedTeaPluginUtilsTest.cc: Tests for the new
     NPString and NPVariant from std::string functions.


[1] http://icedtea.classpath.org/bugzilla/show_bug.cgi?id=1198


Happy hacking,
-Adam
-------------- next part --------------
A non-text attachment was scrubbed...
Name: browsermock.patch
Type: text/x-patch
Size: 6524 bytes
Desc: not available
Url : http://mail.openjdk.java.net/pipermail/distro-pkg-dev/attachments/20121129/4804001d/browsermock.patch 
-------------- next part --------------
A non-text attachment was scrubbed...
Name: jsfunc-refactor.patch
Type: text/x-patch
Size: 11790 bytes
Desc: not available
Url : http://mail.openjdk.java.net/pipermail/distro-pkg-dev/attachments/20121129/4804001d/jsfunc-refactor.patch 
-------------- next part --------------
A non-text attachment was scrubbed...
Name: newjsfunc-snippet.cpp
Type: text/x-c++src
Size: 3681 bytes
Desc: not available
Url : http://mail.openjdk.java.net/pipermail/distro-pkg-dev/attachments/20121129/4804001d/newjsfunc-snippet.cpp 


More information about the distro-pkg-dev mailing list