summaryrefslogtreecommitdiffstats
path: root/sc/qa/unit/datatransformation_test.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'sc/qa/unit/datatransformation_test.cxx')
-rw-r--r--sc/qa/unit/datatransformation_test.cxx1036
1 files changed, 1036 insertions, 0 deletions
diff --git a/sc/qa/unit/datatransformation_test.cxx b/sc/qa/unit/datatransformation_test.cxx
new file mode 100644
index 000000000..37fc1a0f3
--- /dev/null
+++ b/sc/qa/unit/datatransformation_test.cxx
@@ -0,0 +1,1036 @@
+/* -*- 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 <rtl/ustring.hxx>
+
+#include "helper/qahelper.hxx"
+#include <document.hxx>
+#include <datatransformation.hxx>
+#include <scdll.hxx>
+#include <svl/numformat.hxx>
+#include <tools/time.hxx>
+
+class ScDataTransformationTest : public ScBootstrapFixture
+{
+public:
+
+ ScDataTransformationTest();
+
+ virtual void setUp() override;
+ virtual void tearDown() override;
+
+ void testColumnRemove();
+ void testColumnSplit();
+ void testColumnMerge();
+ void testTextToLower();
+ void testTextToUpper();
+ void testTextCapitalize();
+ void testTextTrim();
+ void testAggregateSum();
+ void testAggregateAverage();
+ void testAggregateMin();
+ void testAggregateMax();
+ void testNumberRound();
+ void testNumberRoundUp();
+ void testNumberRoundDown();
+ void testNumberAbsolute();
+ void testNumberLogE();
+ void testNumberLog10();
+ void testNumberCube();
+ void testNumberSquare();
+ void testNumberSquareRoot();
+ void testNumberEven();
+ void testNumberOdd();
+ void testNumberSign();
+ void testReplaceNull();
+ void testGetDateString();
+ void testGetYear();
+ void testGetStartOfYear();
+ void testGetEndOfYear();
+ void testGetMonth();
+ void testGetMonthName();
+ void testGetStartOfMonth();
+ void testGetEndOfMonth();
+ void testGetDay();
+ void testGetDayOfWeek();
+ void testGetDayOfYear();
+ void testGetQuarter();
+ void testGetStartOfQuarter();
+ void testGetEndOfQuarter();
+ void testGetTime();
+ void testGetHour();
+ void testGetMinute();
+ void testGetSecond();
+
+ CPPUNIT_TEST_SUITE(ScDataTransformationTest);
+ CPPUNIT_TEST(testColumnRemove);
+ CPPUNIT_TEST(testColumnSplit);
+ CPPUNIT_TEST(testColumnMerge);
+ CPPUNIT_TEST(testTextToLower);
+ CPPUNIT_TEST(testTextToUpper);
+ CPPUNIT_TEST(testTextCapitalize);
+ CPPUNIT_TEST(testTextTrim);
+ CPPUNIT_TEST(testAggregateSum);
+ CPPUNIT_TEST(testAggregateAverage);
+ CPPUNIT_TEST(testAggregateMin);
+ CPPUNIT_TEST(testAggregateMax);
+ CPPUNIT_TEST(testNumberRound);
+ CPPUNIT_TEST(testNumberRoundUp);
+ CPPUNIT_TEST(testNumberRoundDown);
+ CPPUNIT_TEST(testNumberAbsolute);
+ CPPUNIT_TEST(testNumberLogE);
+ CPPUNIT_TEST(testNumberLog10);
+ CPPUNIT_TEST(testNumberCube);
+ CPPUNIT_TEST(testNumberSquare);
+ CPPUNIT_TEST(testNumberSquareRoot);
+ CPPUNIT_TEST(testNumberEven);
+ CPPUNIT_TEST(testNumberOdd);
+ CPPUNIT_TEST(testNumberSign);
+ CPPUNIT_TEST(testReplaceNull);
+ CPPUNIT_TEST(testGetDateString);
+ CPPUNIT_TEST(testGetYear);
+ CPPUNIT_TEST(testGetStartOfYear);
+ CPPUNIT_TEST(testGetEndOfYear);
+ CPPUNIT_TEST(testGetMonth);
+ CPPUNIT_TEST(testGetMonthName);
+ CPPUNIT_TEST(testGetStartOfMonth);
+ CPPUNIT_TEST(testGetEndOfMonth);
+ CPPUNIT_TEST(testGetDay);
+ CPPUNIT_TEST(testGetDayOfWeek);
+ CPPUNIT_TEST(testGetDayOfYear);
+ CPPUNIT_TEST(testGetQuarter);
+ CPPUNIT_TEST(testGetStartOfQuarter);
+ CPPUNIT_TEST(testGetEndOfQuarter);
+ CPPUNIT_TEST(testGetTime);
+ CPPUNIT_TEST(testGetHour);
+ CPPUNIT_TEST(testGetMinute);
+ CPPUNIT_TEST(testGetSecond);
+ CPPUNIT_TEST_SUITE_END();
+
+private:
+ ScDocShellRef m_xDocShell;
+ ScDocument *m_pDoc;
+};
+
+void ScDataTransformationTest::testColumnRemove()
+{
+ for (SCROW nRow = 0; nRow < 10; ++nRow)
+ {
+ for (SCCOL nCol = 0; nCol < 10; ++nCol)
+ {
+ m_pDoc->SetValue(nCol, nRow, 0, nRow*nCol);
+ }
+ }
+
+ sc::ColumnRemoveTransformation aTransformation({5});
+ aTransformation.Transform(*m_pDoc);
+
+ for (SCROW nRow = 0; nRow < 10; ++nRow)
+ {
+ for (SCCOL nCol = 0; nCol < 9; ++nCol)
+ {
+ double nVal = m_pDoc->GetValue(nCol, nRow, 0);
+ if (nCol < 5)
+ {
+ ASSERT_DOUBLES_EQUAL(static_cast<double>(nCol)*nRow, nVal);
+ }
+ else
+ {
+ ASSERT_DOUBLES_EQUAL(static_cast<double>(nCol+1)*nRow, nVal);
+ }
+ }
+ }
+}
+
+void ScDataTransformationTest::testColumnSplit()
+{
+ m_pDoc->SetString(2, 0, 0, "Test1,Test2");
+ m_pDoc->SetString(2, 1, 0, "Test1,");
+ m_pDoc->SetString(2, 2, 0, ",Test1");
+ m_pDoc->SetString(2, 3, 0, "Test1,Test2,Test3");
+ m_pDoc->SetString(3, 0, 0, "AnotherString");
+
+ sc::SplitColumnTransformation aTransform(2, ',');
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_EQUAL(OUString("AnotherString"), m_pDoc->GetString(4, 0, 0));
+
+ CPPUNIT_ASSERT_EQUAL(OUString("Test1"), m_pDoc->GetString(2, 0, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("Test1"), m_pDoc->GetString(2, 1, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString(""), m_pDoc->GetString(2, 2, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("Test1"), m_pDoc->GetString(2, 3, 0));
+
+ CPPUNIT_ASSERT_EQUAL(OUString("Test2"), m_pDoc->GetString(3, 0, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString(""), m_pDoc->GetString(3, 1, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("Test1"), m_pDoc->GetString(3, 2, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("Test2,Test3"), m_pDoc->GetString(3, 3, 0));
+}
+
+void ScDataTransformationTest::testColumnMerge()
+{
+ m_pDoc->SetString(2, 0, 0, "Berlin");
+ m_pDoc->SetString(2, 1, 0, "Brussels");
+ m_pDoc->SetString(2, 2, 0, "Paris");
+ m_pDoc->SetString(2, 3, 0, "Peking");
+
+ m_pDoc->SetString(4, 0, 0, "Germany");
+ m_pDoc->SetString(4, 1, 0, "Belgium");
+ m_pDoc->SetString(4, 2, 0, "France");
+ m_pDoc->SetString(4, 3, 0, "China");
+
+ sc::MergeColumnTransformation aTransform({2, 4}, ", ");
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_EQUAL(OUString("Berlin, Germany"), m_pDoc->GetString(2, 0, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("Brussels, Belgium"), m_pDoc->GetString(2, 1, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("Paris, France"), m_pDoc->GetString(2, 2, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("Peking, China"), m_pDoc->GetString(2, 3, 0));
+
+ for (SCROW nRow = 0; nRow <= 3; ++nRow)
+ {
+ CPPUNIT_ASSERT(m_pDoc->GetString(4, nRow, 0).isEmpty());
+ }
+}
+
+void ScDataTransformationTest::testTextToLower()
+{
+ m_pDoc->SetString(2, 0, 0, "Berlin");
+ m_pDoc->SetString(2, 1, 0, "Brussels");
+ m_pDoc->SetString(2, 2, 0, "Paris");
+ m_pDoc->SetString(2, 3, 0, "Peking");
+
+ sc::TextTransformation aTransform({2}, sc::TEXT_TRANSFORM_TYPE::TO_LOWER);
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_EQUAL(OUString("berlin"), m_pDoc->GetString(2, 0, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("brussels"), m_pDoc->GetString(2, 1, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("paris"), m_pDoc->GetString(2, 2, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("peking"), m_pDoc->GetString(2, 3, 0));
+}
+
+void ScDataTransformationTest::testTextToUpper()
+{
+ m_pDoc->SetString(2, 0, 0, "Berlin");
+ m_pDoc->SetString(2, 1, 0, "Brussels");
+ m_pDoc->SetString(2, 2, 0, "Paris");
+ m_pDoc->SetString(2, 3, 0, "Peking");
+
+ sc::TextTransformation aTransform({2}, sc::TEXT_TRANSFORM_TYPE::TO_UPPER);
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_EQUAL(OUString("BERLIN"), m_pDoc->GetString(2, 0, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("BRUSSELS"), m_pDoc->GetString(2, 1, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("PARIS"), m_pDoc->GetString(2, 2, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("PEKING"), m_pDoc->GetString(2, 3, 0));
+}
+
+void ScDataTransformationTest::testTextCapitalize()
+{
+ m_pDoc->SetString(2, 0, 0, "hello woRlD");
+ m_pDoc->SetString(2, 1, 0, "qUe vA");
+ m_pDoc->SetString(2, 2, 0, "si tu la ves");
+ m_pDoc->SetString(2, 3, 0, "cUaNdO mE EnAmOro");
+
+ sc::TextTransformation aTransform({2}, sc::TEXT_TRANSFORM_TYPE::CAPITALIZE);
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_EQUAL(OUString("Hello World"), m_pDoc->GetString(2, 0, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("Que Va"), m_pDoc->GetString(2, 1, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("Si Tu La Ves"), m_pDoc->GetString(2, 2, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("Cuando Me Enamoro"), m_pDoc->GetString(2, 3, 0));
+}
+
+void ScDataTransformationTest::testTextTrim()
+{
+ m_pDoc->SetString(2, 0, 0, " Berlin");
+ m_pDoc->SetString(2, 1, 0, "Brussels ");
+ m_pDoc->SetString(2, 2, 0, " Paris ");
+
+ sc::TextTransformation aTransform({2}, sc::TEXT_TRANSFORM_TYPE::TRIM);
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_EQUAL(OUString("Berlin"), m_pDoc->GetString(2, 0, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("Brussels"), m_pDoc->GetString(2, 1, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("Paris"), m_pDoc->GetString(2, 2, 0));
+}
+
+void ScDataTransformationTest::testAggregateSum()
+{
+ m_pDoc->SetValue(2, 0, 0, 2034);
+ m_pDoc->SetValue(2, 1, 0, 2342);
+ m_pDoc->SetValue(2, 2, 0, 57452);
+
+ m_pDoc->SetValue(4, 0, 0, 4829.98);
+ m_pDoc->SetValue(4, 1, 0, 53781.3);
+ m_pDoc->SetValue(4, 2, 0, 9876.4);
+ m_pDoc->SetValue(4, 3, 0, 0);
+
+ sc::AggregateFunction aTransform({2, 4}, sc::AGGREGATE_FUNCTION::SUM);
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(61828, m_pDoc->GetValue(2, 4, 0), 1e-10);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(68487.68, m_pDoc->GetValue(4, 4, 0), 1e-10);
+}
+
+void ScDataTransformationTest::testAggregateAverage()
+{
+ m_pDoc->SetValue(2, 0, 0, 2034);
+ m_pDoc->SetValue(2, 1, 0, 2342);
+ m_pDoc->SetValue(2, 2, 0, 57453);
+
+ m_pDoc->SetValue(3, 0, 0, 4);
+ m_pDoc->SetValue(3, 1, 0, 4);
+ m_pDoc->SetValue(3, 2, 0, 4);
+
+ sc::AggregateFunction aTransform({2, 3}, sc::AGGREGATE_FUNCTION::AVERAGE);
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(20609.6666666667, m_pDoc->GetValue(2, 3, 0), 1e-10);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(4, m_pDoc->GetValue(3, 3, 0), 1e-10);
+}
+
+void ScDataTransformationTest::testAggregateMin()
+{
+ m_pDoc->SetValue(2, 0, 0, 2034);
+ m_pDoc->SetValue(2, 1, 0, 2342);
+ m_pDoc->SetValue(2, 2, 0, 57453);
+
+ m_pDoc->SetValue(3, 0, 0, 2034);
+ m_pDoc->SetValue(3, 1, 0, -2342);
+ m_pDoc->SetValue(3, 2, 0, 57453);
+
+ sc::AggregateFunction aTransform({2, 3}, sc::AGGREGATE_FUNCTION::MIN);
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(2034, m_pDoc->GetValue(2, 3, 0), 1e-10);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(-2342, m_pDoc->GetValue(3, 3, 0), 1e-10);
+}
+
+void ScDataTransformationTest::testAggregateMax()
+{
+ m_pDoc->SetValue(2, 0, 0, 2034);
+ m_pDoc->SetValue(2, 1, 0, 2342);
+ m_pDoc->SetValue(2, 2, 0, 57453);
+ m_pDoc->SetValue(2, 3, 0, -453);
+
+ m_pDoc->SetValue(3, 0, 0, 2034);
+ m_pDoc->SetValue(3, 1, 0, -2342);
+ m_pDoc->SetValue(3, 2, 0, -57453);
+ m_pDoc->SetValue(3, 3, 0, -453);
+
+ sc::AggregateFunction aTransform({2, 3}, sc::AGGREGATE_FUNCTION::MAX);
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(57453, m_pDoc->GetValue(2, 4, 0), 1e-10);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(2034, m_pDoc->GetValue(3, 4, 0), 1e-10);
+}
+
+void ScDataTransformationTest::testNumberRound()
+{
+ m_pDoc->SetValue(2, 0, 0, 2034.342453456);
+ m_pDoc->SetValue(2, 1, 0, 2342.252678567542);
+ m_pDoc->SetValue(2, 2, 0, 57453.651345687654345676);
+ m_pDoc->SetValue(2, 3, 0, -453.22234567543);
+
+ sc::NumberTransformation aTransform({2}, sc::NUMBER_TRANSFORM_TYPE::ROUND, 4);
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_EQUAL(2034.3425, m_pDoc->GetValue(2, 0, 0));
+ CPPUNIT_ASSERT_EQUAL(2342.2527, m_pDoc->GetValue(2, 1, 0));
+ CPPUNIT_ASSERT_EQUAL(57453.6513, m_pDoc->GetValue(2, 2, 0));
+ CPPUNIT_ASSERT_EQUAL(-453.2223, m_pDoc->GetValue(2, 3, 0));
+}
+
+void ScDataTransformationTest::testNumberRoundUp()
+{
+ m_pDoc->SetValue(2, 0, 0, 2034.34);
+ m_pDoc->SetValue(2, 1, 0, 2342.22);
+ m_pDoc->SetValue(2, 2, 0, 57453.65);
+ m_pDoc->SetValue(2, 3, 0, -453.22);
+
+ sc::NumberTransformation aTransform({2}, sc::NUMBER_TRANSFORM_TYPE::ROUND_UP);
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_EQUAL(2035.0, m_pDoc->GetValue(2, 0, 0));
+ CPPUNIT_ASSERT_EQUAL(2343.0, m_pDoc->GetValue(2, 1, 0));
+ CPPUNIT_ASSERT_EQUAL(57454.0, m_pDoc->GetValue(2, 2, 0));
+ CPPUNIT_ASSERT_EQUAL(-453.0, m_pDoc->GetValue(2, 3, 0));
+}
+
+void ScDataTransformationTest::testNumberRoundDown()
+{
+ m_pDoc->SetValue(2, 0, 0, 2034.34);
+ m_pDoc->SetValue(2, 1, 0, 2342.22);
+ m_pDoc->SetValue(2, 2, 0, 57453.65);
+ m_pDoc->SetValue(2, 3, 0, -453.22);
+
+ sc::NumberTransformation aTransform({2}, sc::NUMBER_TRANSFORM_TYPE::ROUND_DOWN);
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_EQUAL(2034.0, m_pDoc->GetValue(2, 0, 0));
+ CPPUNIT_ASSERT_EQUAL(2342.0, m_pDoc->GetValue(2, 1, 0));
+ CPPUNIT_ASSERT_EQUAL(57453.0, m_pDoc->GetValue(2, 2, 0));
+ CPPUNIT_ASSERT_EQUAL(-454.0, m_pDoc->GetValue(2, 3, 0));
+}
+
+void ScDataTransformationTest::testNumberAbsolute()
+{
+ m_pDoc->SetValue(2, 0, 0, 2034.34);
+ m_pDoc->SetValue(2, 1, 0, -2342.22);
+ m_pDoc->SetValue(2, 2, 0, 57453.65);
+ m_pDoc->SetValue(2, 3, 0, -453.22);
+
+ sc::NumberTransformation aTransform({2}, sc::NUMBER_TRANSFORM_TYPE::ABSOLUTE);
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_EQUAL(2034.34, m_pDoc->GetValue(2, 0, 0));
+ CPPUNIT_ASSERT_EQUAL(2342.22, m_pDoc->GetValue(2, 1, 0));
+ CPPUNIT_ASSERT_EQUAL(57453.65, m_pDoc->GetValue(2, 2, 0));
+ CPPUNIT_ASSERT_EQUAL(453.22, m_pDoc->GetValue(2, 3, 0));
+}
+
+void ScDataTransformationTest::testNumberLogE()
+{
+ m_pDoc->SetValue(2, 0, 0, 1);
+ m_pDoc->SetValue(2, 1, 0, 5);
+ m_pDoc->SetValue(2, 2, 0, -9);
+ m_pDoc->SetValue(2, 3, 0, 500);
+
+ sc::NumberTransformation aTransform({2}, sc::NUMBER_TRANSFORM_TYPE::LOG_E);
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(0, m_pDoc->GetValue(2, 0, 0), 1e-10);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(1.60943791243, m_pDoc->GetValue(2, 1, 0), 1e-10);
+ CPPUNIT_ASSERT_EQUAL(OUString(""), m_pDoc->GetString(2, 2, 0));
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(6.21460809842, m_pDoc->GetValue(2, 3, 0), 1e-10);
+}
+
+void ScDataTransformationTest::testNumberLog10()
+{
+ m_pDoc->SetValue(2, 0, 0, 1);
+ m_pDoc->SetValue(2, 1, 0, 10);
+ m_pDoc->SetValue(2, 2, 0, -9);
+ m_pDoc->SetValue(2, 3, 0, 500);
+
+ sc::NumberTransformation aTransform({2}, sc::NUMBER_TRANSFORM_TYPE::LOG_10);
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(0, m_pDoc->GetValue(2, 0, 0), 1e-10);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(1.0, m_pDoc->GetValue(2, 1, 0), 1e-10);
+ CPPUNIT_ASSERT_EQUAL(OUString(), m_pDoc->GetString(2, 2, 0));
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(2.69897000434, m_pDoc->GetValue(2, 3, 0), 1e-10);
+}
+
+void ScDataTransformationTest::testNumberCube()
+{
+ m_pDoc->SetValue(2, 0, 0, 2);
+ m_pDoc->SetValue(2, 1, 0, -2);
+ m_pDoc->SetValue(2, 2, 0, 8);
+ m_pDoc->SetValue(2, 3, 0, -8);
+
+ sc::NumberTransformation aTransform({2}, sc::NUMBER_TRANSFORM_TYPE::CUBE);
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_EQUAL(8.0, m_pDoc->GetValue(2, 0, 0));
+ CPPUNIT_ASSERT_EQUAL(-8.0, m_pDoc->GetValue(2, 1, 0));
+ CPPUNIT_ASSERT_EQUAL(512.0, m_pDoc->GetValue(2, 2, 0));
+ CPPUNIT_ASSERT_EQUAL(-512.0, m_pDoc->GetValue(2, 3, 0));
+}
+
+void ScDataTransformationTest::testNumberSquare()
+{
+ m_pDoc->SetValue(2, 0, 0, 2);
+ m_pDoc->SetValue(2, 1, 0, -2);
+ m_pDoc->SetValue(2, 2, 0, 8);
+ m_pDoc->SetValue(2, 3, 0, -8);
+
+ sc::NumberTransformation aTransform({2}, sc::NUMBER_TRANSFORM_TYPE::SQUARE);
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_EQUAL(4.0, m_pDoc->GetValue(2, 0, 0));
+ CPPUNIT_ASSERT_EQUAL(4.0, m_pDoc->GetValue(2, 1, 0));
+ CPPUNIT_ASSERT_EQUAL(64.0, m_pDoc->GetValue(2, 2, 0));
+ CPPUNIT_ASSERT_EQUAL(64.0, m_pDoc->GetValue(2, 3, 0));
+}
+
+void ScDataTransformationTest::testNumberSquareRoot()
+{
+ m_pDoc->SetValue(2, 0, 0, 8);
+ m_pDoc->SetValue(2, 1, 0, 4);
+ m_pDoc->SetValue(2, 2, 0, 9);
+
+ sc::NumberTransformation aTransform({2}, sc::NUMBER_TRANSFORM_TYPE::SQUARE_ROOT);
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(2.82842712475, m_pDoc->GetValue(2, 0, 0), 1e-10);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(2.0, m_pDoc->GetValue(2, 1, 0), 1e-10);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(3.0, m_pDoc->GetValue(2, 2, 0), 1e-10);
+}
+
+void ScDataTransformationTest::testNumberEven()
+{
+ m_pDoc->SetValue(2, 0, 0, 2034);
+ m_pDoc->SetValue(2, 1, 0, 2343);
+ m_pDoc->SetValue(2, 2, 0, 57453.65);
+ m_pDoc->SetValue(2, 3, 0, -453);
+
+ sc::NumberTransformation aTransform({2}, sc::NUMBER_TRANSFORM_TYPE::IS_EVEN);
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_EQUAL(1.0, m_pDoc->GetValue(2, 0, 0));
+ CPPUNIT_ASSERT_EQUAL(0.0, m_pDoc->GetValue(2, 1, 0));
+ CPPUNIT_ASSERT_EQUAL(0.0, m_pDoc->GetValue(2, 2, 0));
+ CPPUNIT_ASSERT_EQUAL(0.0, m_pDoc->GetValue(2, 3, 0));
+}
+
+void ScDataTransformationTest::testNumberOdd()
+{
+ m_pDoc->SetValue(2, 0, 0, 2034);
+ m_pDoc->SetValue(2, 1, 0, 2343);
+ m_pDoc->SetValue(2, 2, 0, 57453.65);
+ m_pDoc->SetValue(2, 3, 0, -453);
+
+ sc::NumberTransformation aTransform({2}, sc::NUMBER_TRANSFORM_TYPE::IS_ODD);
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_EQUAL(0.0, m_pDoc->GetValue(2, 0, 0));
+ CPPUNIT_ASSERT_EQUAL(1.0, m_pDoc->GetValue(2, 1, 0));
+ CPPUNIT_ASSERT_EQUAL(0.0, m_pDoc->GetValue(2, 2, 0));
+ CPPUNIT_ASSERT_EQUAL(1.0, m_pDoc->GetValue(2, 3, 0));
+}
+
+void ScDataTransformationTest::testNumberSign()
+{
+ m_pDoc->SetValue(2, 0, 0, 2034.34);
+ m_pDoc->SetValue(2, 1, 0, -2342.22);
+ m_pDoc->SetValue(2, 2, 0, 0);
+ m_pDoc->SetValue(2, 3, 0, -453.22);
+
+ sc::NumberTransformation aTransform({2}, sc::NUMBER_TRANSFORM_TYPE::SIGN);
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_EQUAL(1.0, m_pDoc->GetValue(2, 0, 0));
+ CPPUNIT_ASSERT_EQUAL(-1.0, m_pDoc->GetValue(2, 1, 0));
+ CPPUNIT_ASSERT_EQUAL(0.0, m_pDoc->GetValue(2, 2, 0));
+ CPPUNIT_ASSERT_EQUAL(-1.0, m_pDoc->GetValue(2, 3, 0));
+}
+
+void ScDataTransformationTest::testReplaceNull()
+{
+ m_pDoc->SetString(2, 0, 0, "Berlin");
+ m_pDoc->SetString(2, 1, 0, "");
+ m_pDoc->SetString(2, 2, 0, "");
+ m_pDoc->SetString(2, 3, 0, "Peking");
+
+ sc::ReplaceNullTransformation aTransform({2}, "Empty");
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_EQUAL(OUString("Berlin"), m_pDoc->GetString(2, 0, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("Empty"), m_pDoc->GetString(2, 1, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("Empty"), m_pDoc->GetString(2, 2, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("Peking"), m_pDoc->GetString(2, 3, 0));
+
+}
+
+void ScDataTransformationTest::testGetDateString()
+{
+ SvNumberFormatter* pFormatter = m_pDoc->GetFormatTable();
+ css::util::Date aDate1(25,1,2011);
+ css::util::Date aDate2(12,10,1994);
+ css::util::Date aDate3(23,9,1996);
+ css::util::Date aDate4(15,8,1947);
+
+ double nDate1 = static_cast<double>(aDate1 - pFormatter->GetNullDate());
+ double nDate2 = static_cast<double>(aDate2 - pFormatter->GetNullDate());
+ double nDate3 = static_cast<double>(aDate3 - pFormatter->GetNullDate());
+ double nDate4 = static_cast<double>(aDate4 - pFormatter->GetNullDate());
+
+ m_pDoc->SetValue(2, 0, 0, nDate1);
+ m_pDoc->SetValue(2, 1, 0, nDate2);
+ m_pDoc->SetValue(2, 2, 0, nDate3);
+ m_pDoc->SetValue(2, 3, 0, nDate4);
+
+ sc:: DateTimeTransformation aTransform({2}, sc::DATETIME_TRANSFORMATION_TYPE::DATE_STRING );
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_EQUAL(OUString("01/25/11"), m_pDoc->GetString(2, 0, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("10/12/94"), m_pDoc->GetString(2, 1, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("09/23/96"), m_pDoc->GetString(2, 2, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("08/15/47"), m_pDoc->GetString(2, 3, 0));
+}
+
+void ScDataTransformationTest::testGetYear()
+{
+ SvNumberFormatter* pFormatter = m_pDoc->GetFormatTable();
+ css::util::Date aDate1(25,1,2011);
+ css::util::Date aDate2(12,10,1994);
+ css::util::Date aDate3(23,9,1996);
+ css::util::Date aDate4(15,8,1947);
+
+ double nDate1 = static_cast<double>(aDate1 - pFormatter->GetNullDate());
+ double nDate2 = static_cast<double>(aDate2 - pFormatter->GetNullDate());
+ double nDate3 = static_cast<double>(aDate3 - pFormatter->GetNullDate());
+ double nDate4 = static_cast<double>(aDate4 - pFormatter->GetNullDate());
+
+ m_pDoc->SetValue(2, 0, 0, nDate1);
+ m_pDoc->SetValue(2, 1, 0, nDate2);
+ m_pDoc->SetValue(2, 2, 0, nDate3);
+ m_pDoc->SetValue(2, 3, 0, nDate4);
+
+ sc:: DateTimeTransformation aTransform({2}, sc::DATETIME_TRANSFORMATION_TYPE::YEAR );
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(2011, m_pDoc->GetValue(2, 0, 0), 0);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(1994, m_pDoc->GetValue(2, 1, 0), 0);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(1996, m_pDoc->GetValue(2, 2, 0), 0);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(1947, m_pDoc->GetValue(2, 3, 0), 0);
+}
+
+void ScDataTransformationTest::testGetStartOfYear()
+{
+ SvNumberFormatter* pFormatter = m_pDoc->GetFormatTable();
+ css::util::Date aDate1(25,1,2011);
+ css::util::Date aDate2(12,10,1994);
+ css::util::Date aDate3(23,9,1996);
+ css::util::Date aDate4(15,8,1947);
+
+ double nDate1 = static_cast<double>(aDate1 - pFormatter->GetNullDate());
+ double nDate2 = static_cast<double>(aDate2 - pFormatter->GetNullDate());
+ double nDate3 = static_cast<double>(aDate3 - pFormatter->GetNullDate());
+ double nDate4 = static_cast<double>(aDate4 - pFormatter->GetNullDate());
+
+ m_pDoc->SetValue(2, 0, 0, nDate1);
+ m_pDoc->SetValue(2, 1, 0, nDate2);
+ m_pDoc->SetValue(2, 2, 0, nDate3);
+ m_pDoc->SetValue(2, 3, 0, nDate4);
+
+ sc:: DateTimeTransformation aTransform({2}, sc::DATETIME_TRANSFORMATION_TYPE::START_OF_YEAR );
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_EQUAL(OUString("01/01/11"), m_pDoc->GetString(2, 0, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("01/01/94"), m_pDoc->GetString(2, 1, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("01/01/96"), m_pDoc->GetString(2, 2, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("01/01/47"), m_pDoc->GetString(2, 3, 0));
+}
+
+void ScDataTransformationTest::testGetEndOfYear()
+{
+ SvNumberFormatter* pFormatter = m_pDoc->GetFormatTable();
+ css::util::Date aDate1(25,1,2011);
+ css::util::Date aDate2(12,10,1994);
+ css::util::Date aDate3(23,9,1996);
+ css::util::Date aDate4(15,8,1947);
+
+ double nDate1 = static_cast<double>(aDate1 - pFormatter->GetNullDate());
+ double nDate2 = static_cast<double>(aDate2 - pFormatter->GetNullDate());
+ double nDate3 = static_cast<double>(aDate3 - pFormatter->GetNullDate());
+ double nDate4 = static_cast<double>(aDate4 - pFormatter->GetNullDate());
+
+ m_pDoc->SetValue(2, 0, 0, nDate1);
+ m_pDoc->SetValue(2, 1, 0, nDate2);
+ m_pDoc->SetValue(2, 2, 0, nDate3);
+ m_pDoc->SetValue(2, 3, 0, nDate4);
+
+ sc:: DateTimeTransformation aTransform({2}, sc::DATETIME_TRANSFORMATION_TYPE::END_OF_YEAR );
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_EQUAL(OUString("12/31/11"), m_pDoc->GetString(2, 0, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("12/31/94"), m_pDoc->GetString(2, 1, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("12/31/96"), m_pDoc->GetString(2, 2, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("12/31/47"), m_pDoc->GetString(2, 3, 0));
+}
+
+void ScDataTransformationTest::testGetMonth()
+{
+ SvNumberFormatter* pFormatter = m_pDoc->GetFormatTable();
+ css::util::Date aDate1(25,1,2011);
+ css::util::Date aDate2(12,10,1994);
+ css::util::Date aDate3(23,9,1996);
+ css::util::Date aDate4(15,8,1947);
+
+ double nDate1 = static_cast<double>(aDate1 - pFormatter->GetNullDate());
+ double nDate2 = static_cast<double>(aDate2 - pFormatter->GetNullDate());
+ double nDate3 = static_cast<double>(aDate3 - pFormatter->GetNullDate());
+ double nDate4 = static_cast<double>(aDate4 - pFormatter->GetNullDate());
+
+ m_pDoc->SetValue(2, 0, 0, nDate1);
+ m_pDoc->SetValue(2, 1, 0, nDate2);
+ m_pDoc->SetValue(2, 2, 0, nDate3);
+ m_pDoc->SetValue(2, 3, 0, nDate4);
+
+ sc:: DateTimeTransformation aTransform({2}, sc::DATETIME_TRANSFORMATION_TYPE::MONTH );
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(1, m_pDoc->GetValue(2, 0, 0), 0);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(10, m_pDoc->GetValue(2, 1, 0), 0);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(9, m_pDoc->GetValue(2, 2, 0), 0);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(8, m_pDoc->GetValue(2, 3, 0), 0);
+}
+
+void ScDataTransformationTest::testGetMonthName()
+{
+ SvNumberFormatter* pFormatter = m_pDoc->GetFormatTable();
+ css::util::Date aDate1(25,1,2011);
+ css::util::Date aDate2(12,10,1994);
+ css::util::Date aDate3(23,9,1996);
+ css::util::Date aDate4(15,8,1947);
+
+ double nDate1 = static_cast<double>(aDate1 - pFormatter->GetNullDate());
+ double nDate2 = static_cast<double>(aDate2 - pFormatter->GetNullDate());
+ double nDate3 = static_cast<double>(aDate3 - pFormatter->GetNullDate());
+ double nDate4 = static_cast<double>(aDate4 - pFormatter->GetNullDate());
+
+ m_pDoc->SetValue(2, 0, 0, nDate1);
+ m_pDoc->SetValue(2, 1, 0, nDate2);
+ m_pDoc->SetValue(2, 2, 0, nDate3);
+ m_pDoc->SetValue(2, 3, 0, nDate4);
+
+ sc:: DateTimeTransformation aTransform({2}, sc::DATETIME_TRANSFORMATION_TYPE::MONTH_NAME);
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_EQUAL(OUString("January"), m_pDoc->GetString(2, 0, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("October"), m_pDoc->GetString(2, 1, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("September"), m_pDoc->GetString(2, 2, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("August"), m_pDoc->GetString(2, 3, 0));
+}
+
+void ScDataTransformationTest::testGetStartOfMonth()
+{
+ SvNumberFormatter* pFormatter = m_pDoc->GetFormatTable();
+ css::util::Date aDate1(25,1,2011);
+ css::util::Date aDate2(12,10,1994);
+ css::util::Date aDate3(23,9,1996);
+ css::util::Date aDate4(15,8,1947);
+
+ double nDate1 = static_cast<double>(aDate1 - pFormatter->GetNullDate());
+ double nDate2 = static_cast<double>(aDate2 - pFormatter->GetNullDate());
+ double nDate3 = static_cast<double>(aDate3 - pFormatter->GetNullDate());
+ double nDate4 = static_cast<double>(aDate4 - pFormatter->GetNullDate());
+
+ m_pDoc->SetValue(2, 0, 0, nDate1);
+ m_pDoc->SetValue(2, 1, 0, nDate2);
+ m_pDoc->SetValue(2, 2, 0, nDate3);
+ m_pDoc->SetValue(2, 3, 0, nDate4);
+
+ sc:: DateTimeTransformation aTransform({2}, sc::DATETIME_TRANSFORMATION_TYPE::START_OF_MONTH );
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_EQUAL(OUString("01/01/11"), m_pDoc->GetString(2, 0, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("10/01/94"), m_pDoc->GetString(2, 1, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("09/01/96"), m_pDoc->GetString(2, 2, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("08/01/47"), m_pDoc->GetString(2, 3, 0));
+}
+
+void ScDataTransformationTest::testGetEndOfMonth()
+{
+ SvNumberFormatter* pFormatter = m_pDoc->GetFormatTable();
+ css::util::Date aDate1(25,1,2011);
+ css::util::Date aDate2(12,10,1994);
+ css::util::Date aDate3(23,9,1996);
+ css::util::Date aDate4(15,8,1947);
+
+ double nDate1 = static_cast<double>(aDate1 - pFormatter->GetNullDate());
+ double nDate2 = static_cast<double>(aDate2 - pFormatter->GetNullDate());
+ double nDate3 = static_cast<double>(aDate3 - pFormatter->GetNullDate());
+ double nDate4 = static_cast<double>(aDate4 - pFormatter->GetNullDate());
+
+ m_pDoc->SetValue(2, 0, 0, nDate1);
+ m_pDoc->SetValue(2, 1, 0, nDate2);
+ m_pDoc->SetValue(2, 2, 0, nDate3);
+ m_pDoc->SetValue(2, 3, 0, nDate4);
+
+ sc:: DateTimeTransformation aTransform({2}, sc::DATETIME_TRANSFORMATION_TYPE::END_OF_MONTH );
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_EQUAL(OUString("01/31/11"), m_pDoc->GetString(2, 0, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("10/31/94"), m_pDoc->GetString(2, 1, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("09/30/96"), m_pDoc->GetString(2, 2, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("08/31/47"), m_pDoc->GetString(2, 3, 0));
+}
+
+void ScDataTransformationTest::testGetDay()
+{
+ SvNumberFormatter* pFormatter = m_pDoc->GetFormatTable();
+ css::util::Date aDate1(25,1,2011);
+ css::util::Date aDate2(12,10,1994);
+ css::util::Date aDate3(23,9,1996);
+ css::util::Date aDate4(15,8,1947);
+
+ double nDate1 = static_cast<double>(aDate1 - pFormatter->GetNullDate());
+ double nDate2 = static_cast<double>(aDate2 - pFormatter->GetNullDate());
+ double nDate3 = static_cast<double>(aDate3 - pFormatter->GetNullDate());
+ double nDate4 = static_cast<double>(aDate4 - pFormatter->GetNullDate());
+
+ m_pDoc->SetValue(2, 0, 0, nDate1);
+ m_pDoc->SetValue(2, 1, 0, nDate2);
+ m_pDoc->SetValue(2, 2, 0, nDate3);
+ m_pDoc->SetValue(2, 3, 0, nDate4);
+
+ sc:: DateTimeTransformation aTransform({2}, sc::DATETIME_TRANSFORMATION_TYPE::DAY );
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(25, m_pDoc->GetValue(2, 0, 0), 0);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(12, m_pDoc->GetValue(2, 1, 0), 0);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(23, m_pDoc->GetValue(2, 2, 0), 0);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(15, m_pDoc->GetValue(2, 3, 0), 0);
+}
+
+void ScDataTransformationTest::testGetDayOfWeek()
+{
+ SvNumberFormatter* pFormatter = m_pDoc->GetFormatTable();
+ css::util::Date aDate1(25,1,2011);
+ css::util::Date aDate2(12,10,1994);
+ css::util::Date aDate3(23,9,1996);
+ css::util::Date aDate4(15,8,1947);
+
+ double nDate1 = static_cast<double>(aDate1 - pFormatter->GetNullDate());
+ double nDate2 = static_cast<double>(aDate2 - pFormatter->GetNullDate());
+ double nDate3 = static_cast<double>(aDate3 - pFormatter->GetNullDate());
+ double nDate4 = static_cast<double>(aDate4 - pFormatter->GetNullDate());
+
+ m_pDoc->SetValue(2, 0, 0, nDate1);
+ m_pDoc->SetValue(2, 1, 0, nDate2);
+ m_pDoc->SetValue(2, 2, 0, nDate3);
+ m_pDoc->SetValue(2, 3, 0, nDate4);
+
+ sc:: DateTimeTransformation aTransform({2}, sc::DATETIME_TRANSFORMATION_TYPE::DAY_OF_WEEK );
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(1, m_pDoc->GetValue(2, 0, 0), 0);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(2, m_pDoc->GetValue(2, 1, 0), 0);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(0, m_pDoc->GetValue(2, 2, 0), 0);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(4, m_pDoc->GetValue(2, 3, 0), 0);
+}
+
+void ScDataTransformationTest::testGetDayOfYear()
+{
+ SvNumberFormatter* pFormatter = m_pDoc->GetFormatTable();
+ css::util::Date aDate1(25,1,2011);
+ css::util::Date aDate2(12,10,1994);
+ css::util::Date aDate3(23,9,1996);
+ css::util::Date aDate4(15,8,1947);
+
+ double nDate1 = static_cast<double>(aDate1 - pFormatter->GetNullDate());
+ double nDate2 = static_cast<double>(aDate2 - pFormatter->GetNullDate());
+ double nDate3 = static_cast<double>(aDate3 - pFormatter->GetNullDate());
+ double nDate4 = static_cast<double>(aDate4 - pFormatter->GetNullDate());
+
+ m_pDoc->SetValue(2, 0, 0, nDate1);
+ m_pDoc->SetValue(2, 1, 0, nDate2);
+ m_pDoc->SetValue(2, 2, 0, nDate3);
+ m_pDoc->SetValue(2, 3, 0, nDate4);
+
+ sc:: DateTimeTransformation aTransform({2}, sc::DATETIME_TRANSFORMATION_TYPE::DAY_OF_YEAR );
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(25, m_pDoc->GetValue(2, 0, 0), 0);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(285, m_pDoc->GetValue(2, 1, 0), 0);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(267, m_pDoc->GetValue(2, 2, 0), 0);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(227, m_pDoc->GetValue(2, 3, 0), 0);
+}
+
+void ScDataTransformationTest::testGetQuarter()
+{
+ SvNumberFormatter* pFormatter = m_pDoc->GetFormatTable();
+ css::util::Date aDate1(25,1,2011);
+ css::util::Date aDate2(12,10,1994);
+ css::util::Date aDate3(23,9,1996);
+ css::util::Date aDate4(15,8,1947);
+
+ double nDate1 = static_cast<double>(aDate1 - pFormatter->GetNullDate());
+ double nDate2 = static_cast<double>(aDate2 - pFormatter->GetNullDate());
+ double nDate3 = static_cast<double>(aDate3 - pFormatter->GetNullDate());
+ double nDate4 = static_cast<double>(aDate4 - pFormatter->GetNullDate());
+
+ m_pDoc->SetValue(2, 0, 0, nDate1);
+ m_pDoc->SetValue(2, 1, 0, nDate2);
+ m_pDoc->SetValue(2, 2, 0, nDate3);
+ m_pDoc->SetValue(2, 3, 0, nDate4);
+
+ sc:: DateTimeTransformation aTransform({2}, sc::DATETIME_TRANSFORMATION_TYPE::QUARTER );
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(1, m_pDoc->GetValue(2, 0, 0), 0);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(4, m_pDoc->GetValue(2, 1, 0), 0);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(3, m_pDoc->GetValue(2, 2, 0), 0);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(3, m_pDoc->GetValue(2, 3, 0), 0);
+}
+
+void ScDataTransformationTest::testGetStartOfQuarter()
+{
+ SvNumberFormatter* pFormatter = m_pDoc->GetFormatTable();
+ css::util::Date aDate1(25,1,2011);
+ css::util::Date aDate2(12,10,1994);
+ css::util::Date aDate3(23,9,1996);
+ css::util::Date aDate4(15,8,1947);
+
+ double nDate1 = static_cast<double>(aDate1 - pFormatter->GetNullDate());
+ double nDate2 = static_cast<double>(aDate2 - pFormatter->GetNullDate());
+ double nDate3 = static_cast<double>(aDate3 - pFormatter->GetNullDate());
+ double nDate4 = static_cast<double>(aDate4 - pFormatter->GetNullDate());
+
+ m_pDoc->SetValue(2, 0, 0, nDate1);
+ m_pDoc->SetValue(2, 1, 0, nDate2);
+ m_pDoc->SetValue(2, 2, 0, nDate3);
+ m_pDoc->SetValue(2, 3, 0, nDate4);
+
+ sc:: DateTimeTransformation aTransform({2}, sc::DATETIME_TRANSFORMATION_TYPE::START_OF_QUARTER );
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_EQUAL(OUString("01/01/11"), m_pDoc->GetString(2, 0, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("10/01/94"), m_pDoc->GetString(2, 1, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("07/01/96"), m_pDoc->GetString(2, 2, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("07/01/47"), m_pDoc->GetString(2, 3, 0));
+}
+
+void ScDataTransformationTest::testGetEndOfQuarter()
+{
+ SvNumberFormatter* pFormatter = m_pDoc->GetFormatTable();
+ css::util::Date aDate1(25,1,2011);
+ css::util::Date aDate2(12,10,1994);
+ css::util::Date aDate3(23,9,1996);
+ css::util::Date aDate4(15,8,1947);
+
+ double nDate1 = static_cast<double>(aDate1 - pFormatter->GetNullDate());
+ double nDate2 = static_cast<double>(aDate2 - pFormatter->GetNullDate());
+ double nDate3 = static_cast<double>(aDate3 - pFormatter->GetNullDate());
+ double nDate4 = static_cast<double>(aDate4 - pFormatter->GetNullDate());
+
+ m_pDoc->SetValue(2, 0, 0, nDate1);
+ m_pDoc->SetValue(2, 1, 0, nDate2);
+ m_pDoc->SetValue(2, 2, 0, nDate3);
+ m_pDoc->SetValue(2, 3, 0, nDate4);
+
+ sc:: DateTimeTransformation aTransform({2}, sc::DATETIME_TRANSFORMATION_TYPE::END_OF_QUARTER );
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_EQUAL(OUString("03/31/11"), m_pDoc->GetString(2, 0, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("12/31/94"), m_pDoc->GetString(2, 1, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("09/30/96"), m_pDoc->GetString(2, 2, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("09/30/47"), m_pDoc->GetString(2, 3, 0));
+}
+
+void ScDataTransformationTest::testGetTime()
+{
+ tools::Time aTime1(5,30,12);
+ tools::Time aTime2(7,23,9);
+ tools::Time aTime3(9,34,40);
+ tools::Time aTime4(22,9,49);
+
+ m_pDoc->SetValue(2, 0, 0, aTime1.GetTimeInDays());
+ m_pDoc->SetValue(2, 1, 0, aTime2.GetTimeInDays());
+ m_pDoc->SetValue(2, 2, 0, aTime3.GetTimeInDays());
+ m_pDoc->SetValue(2, 3, 0, aTime4.GetTimeInDays());
+
+ sc:: DateTimeTransformation aTransform({2}, sc::DATETIME_TRANSFORMATION_TYPE::TIME );
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_EQUAL(OUString("05:30:12 AM"), m_pDoc->GetString(2, 0, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("07:23:09 AM"), m_pDoc->GetString(2, 1, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("09:34:40 AM"), m_pDoc->GetString(2, 2, 0));
+ CPPUNIT_ASSERT_EQUAL(OUString("10:09:49 PM"), m_pDoc->GetString(2, 3, 0));
+}
+
+void ScDataTransformationTest::testGetHour()
+{
+ tools::Time aTime1(5,30,12);
+ tools::Time aTime2(7,23,9);
+ tools::Time aTime3(9,34,40);
+ tools::Time aTime4(22,9,49);
+
+ m_pDoc->SetValue(2, 0, 0, aTime1.GetTimeInDays());
+ m_pDoc->SetValue(2, 1, 0, aTime2.GetTimeInDays());
+ m_pDoc->SetValue(2, 2, 0, aTime3.GetTimeInDays());
+ m_pDoc->SetValue(2, 3, 0, aTime4.GetTimeInDays());
+
+ sc:: DateTimeTransformation aTransform({2}, sc::DATETIME_TRANSFORMATION_TYPE::HOUR );
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(5, m_pDoc->GetValue(2, 0, 0), 0);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(7, m_pDoc->GetValue(2, 1, 0), 0);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(9, m_pDoc->GetValue(2, 2, 0), 0);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(22, m_pDoc->GetValue(2, 3, 0), 0);
+}
+
+void ScDataTransformationTest::testGetMinute()
+{
+ tools::Time aTime1(5,30,12);
+ tools::Time aTime2(7,23,9);
+ tools::Time aTime3(9,34,40);
+ tools::Time aTime4(22,9,49);
+
+ m_pDoc->SetValue(2, 0, 0, aTime1.GetTimeInDays());
+ m_pDoc->SetValue(2, 1, 0, aTime2.GetTimeInDays());
+ m_pDoc->SetValue(2, 2, 0, aTime3.GetTimeInDays());
+ m_pDoc->SetValue(2, 3, 0, aTime4.GetTimeInDays());
+
+ sc:: DateTimeTransformation aTransform({2}, sc::DATETIME_TRANSFORMATION_TYPE::MINUTE );
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(30, m_pDoc->GetValue(2, 0, 0), 0);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(23, m_pDoc->GetValue(2, 1, 0), 0);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(34, m_pDoc->GetValue(2, 2, 0), 0);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(9, m_pDoc->GetValue(2, 3, 0), 0);
+}
+
+void ScDataTransformationTest::testGetSecond()
+{
+ tools::Time aTime1(5,30,53);
+ tools::Time aTime2(7,23,10);
+ tools::Time aTime3(9,34,40);
+ tools::Time aTime4(22,9,49);
+
+ m_pDoc->SetValue(2, 0, 0, aTime1.GetTimeInDays());
+ m_pDoc->SetValue(2, 1, 0, aTime2.GetTimeInDays());
+ m_pDoc->SetValue(2, 2, 0, aTime3.GetTimeInDays());
+ m_pDoc->SetValue(2, 3, 0, aTime4.GetTimeInDays());
+
+ sc:: DateTimeTransformation aTransform({2}, sc::DATETIME_TRANSFORMATION_TYPE::SECOND );
+ aTransform.Transform(*m_pDoc);
+
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(53, m_pDoc->GetValue(2, 0, 0), 0);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(10, m_pDoc->GetValue(2, 1, 0), 0);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(40, m_pDoc->GetValue(2, 2, 0), 0);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(49, m_pDoc->GetValue(2, 3, 0), 0);
+}
+
+ScDataTransformationTest::ScDataTransformationTest() :
+ ScBootstrapFixture( "sc/qa/unit/data/dataprovider" ),
+ m_pDoc(nullptr)
+{
+}
+
+void ScDataTransformationTest::setUp()
+{
+ ScBootstrapFixture::setUp();
+
+ ScDLL::Init();
+ m_xDocShell = new ScDocShell(
+ SfxModelFlags::EMBEDDED_OBJECT |
+ SfxModelFlags::DISABLE_EMBEDDED_SCRIPTS |
+ SfxModelFlags::DISABLE_DOCUMENT_RECOVERY);
+
+ m_xDocShell->SetIsInUcalc();
+ m_xDocShell->DoInitUnitTest();
+ m_pDoc = &m_xDocShell->GetDocument();
+ m_pDoc->InsertTab(0, "Tab");
+}
+
+void ScDataTransformationTest::tearDown()
+{
+ m_xDocShell->DoClose();
+ m_xDocShell.clear();
+ ScBootstrapFixture::tearDown();
+}
+
+CPPUNIT_TEST_SUITE_REGISTRATION(ScDataTransformationTest);
+
+CPPUNIT_PLUGIN_IMPLEMENT();
+
+/* vim:set shiftwidth=4 softtabstop=4 expandtab: */