142 lines
4.8 KiB
C++
142 lines
4.8 KiB
C++
/* -*- 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 <test/unoapi_test.hxx>
|
|
#include <test/container/xnamed.hxx>
|
|
#include <test/sheet/xdatapilotdescriptor.hxx>
|
|
#include <test/sheet/xdatapilottable.hxx>
|
|
#include <test/sheet/xdatapilottable2.hxx>
|
|
|
|
#include <com/sun/star/sheet/XSpreadsheetDocument.hpp>
|
|
#include <com/sun/star/sheet/XSpreadsheet.hpp>
|
|
#include <com/sun/star/sheet/XDataPilotTablesSupplier.hpp>
|
|
#include <com/sun/star/sheet/XDataPilotTables.hpp>
|
|
#include <com/sun/star/sheet/XDataPilotTable.hpp>
|
|
|
|
using namespace css;
|
|
using namespace css::uno;
|
|
|
|
namespace sc_apitest {
|
|
|
|
class ScDataPilotTableObj : public UnoApiTest,
|
|
public apitest::XDataPilotDescriptor,
|
|
public apitest::XDataPilotTable,
|
|
public apitest::XDataPilotTable2,
|
|
public apitest::XNamed
|
|
{
|
|
public:
|
|
ScDataPilotTableObj();
|
|
|
|
virtual void setUp() override;
|
|
virtual uno::Reference< uno::XInterface > init() override;
|
|
virtual uno::Reference< uno::XInterface > initDP2() override;
|
|
virtual uno::Reference< uno::XInterface > getSheets() override;
|
|
|
|
CPPUNIT_TEST_SUITE(ScDataPilotTableObj);
|
|
|
|
// XDataPilotDescriptor
|
|
CPPUNIT_TEST(testSourceRange);
|
|
CPPUNIT_TEST(testTag);
|
|
CPPUNIT_TEST(testGetFilterDescriptor);
|
|
CPPUNIT_TEST(testGetDataPilotFields);
|
|
CPPUNIT_TEST(testGetColumnFields);
|
|
CPPUNIT_TEST(testGetRowFields);
|
|
CPPUNIT_TEST(testGetPageFields);
|
|
CPPUNIT_TEST(testGetDataFields);
|
|
//CPPUNIT_TEST(testGetHiddenFields);
|
|
|
|
// XDataPilotTable
|
|
CPPUNIT_TEST(testGetOutputRange);
|
|
CPPUNIT_TEST(testRefresh);
|
|
|
|
// XDataPilotTable2
|
|
CPPUNIT_TEST(testGetDrillDownData);
|
|
CPPUNIT_TEST(testInsertDrillDownSheet);
|
|
CPPUNIT_TEST(testGetPositionData);
|
|
CPPUNIT_TEST(testGetOutputRangeByType);
|
|
|
|
// XNamed
|
|
CPPUNIT_TEST(testGetName);
|
|
CPPUNIT_TEST(testSetName);
|
|
|
|
CPPUNIT_TEST_SUITE_END();
|
|
};
|
|
|
|
ScDataPilotTableObj::ScDataPilotTableObj()
|
|
: UnoApiTest(u"/sc/qa/extras/testdocuments"_ustr),
|
|
apitest::XNamed(u"DataPilotTable"_ustr)
|
|
{
|
|
}
|
|
|
|
uno::Reference< uno::XInterface > ScDataPilotTableObj::init()
|
|
{
|
|
uno::Reference< sheet::XSpreadsheetDocument > xDoc(mxComponent, UNO_QUERY_THROW);
|
|
|
|
uno::Reference< container::XIndexAccess > xIndex (xDoc->getSheets(), UNO_QUERY_THROW);
|
|
uno::Reference< sheet::XSpreadsheet > xSheet( xIndex->getByIndex(0), UNO_QUERY_THROW);
|
|
|
|
// set variables from xdatapilottable.[ch]xx
|
|
xCellForChange = xSheet->getCellByPosition( 1, 5 );
|
|
xCellForCheck = xSheet->getCellByPosition( 7, 11 );
|
|
CPPUNIT_ASSERT(xCellForCheck.is());
|
|
CPPUNIT_ASSERT(xCellForChange.is());
|
|
|
|
CPPUNIT_ASSERT_MESSAGE("Could not create interface of type XSpreadsheet", xSheet.is());
|
|
uno::Reference< sheet::XDataPilotTablesSupplier > xDPTS(xSheet, UNO_QUERY_THROW);
|
|
uno::Reference< sheet::XDataPilotTables > xDPT = xDPTS->getDataPilotTables();
|
|
CPPUNIT_ASSERT(xDPT.is());
|
|
|
|
uno::Reference< sheet::XDataPilotTable > xDPTable(xDPT->getByName(u"DataPilotTable"_ustr),UNO_QUERY_THROW);
|
|
|
|
return xDPTable;
|
|
}
|
|
|
|
uno::Reference< uno::XInterface > ScDataPilotTableObj::getSheets()
|
|
{
|
|
uno::Reference< sheet::XSpreadsheetDocument > xDoc(mxComponent, UNO_QUERY_THROW);
|
|
uno::Reference< uno::XInterface > xSheets(xDoc->getSheets());
|
|
return xSheets;
|
|
}
|
|
|
|
uno::Reference< uno::XInterface > ScDataPilotTableObj::initDP2()
|
|
{
|
|
uno::Reference< sheet::XSpreadsheetDocument > xDoc(mxComponent, UNO_QUERY_THROW);
|
|
uno::Reference< container::XIndexAccess > xIndex (xDoc->getSheets(), UNO_QUERY_THROW);
|
|
uno::Reference< sheet::XSpreadsheet > xSheet( xIndex->getByIndex(0), UNO_QUERY_THROW);
|
|
|
|
// set variables from xdatapilottable.[ch]xx
|
|
xCellForChange = xSheet->getCellByPosition( 1, 5 );
|
|
xCellForCheck = xSheet->getCellByPosition( 7, 11 );
|
|
CPPUNIT_ASSERT(xCellForCheck.is());
|
|
CPPUNIT_ASSERT(xCellForChange.is());
|
|
|
|
CPPUNIT_ASSERT_MESSAGE("Could not create interface of type XSpreadsheet", xSheet.is());
|
|
uno::Reference< sheet::XDataPilotTablesSupplier > xDPTS(xSheet, UNO_QUERY_THROW);
|
|
uno::Reference< sheet::XDataPilotTables > xDPT = xDPTS->getDataPilotTables();
|
|
CPPUNIT_ASSERT(xDPT.is());
|
|
|
|
uno::Reference< sheet::XDataPilotTable > xDPTable(xDPT->getByName(u"DataPilotTable2"_ustr),UNO_QUERY_THROW);
|
|
|
|
return xDPTable;
|
|
}
|
|
|
|
void ScDataPilotTableObj::setUp()
|
|
{
|
|
UnoApiTest::setUp();
|
|
// create a calc document
|
|
loadFromFile(u"ScDataPilotTableObj.ods");
|
|
}
|
|
|
|
CPPUNIT_TEST_SUITE_REGISTRATION(ScDataPilotTableObj);
|
|
|
|
}
|
|
|
|
CPPUNIT_PLUGIN_IMPLEMENT();
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|