[rfc][icedtea-web] Many C++-plugin unit tests that invoke Java

Pavel Tisnovsky ptisnovs at redhat.com
Fri Aug 23 07:48:42 PDT 2013


Hi Adam,

both changes looks good, ok for head.

Thank you,
Pavel

----- Adam Domurad <adomurad at redhat.com> wrote:
> Hi all. Recently I decided to try spawning the Java process during the 
> C++ unit tests to great success. This allows us to test much of the 
> NPAPI usage and the Java<->Javascript usage.
> 
> I have painstakenly provided full method coverage (at least execution) 
> for JavaRequestProcessor, which provides reflection-oriented requests 
> from C++ to Java. As well I introduced a few other tests this enabled.
> 
> Small refactoring goes first.
> ChangeLog:
> 	2013-XX-XX  Adam Domurad  <adomurad at redhat.com>
> 
>          * plugin/icedteanp/IcedTeaNPPlugin.cc: Refactor plugin data 
> creation.
>          * plugin/icedteanp/IcedTeaNPPlugin.h: Same.
> 
> 
> And the major patch:
> ChangeLog:
> 2013-XX-XX  Adam Domurad  <adomurad at redhat.com>
> 
>          Spawn Java side during C++ unit tests. Many new tests.
>          * plugin/icedteanp/IcedTeaJavaRequestProcessor.cc
>          (hasPackage): Minor cleanup.
>          * plugin/icedteanp/IcedTeaNPPlugin.cc
>          (initialize_data_directory): New, extracted function.
>          (NP_Initialize): Calls extracted function.
>          * plugin/icedteanp/IcedTeaNPPlugin.h: Expose more functions for
>          testing purposes.
>          * tests/cpp-unit-tests/IcedTeaNPPluginTest.cc
>          (get_scriptable_package_object): Test binding of java package
>          (get_scriptable_java_object): Test binding of java object
>          * tests/cpp-unit-tests/IcedTeaPluginUtilsTest.cc
>          (NPIdentifierAsString): Update to create npidentifier properly.
>          * tests/cpp-unit-tests/IcedTeaScriptablePluginObjectTest.cc
>          (getProperty): Test loading java.lang.Integer.MAX_VALUE from C++.
>          * tests/cpp-unit-tests/MemoryLeakDetector.h
>          (reset_global_state): Made public
>          * tests/cpp-unit-tests/checked_allocations.h
>          (SafeAllocator): New, typedef for allocator that avoids leak 
> detection.
>          * tests/cpp-unit-tests/browser_mock.cc
>          (browsermock_setup_functions): Renamed to 
> (browsermock_create_table).
>          (browsermock_create_table): Now returns browser table, additional
>          object release and identifier methods added.
>          * tests/cpp-unit-tests/browser_mock.h: Update for rename.
>          * tests/cpp-unit-tests/main.cc: Now clears state via
>          (reset_global_state)
>          * tests/cpp-unit-tests/IcedTeaJavaRequestProcessorTest.cc: New,
>          contains unit tests that cover all of JavaRequestProcessor's 
> methods.
>          * tests/cpp-unit-tests/browser_mock_npidentifier.cc: 
> Allocation-safe
>          npidentifier mocking, adheres to NPAPI spec.
>          * tests/cpp-unit-tests/browser_mock_npidentifier.h: Same.
> 
> 
> Happy hacking,
> -Adam




More information about the distro-pkg-dev mailing list