/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4; fill-column: 100 -*- */ /* * This file is part of the LibreOffice project. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include using namespace css; using namespace css::uno; namespace sc_apitest { class ScTableSheetsObj : public UnoApiTest, public ::apitest::XElementAccess, public ::apitest::XEnumerationAccess, public ::apitest::XIndexAccess, public ::apitest::XNameAccess, public ::apitest::XNameContainer, public ::apitest::XNameReplace, public ::apitest::XServiceInfo, public ::apitest::XSpreadsheets, public ::apitest::XSpreadsheets2 { public: ScTableSheetsObj(); virtual void setUp() override; virtual uno::Reference init() override; CPPUNIT_TEST_SUITE(ScTableSheetsObj); // XElementAccess CPPUNIT_TEST(testGetElementType); CPPUNIT_TEST(testHasElements); // XEnumerationAccess CPPUNIT_TEST(testCreateEnumeration); // XIndexAccess CPPUNIT_TEST(testGetByIndex); CPPUNIT_TEST(testGetCount); // XNameAccess CPPUNIT_TEST(testGetByName); CPPUNIT_TEST(testGetElementNames); CPPUNIT_TEST(testHasByName); // XNameContainer CPPUNIT_TEST(testInsertByName); CPPUNIT_TEST(testInsertByNameEmptyName); CPPUNIT_TEST(testInsertByNameDuplicate); CPPUNIT_TEST(testRemoveByName); CPPUNIT_TEST(testRemoveByNameNoneExistingElement); // XNameReplace CPPUNIT_TEST(testReplaceByName); // XServiceInfo CPPUNIT_TEST(testGetImplementationName); CPPUNIT_TEST(testGetSupportedServiceNames); CPPUNIT_TEST(testSupportsService); // XSpreadsheets CPPUNIT_TEST(testInsertNewByName); CPPUNIT_TEST(testInsertNewByNameBadName); CPPUNIT_TEST(testCopyByName); CPPUNIT_TEST(testMoveByName); // XSpreadsheets2 CPPUNIT_TEST(testImportedSheetNameAndIndex); CPPUNIT_TEST(testImportString); CPPUNIT_TEST(testImportValue); CPPUNIT_TEST(testImportFormulaBasicMath); CPPUNIT_TEST(testImportFormulaWithNamedRange); CPPUNIT_TEST(testImportOverExistingNamedRange); CPPUNIT_TEST(testImportNamedRangeDefinedInSource); CPPUNIT_TEST(testImportNamedRangeRedefinedInSource); CPPUNIT_TEST(testImportNewNamedRange); CPPUNIT_TEST(testImportCellStyle); CPPUNIT_TEST(testLastAfterInsertCopy); CPPUNIT_TEST_SUITE_END(); virtual uno::Reference loadFromDesktop(const OUString& rFileBase) override; }; ScTableSheetsObj::ScTableSheetsObj() : UnoApiTest(u"/sc/qa/extras/testdocuments"_ustr) , ::apitest::XElementAccess(cppu::UnoType::get()) , ::apitest::XIndexAccess(3) , ::apitest::XNameAccess(u"Sheet1"_ustr) , ::apitest::XNameContainer(u"Sheet2"_ustr) , ::apitest::XNameReplace(u"Sheet2"_ustr) , ::apitest::XServiceInfo(u"ScTableSheetsObj"_ustr, u"com.sun.star.sheet.Spreadsheets"_ustr) { } uno::Reference ScTableSheetsObj::loadFromDesktop(const OUString& rFileBase) { OUString aString = createFileURL(rFileBase); return UnoApiTest::loadFromDesktop(aString); } uno::Reference ScTableSheetsObj::init() { xDocument.set(mxComponent, UNO_QUERY_THROW); uno::Reference xReturn(xDocument->getSheets(), UNO_QUERY_THROW); uno::Reference xMSF(mxComponent, uno::UNO_QUERY_THROW); XNameContainer::setElement( uno::Any(xMSF->createInstance(u"com.sun.star.sheet.Spreadsheet"_ustr))); // XNameReplace XNameReplace::setElement( uno::Any(xMSF->createInstance(u"com.sun.star.sheet.Spreadsheet"_ustr))); return xReturn; } void ScTableSheetsObj::setUp() { UnoApiTest::setUp(); // create a calc document loadFromFile(u"rangenamessrc.ods"); } CPPUNIT_TEST_SUITE_REGISTRATION(ScTableSheetsObj); } // namespace sc_apitest CPPUNIT_PLUGIN_IMPLEMENT(); /* vim:set shiftwidth=4 softtabstop=4 expandtab cinoptions=b1,g0,N-s cinkeys+=0=break: */