diff options
author | Norbert Thiebaud <nthiebaud@gmail.com> | 2014-03-30 20:20:23 -0500 |
---|---|---|
committer | Norbert Thiebaud <nthiebaud@gmail.com> | 2014-03-30 20:20:39 -0500 |
commit | c176cb8907530a795cb0e38de8193df931f891fb (patch) | |
tree | a9741bb08b78ca6ce15056aaa6d1e616b37537f6 /sal | |
parent | 2996f24c6999833c57a041c362ce4abc82e9279d (diff) |
decorate tempfile name's to help identify leaks' author
unottols TempFile class check in debug bod for
and env variable LO_TESTNAME.. if present it use that as the root
for the tempfile filename.
cppunitteset framework is augmented so that it export such
LO_TESNAME using the cppunit testName(), after replacement of
non-alphnum characters by _
Change-Id: Iebb9545d3bd789083afbeaf4c64eab086b56049a
Diffstat (limited to 'sal')
-rw-r--r-- | sal/cppunittester/cppunittester.cxx | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/sal/cppunittester/cppunittester.cxx b/sal/cppunittester/cppunittester.cxx index 1faae7192f86..0f4d58a06b48 100644 --- a/sal/cppunittester/cppunittester.cxx +++ b/sal/cppunittester/cppunittester.cxx @@ -95,6 +95,39 @@ private: sal_uInt32 m_nStartTime; }; +#ifdef UNX +#include <stdlib.h> +// Setup an env variable so that temp file (or other) can +// have a usefull value to identify the source +class EyecatcherListener + : public CppUnit::TestListener + , private boost::noncopyable +{ +public: + void startTest( CppUnit::Test* test) SAL_OVERRIDE + { + char* tn = new char [ test->getName().length() + 2 ]; + strcpy(tn, test->getName().c_str()); + int len = strlen(tn); + for(int i = 0; i < len; i++) + { + if(!isalnum(tn[i])) + { + tn[i] = '_'; + } + tn[len] = '_'; + tn[len + 1] = 0; + } + setenv("LO_TESTNAME", tn, true); + delete[] tn; + } + + void endTest( CppUnit::Test* /* test */ ) SAL_OVERRIDE + { + } +}; +#endif + //Allow the whole uniting testing framework to be run inside a "Protector" //which knows about uno exceptions, so it can print the content of the //exception before falling over and dying @@ -144,6 +177,10 @@ public: result.addListener(&timer); #endif +#ifdef UNX + EyecatcherListener eye; + result.addListener(&eye); +#endif for (size_t i = 0; i < protectors.size(); ++i) result.pushProtector(protectors[i]); |