31e0ada711
E.g. sctablesheetobj test had the limits hardcoded, even as actual numbers. Apparently some tests cannot easily access global settings, but this at least makes it easy to check all tests after modifying ScSheetLimits::CreateDefault(). Change-Id: I6cff577fb01b1ea262dcd1f9fde24e114e19abdc Reviewed-on: https://gerrit.libreoffice.org/c/core/+/131040 Tested-by: Jenkins Reviewed-by: Luboš Luňák <l.lunak@collabora.com>
136 lines
4.4 KiB
C++
136 lines
4.4 KiB
C++
/* -*- 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 <test/calc_unoapi_test.hxx>
|
|
#include <test/container/xelementaccess.hxx>
|
|
#include <test/container/xenumerationaccess.hxx>
|
|
#include <test/container/xindexaccess.hxx>
|
|
#include <test/lang/xserviceinfo.hxx>
|
|
#include <test/table/xtablerows.hxx>
|
|
|
|
#include <com/sun/star/container/XNameAccess.hpp>
|
|
#include <com/sun/star/lang/XComponent.hpp>
|
|
#include <com/sun/star/sheet/XSpreadsheet.hpp>
|
|
#include <com/sun/star/sheet/XSpreadsheetDocument.hpp>
|
|
#include <com/sun/star/sheet/XSpreadsheets.hpp>
|
|
#include <com/sun/star/table/XCellRange.hpp>
|
|
#include <com/sun/star/table/XColumnRowRange.hpp>
|
|
#include <com/sun/star/table/XTableRows.hpp>
|
|
#include <com/sun/star/uno/XInterface.hpp>
|
|
|
|
#include <com/sun/star/uno/Reference.hxx>
|
|
|
|
#include <cppu/unotype.hxx>
|
|
|
|
#include <sheetlimits.hxx>
|
|
|
|
using namespace css;
|
|
using namespace css::uno;
|
|
|
|
namespace sc_apitest
|
|
{
|
|
class ScTableRowsObj : public CalcUnoApiTest,
|
|
public apitest::XElementAccess,
|
|
public apitest::XEnumerationAccess,
|
|
public apitest::XIndexAccess,
|
|
public apitest::XServiceInfo,
|
|
public apitest::XTableRows
|
|
{
|
|
public:
|
|
ScTableRowsObj();
|
|
|
|
virtual uno::Reference<uno::XInterface> init() override;
|
|
virtual uno::Reference<uno::XInterface> getXCellRange() override;
|
|
virtual void setUp() override;
|
|
virtual void tearDown() override;
|
|
|
|
CPPUNIT_TEST_SUITE(ScTableRowsObj);
|
|
|
|
// XElementAccess
|
|
CPPUNIT_TEST(testGetElementType);
|
|
CPPUNIT_TEST(testHasElements);
|
|
|
|
// XEnumerationAccess
|
|
CPPUNIT_TEST(testCreateEnumeration);
|
|
|
|
// XIndexAccess
|
|
CPPUNIT_TEST(testGetByIndex);
|
|
CPPUNIT_TEST(testGetCount);
|
|
|
|
// XServiceInfo
|
|
CPPUNIT_TEST(testGetImplementationName);
|
|
CPPUNIT_TEST(testGetSupportedServiceNames);
|
|
CPPUNIT_TEST(testSupportsService);
|
|
|
|
// XTableRows
|
|
CPPUNIT_TEST(testInsertByIndex);
|
|
CPPUNIT_TEST(testRemoveByIndex);
|
|
|
|
CPPUNIT_TEST_SUITE_END();
|
|
|
|
private:
|
|
uno::Reference<lang::XComponent> m_xComponent;
|
|
};
|
|
|
|
ScTableRowsObj::ScTableRowsObj()
|
|
: CalcUnoApiTest("/sc/qa/extras/testdocuments")
|
|
, XElementAccess(cppu::UnoType<table::XCellRange>::get())
|
|
, XIndexAccess(ScSheetLimits::CreateDefault().GetMaxRowCount())
|
|
, XServiceInfo("ScTableRowsObj", "com.sun.star.table.TableRows")
|
|
{
|
|
}
|
|
|
|
uno::Reference<uno::XInterface> ScTableRowsObj::init()
|
|
{
|
|
uno::Reference<sheet::XSpreadsheetDocument> xDoc(m_xComponent, uno::UNO_QUERY_THROW);
|
|
CPPUNIT_ASSERT_MESSAGE("no calc document", xDoc.is());
|
|
|
|
uno::Reference<sheet::XSpreadsheets> xSheets(xDoc->getSheets(), uno::UNO_SET_THROW);
|
|
uno::Reference<container::XNameAccess> xNA(xSheets, uno::UNO_QUERY_THROW);
|
|
uno::Reference<sheet::XSpreadsheet> xSheet0(xSheets->getByName(xNA->getElementNames()[0]),
|
|
uno::UNO_QUERY_THROW);
|
|
|
|
uno::Reference<table::XColumnRowRange> xCRR(xSheet0, uno::UNO_QUERY_THROW);
|
|
uno::Reference<table::XTableRows> xTR(xCRR->getRows(), uno::UNO_SET_THROW);
|
|
|
|
return xTR;
|
|
}
|
|
|
|
uno::Reference<uno::XInterface> ScTableRowsObj::getXCellRange()
|
|
{
|
|
uno::Reference<sheet::XSpreadsheetDocument> xDoc(m_xComponent, uno::UNO_QUERY_THROW);
|
|
CPPUNIT_ASSERT_MESSAGE("no calc document", xDoc.is());
|
|
|
|
uno::Reference<sheet::XSpreadsheets> xSheets(xDoc->getSheets(), uno::UNO_SET_THROW);
|
|
uno::Reference<container::XNameAccess> xNA(xSheets, uno::UNO_QUERY_THROW);
|
|
uno::Reference<sheet::XSpreadsheet> xSheet0(xSheets->getByName(xNA->getElementNames()[0]),
|
|
uno::UNO_QUERY_THROW);
|
|
|
|
uno::Reference<table::XCellRange> xCR(xSheet0, uno::UNO_QUERY_THROW);
|
|
return xCR;
|
|
}
|
|
|
|
void ScTableRowsObj::setUp()
|
|
{
|
|
CalcUnoApiTest::setUp();
|
|
m_xComponent = loadFromDesktop("private:factory/scalc");
|
|
}
|
|
|
|
void ScTableRowsObj::tearDown()
|
|
{
|
|
closeDocument(m_xComponent);
|
|
CalcUnoApiTest::tearDown();
|
|
}
|
|
|
|
CPPUNIT_TEST_SUITE_REGISTRATION(ScTableRowsObj);
|
|
} // namespace sc_apitest
|
|
|
|
CPPUNIT_PLUGIN_IMPLEMENT();
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab cinoptions=b1,g0,N-s cinkeys+=0=break: */
|