diff options
author | Adam Domurad <[email protected]> | 2012-11-30 12:38:03 -0500 |
---|---|---|
committer | Adam Domurad <[email protected]> | 2012-11-30 12:38:03 -0500 |
commit | 3bc37bc363d716240558b095932a673257b2a20c (patch) | |
tree | e7411deeafe47134b365668153cf9891d66761f7 | |
parent | c1105d2abe3e384e36be912d9043dd5fda3ebc7f (diff) |
C++ unit testing: Simple mocking of browser-table functions
-rw-r--r-- | ChangeLog | 11 | ||||
-rw-r--r-- | tests/cpp-unit-tests/browser_mock.cc | 79 | ||||
-rw-r--r-- | tests/cpp-unit-tests/browser_mock.h | 50 | ||||
-rw-r--r-- | tests/cpp-unit-tests/main.cc | 14 |
4 files changed, 152 insertions, 2 deletions
@@ -1,3 +1,14 @@ +2012-11-30 Adam Domurad <[email protected]> + + Added a simple mechanism for mocking functions in the browser function + table. Can be expanded 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. + 2012-11-27 Jiri Vanek <[email protected]> Better error reporting from applets diff --git a/tests/cpp-unit-tests/browser_mock.cc b/tests/cpp-unit-tests/browser_mock.cc new file mode 100644 index 0000000..040910b --- /dev/null +++ b/tests/cpp-unit-tests/browser_mock.cc @@ -0,0 +1,79 @@ +/* Copyright (C) 2012 Red Hat + + This file is part of IcedTea. + + IcedTea is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2, or (at your option) + any later version. + + IcedTea is distributed in the hope that it will be useful, but + WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + General Public License for more details. + + You should have received a copy of the GNU General Public License + along with IcedTea; see the file COPYING. If not, write to the + Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA + 02110-1301 USA. + + Linking this library statically or dynamically with other modules is + making a combined work based on this library. Thus, the terms and + conditions of the GNU General Public License cover the whole + combination. + + As a special exception, the copyright holders of this library give you + permission to link this library with independent modules to produce an + executable, regardless of the license terms of these independent + modules, and to copy and distribute the resulting executable under + terms of your choice, provided that you also meet, for each linked + independent module, the terms and conditions of the license of that + module. An independent module is a module which is not derived from + or based on this library. If you modify this library, you may extend + this exception to your version of the library, but you are not + obligated to do so. If you do not wish to do so, delete this + exception statement from your version. */ + +// Browser mock functions. Add more as needed. + +#include <cstring> +#include <set> + +#include "UnitTest++.h" + +#include "browser_mock.h" + +#include "IcedTeaNPPlugin.h" + +static std::set<void*> __allocations; + +// It is expected that these will only run during a unit test +static void* mock_memalloc(uint32_t size) { + void* mem = malloc(size); + __allocations.insert(mem); + return mem; +} + +static void mock_memfree(void* ptr) { + if (__allocations.erase(ptr)) { + free(ptr); + } else { + printf("Attempt to free memory with browserfunctions.memfree that was not allocated by the browser!\n"); + CHECK(false); + } +} + +void browsermock_setup_functions() { + memset(&browser_functions, 0, sizeof(NPNetscapeFuncs)); + + browser_functions.memalloc = &mock_memalloc; + browser_functions.memfree = &mock_memfree; +} + +void browsermock_clear_state() { + __allocations.clear(); +} + +int browsermock_unfreed_allocations() { + return __allocations.size(); +} diff --git a/tests/cpp-unit-tests/browser_mock.h b/tests/cpp-unit-tests/browser_mock.h new file mode 100644 index 0000000..d936215 --- /dev/null +++ b/tests/cpp-unit-tests/browser_mock.h @@ -0,0 +1,50 @@ +/* Copyright (C) 2012 Red Hat + + This file is part of IcedTea. + + IcedTea is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2, or (at your option) + any later version. + + IcedTea is distributed in the hope that it will be useful, but + WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + General Public License for more details. + + You should have received a copy of the GNU General Public License + along with IcedTea; see the file COPYING. If not, write to the + Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA + 02110-1301 USA. + + Linking this library statically or dynamically with other modules is + making a combined work based on this library. Thus, the terms and + conditions of the GNU General Public License cover the whole + combination. + + As a special exception, the copyright holders of this library give you + permission to link this library with independent modules to produce an + executable, regardless of the license terms of these independent + modules, and to copy and distribute the resulting executable under + terms of your choice, provided that you also meet, for each linked + independent module, the terms and conditions of the license of that + module. An independent module is a module which is not derived from + or based on this library. If you modify this library, you may extend + this exception to your version of the library, but you are not + obligated to do so. If you do not wish to do so, delete this + exception statement from your version. */ + +// Browser mock functions. +// This sets up a mock for unit testing purposes that puts simple +// functions in the 'browserfunctions' table. This enables unit testing +// of some functions that would otherwise not be possible. +// Add additional mock functions in browser_mock.cc as needed + +#ifndef __BROWSER_MOCK_H__ +#define __BROWSER_MOCK_H__ + +void browsermock_setup_functions(); +void browsermock_clear_state(); +int browsermock_unfreed_allocations(); + +#endif // __BROWSER_MOCK_H__ diff --git a/tests/cpp-unit-tests/main.cc b/tests/cpp-unit-tests/main.cc index d1b6c65..135644c 100644 --- a/tests/cpp-unit-tests/main.cc +++ b/tests/cpp-unit-tests/main.cc @@ -42,6 +42,8 @@ #include <UnitTest++.h> #include <TestReporter.h> +#include "browser_mock.h" + using namespace UnitTest; class IcedteaWebUnitTestReporter: public TestReporter { @@ -54,6 +56,7 @@ public: } virtual void ReportTestStart(const TestDetails& test) { + browsermock_clear_state(); did_finish_correctly = true; } @@ -69,6 +72,11 @@ public: virtual void ReportTestFinish(const TestDetails& details, float secondsElapsed) { + if (browsermock_unfreed_allocations() > 0) { + printf("*** WARNING: Memory leak! %d more NPAPI allocations than frees!\n", + browsermock_unfreed_allocations()); + } + if (did_finish_correctly) { printf("Passed: %s\n", details.testName); } @@ -99,7 +107,9 @@ static int run_icedtea_web_unit_tests() { } int main() { - return run_icedtea_web_unit_tests(); -} + browsermock_setup_functions(); + int exitcode = run_icedtea_web_unit_tests(); + return exitcode; +} |