summaryrefslogtreecommitdiff
path: root/basic/qa/cppunit
diff options
context:
space:
mode:
authorNoel Power <noel.power@novell.com>2012-05-14 12:00:00 +0100
committerNoel Power <noel.power@novell.com>2012-05-14 12:01:08 +0100
commitd87676da2201bca921f319bd7b02ef8853edfa4f (patch)
tree69798fbc41966facfcfa8e889e9dd3f284ce148a /basic/qa/cppunit
parente9512baf22219e5073207bcce5f9e62dc6a8badc (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.cxx82
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: */