diff options
author | Noel Power <noel.power@novell.com> | 2012-05-14 12:00:00 +0100 |
---|---|---|
committer | Noel Power <noel.power@novell.com> | 2012-05-14 12:01:08 +0100 |
commit | d87676da2201bca921f319bd7b02ef8853edfa4f (patch) | |
tree | 69798fbc41966facfcfa8e889e9dd3f284ce148a /basic/qa/cppunit | |
parent | e9512baf22219e5073207bcce5f9e62dc6a8badc (diff) |
simple compile test for use of 'Enable' in a Dim statement
Change-Id: I051dbb5cd56fe61e2b0aea1184dcdb03c6413834
Diffstat (limited to 'basic/qa/cppunit')
-rw-r--r-- | basic/qa/cppunit/test_append.cxx | 82 |
1 files changed, 82 insertions, 0 deletions
diff --git a/basic/qa/cppunit/test_append.cxx b/basic/qa/cppunit/test_append.cxx new file mode 100644 index 000000000000..2afd912087f4 --- /dev/null +++ b/basic/qa/cppunit/test_append.cxx @@ -0,0 +1,82 @@ +/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ +#include "sal/config.h" +#include "sal/precppunit.hxx" + +#include "cppunit/TestAssert.h" +#include "cppunit/TestFixture.h" +#include "cppunit/extensions/HelperMacros.h" +#include "cppunit/plugin/TestPlugIn.h" + +#include <test/bootstrapfixture.hxx> + +#include "osl/file.hxx" +#include "osl/process.h" + +#include "basic/sbstar.hxx" +#include "basic/sbmod.hxx" +#include "basic/basrdll.hxx" +namespace +{ + class EnableTest : public test::BootstrapFixture + { + private: + bool mbError; + public: + EnableTest() : mbError(false) {}; + void testDimEnable(); + // Adds code needed to register the test suite + CPPUNIT_TEST_SUITE(EnableTest); + + // Declares the method as a test to call + CPPUNIT_TEST(testDimEnable); + + // End of test suite definition + CPPUNIT_TEST_SUITE_END(); + + DECL_LINK( BasicErrorHdl, StarBASIC * ); + bool HasError() { return mbError; } + BasicDLL& basicDLL() + { + static BasicDLL maDll; // we need a dll instance for resouce manager etc. + return maDll; + } + }; + +IMPL_LINK( EnableTest, BasicErrorHdl, StarBASIC *, /*pBasic*/) +{ + fprintf(stderr,"Got error: \n\t%s!!!\n", rtl::OUStringToOString( StarBASIC::GetErrorText(), RTL_TEXTENCODING_UTF8 ).getStr() ); + mbError = true; + return 0; +} + +class MyBASIC : public StarBASIC +{ + public: + MyBASIC(){} + ~MyBASIC(){} +}; + +void EnableTest::testDimEnable() +{ + CPPUNIT_ASSERT_MESSAGE( "No resource manager", basicDLL().GetBasResMgr() != NULL ); + std::auto_ptr<MyBASIC> pBasic; + pBasic.reset( new MyBASIC() ); + StarBASIC::SetGlobalErrorHdl( LINK( this, EnableTest, BasicErrorHdl ) ); + + rtl::OUString sSource("Sub Test\n"); + sSource += rtl::OUString("Dim Enable as String\n"); + sSource += rtl::OUString("End Sub\n"); + + SbModule* pMod = pBasic->MakeModule( rtl::OUString( "TestModule" ), sSource ); + pMod->Compile(); + + CPPUNIT_ASSERT_MESSAGE("Dim causes compile error", !mbError ); + StarBASIC::SetGlobalErrorHdl( Link() ); +} + + // Put the test suite in the registry + CPPUNIT_TEST_SUITE_REGISTRATION(EnableTest); +} // namespace +CPPUNIT_PLUGIN_IMPLEMENT(); + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |