/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * 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 "cppunit/extensions/HelperMacros.h" using namespace com::sun::star; using namespace com::sun::star::uno; namespace apitest { void XSpreadsheets::testInsertNewByName() { uno::Reference< sheet::XSpreadsheets > xSpreadsheets(init(), UNO_QUERY_THROW); OUString newSheetName( "SheetToInsert" ); xSpreadsheets->insertNewByName(newSheetName, 0); uno::Reference< container::XNameAccess > xNameAccess(xSpreadsheets, UNO_QUERY_THROW); CPPUNIT_ASSERT_MESSAGE("Sheet was not insert", xNameAccess->hasByName(newSheetName)); } void XSpreadsheets::testInsertNewByNameBadName() { uno::Reference< sheet::XSpreadsheets > xSpreadsheets(init(), UNO_QUERY_THROW); CPPUNIT_ASSERT_THROW_MESSAGE("No exception thrown", xSpreadsheets->insertNewByName("$%#/?\\", 0), uno::RuntimeException); } void XSpreadsheets::testMoveByName() { uno::Reference< sheet::XSpreadsheets > xSpreadsheets(init(), UNO_QUERY_THROW); // first insert one that should be moved xSpreadsheets->insertNewByName("SheetToMove", 0); uno::Reference< container::XNameAccess > xNameAccess(xSpreadsheets, UNO_QUERY_THROW); CPPUNIT_ASSERT_MESSAGE("Sheet to move was not insert", xNameAccess->hasByName("SheetToCopySrc")); xSpreadsheets->moveByName("SheetToMove", 2); // get sheet from the new position uno::Reference< container::XIndexAccess > oIndexAccess(xSpreadsheets, UNO_QUERY_THROW); uno::Any aAny = oIndexAccess->getByIndex(1); uno::Reference< container::XNamed > xNamed; CPPUNIT_ASSERT(aAny >>= xNamed); CPPUNIT_ASSERT_EQUAL_MESSAGE("Sheet was not moved", OUString("SheetToMove"), xNamed->getName()); } void XSpreadsheets::testCopyByName() { uno::Reference< sheet::XSpreadsheets > xSpreadsheets(init(), UNO_QUERY_THROW); // insert new sheet to copy xSpreadsheets->insertNewByName("SheetToCopySrc", 0); uno::Reference< container::XNameAccess > xNameAccess(xSpreadsheets, UNO_QUERY_THROW); CPPUNIT_ASSERT_MESSAGE("Sheet to copy was not insert", xNameAccess->hasByName("SheetToCopySrc")); xSpreadsheets->copyByName("SheetToCopySrc", "SheetToCopyDst", 0); CPPUNIT_ASSERT_MESSAGE("Sheet was not copied", xNameAccess->hasByName("SheetToCopyDst")); } } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */