make unoCheckStruct uglier but detect unfixed type assignment + add new tests
Change-Id: I6160e7d1abeeda1ea89e2fe15a9155041f2e5adb
This commit is contained in:
@@ -20,12 +20,16 @@ namespace
|
||||
Nested_Struct() {};
|
||||
void testAssign1();
|
||||
void testOldAssign();
|
||||
void testUnfixedVarAssign();
|
||||
void testFixedVarAssign();
|
||||
// Adds code needed to register the test suite
|
||||
CPPUNIT_TEST_SUITE(Nested_Struct);
|
||||
|
||||
// Declares the method as a test to call
|
||||
CPPUNIT_TEST(testAssign1);
|
||||
CPPUNIT_TEST(testOldAssign);
|
||||
CPPUNIT_TEST(testUnfixedVarAssign);
|
||||
CPPUNIT_TEST(testFixedVarAssign);
|
||||
|
||||
// End of test suite definition
|
||||
CPPUNIT_TEST_SUITE_END();
|
||||
@@ -57,6 +61,35 @@ rtl::OUString sTestSource2(
|
||||
"End Function\n"
|
||||
);
|
||||
|
||||
// it should be legal to assign a variant to a struct ( and copy by val )
|
||||
// make sure we aren't copying by reference, we make sure that l is not
|
||||
// a reference copy of b0.HorizontalLine, each one should have an
|
||||
// OuterLineWidth of 4 & 9 respectively and we should be returning
|
||||
// 13 the sum of the two ( hopefully unique values if we haven't copied by reference )
|
||||
rtl::OUString sTestSource3(
|
||||
"Function testUnfixedVarAssign()\n"
|
||||
"Dim b0 as new \"com.sun.star.table.TableBorder\"\n"
|
||||
"l = b0.HorizontalLine\n"
|
||||
"l.OuterLineWidth = 9\n"
|
||||
"b0.HorizontalLine = l\n"
|
||||
"l.OuterLineWidth = 4\n"
|
||||
"testUnfixedVarAssign = b0.HorizontalLine.OuterLineWidth + l.OuterLineWidth\n"
|
||||
"End Function\n"
|
||||
);
|
||||
|
||||
// nearly the same as above but this time for a fixed type
|
||||
// variable
|
||||
rtl::OUString sTestSource4(
|
||||
"Function testFixedVarAssign()\n"
|
||||
"Dim b0 as new \"com.sun.star.table.TableBorder\", l as new \"com.sun.star.table.BorderLine\"\n"
|
||||
"l = b0.HorizontalLine\n"
|
||||
"l.OuterLineWidth = 9\n"
|
||||
"b0.HorizontalLine = l\n"
|
||||
"l.OuterLineWidth = 4\n"
|
||||
"testFixedVarAssign = b0.HorizontalLine.OuterLineWidth + l.OuterLineWidth\n"
|
||||
"End Function\n"
|
||||
);
|
||||
|
||||
void Nested_Struct::testAssign1()
|
||||
{
|
||||
CPPUNIT_ASSERT_MESSAGE( "No resource manager", basicDLL().GetBasResMgr() != NULL );
|
||||
@@ -93,6 +126,42 @@ void Nested_Struct::testOldAssign()
|
||||
CPPUNIT_ASSERT(pNew->GetInteger() == 9 );
|
||||
}
|
||||
|
||||
void Nested_Struct::testUnfixedVarAssign()
|
||||
{
|
||||
CPPUNIT_ASSERT_MESSAGE( "No resource manager", basicDLL().GetBasResMgr() != NULL );
|
||||
StarBASICRef pBasic = new StarBASIC();
|
||||
ResetError();
|
||||
StarBASIC::SetGlobalErrorHdl( LINK( this, Nested_Struct, BasicErrorHdl ) );
|
||||
|
||||
SbModule* pMod = pBasic->MakeModule( rtl::OUString( "TestModule" ), sTestSource3 );
|
||||
pMod->Compile();
|
||||
CPPUNIT_ASSERT_MESSAGE("testUnfixedVarAssign fails with compile error",!HasError() );
|
||||
SbMethod* pMeth = static_cast<SbMethod*>(pMod->Find( rtl::OUString("testUnfixedVarAssign"), SbxCLASS_METHOD ));
|
||||
CPPUNIT_ASSERT_MESSAGE("testUnfixedVarAssign no method found", pMeth );
|
||||
SbxVariableRef refTemp = pMeth;
|
||||
// forces a broadcast
|
||||
SbxVariableRef pNew = new SbxMethod( *((SbxMethod*)pMeth));
|
||||
CPPUNIT_ASSERT(pNew->GetInteger() == 13 );
|
||||
}
|
||||
|
||||
void Nested_Struct::testFixedVarAssign()
|
||||
{
|
||||
CPPUNIT_ASSERT_MESSAGE( "No resource manager", basicDLL().GetBasResMgr() != NULL );
|
||||
StarBASICRef pBasic = new StarBASIC();
|
||||
ResetError();
|
||||
StarBASIC::SetGlobalErrorHdl( LINK( this, Nested_Struct, BasicErrorHdl ) );
|
||||
|
||||
SbModule* pMod = pBasic->MakeModule( rtl::OUString( "TestModule" ), sTestSource4 );
|
||||
pMod->Compile();
|
||||
CPPUNIT_ASSERT_MESSAGE("testFixedVarAssign fails with compile error",!HasError() );
|
||||
SbMethod* pMeth = static_cast<SbMethod*>(pMod->Find( rtl::OUString("testFixedVarAssign"), SbxCLASS_METHOD ));
|
||||
CPPUNIT_ASSERT_MESSAGE("testFixedVarAssign no method found", pMeth );
|
||||
SbxVariableRef refTemp = pMeth;
|
||||
// forces a broadcast
|
||||
SbxVariableRef pNew = new SbxMethod( *((SbxMethod*)pMeth));
|
||||
CPPUNIT_ASSERT(pNew->GetInteger() == 13 );
|
||||
}
|
||||
|
||||
// Put the test suite in the registry
|
||||
CPPUNIT_TEST_SUITE_REGISTRATION(Nested_Struct);
|
||||
} // namespace
|
||||
|
Reference in New Issue
Block a user