summaryrefslogtreecommitdiffstats
path: root/unotools/qa/unit
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-15 05:54:39 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-15 05:54:39 +0000
commit267c6f2ac71f92999e969232431ba04678e7437e (patch)
tree358c9467650e1d0a1d7227a21dac2e3d08b622b2 /unotools/qa/unit
parentInitial commit. (diff)
downloadlibreoffice-267c6f2ac71f92999e969232431ba04678e7437e.tar.xz
libreoffice-267c6f2ac71f92999e969232431ba04678e7437e.zip
Adding upstream version 4:24.2.0.upstream/4%24.2.0
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'unotools/qa/unit')
-rw-r--r--unotools/qa/unit/configpaths.cxx115
-rw-r--r--unotools/qa/unit/testGetEnglishSearchName.cxx73
-rw-r--r--unotools/qa/unit/testRecodeString.cxx45
3 files changed, 233 insertions, 0 deletions
diff --git a/unotools/qa/unit/configpaths.cxx b/unotools/qa/unit/configpaths.cxx
new file mode 100644
index 0000000000..7d9907d9e3
--- /dev/null
+++ b/unotools/qa/unit/configpaths.cxx
@@ -0,0 +1,115 @@
+/* -*- 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 <sal/config.h>
+
+#include <cppunit/TestAssert.h>
+#include <cppunit/TestFixture.h>
+#include <cppunit/extensions/HelperMacros.h>
+#include <cppunit/plugin/TestPlugIn.h>
+
+#include <unotools/configpaths.hxx>
+
+namespace
+{
+class Test : public CppUnit::TestFixture
+{
+public:
+ void testSplitLastFromConfigurationPath()
+ {
+ {
+ OUString path, last;
+ CPPUNIT_ASSERT(!utl::splitLastFromConfigurationPath(u"", path, last));
+ CPPUNIT_ASSERT_EQUAL(OUString(""), path);
+ CPPUNIT_ASSERT_EQUAL(OUString(""), last);
+ }
+ {
+ // Already prior to 5edefc801fb48559c8064003f23d22d838710ee4 "use more string_view in
+ // unotools", and in discordance with the documentation, this returned true (but
+ // "@returns <FALSE/>, if the path was a one-level path or an invalid path"):
+ OUString path, last;
+ CPPUNIT_ASSERT(utl::splitLastFromConfigurationPath(u"/", path, last));
+ CPPUNIT_ASSERT_EQUAL(OUString(""), path);
+ CPPUNIT_ASSERT_EQUAL(OUString(""), last);
+ }
+ {
+ // Already prior to 5edefc801fb48559c8064003f23d22d838710ee4 "use more string_view in
+ // unotools", and in discordance with the documentation, this returned true (but
+ // "@returns <FALSE/>, if the path was a one-level path or an invalid path"):
+ OUString path, last;
+ CPPUNIT_ASSERT(utl::splitLastFromConfigurationPath(u"/foo", path, last));
+ CPPUNIT_ASSERT_EQUAL(OUString(""), path);
+ CPPUNIT_ASSERT_EQUAL(OUString("foo"), last);
+ }
+ {
+ // Already prior to 5edefc801fb48559c8064003f23d22d838710ee4 "use more string_view in
+ // unotools", and in discordance with the documentation, this returned true (but
+ // "@returns <FALSE/>, if the path was a one-level path or an invalid path"):
+ OUString path, last;
+ CPPUNIT_ASSERT(utl::splitLastFromConfigurationPath(u"/foo/", path, last));
+ CPPUNIT_ASSERT_EQUAL(OUString(""), path);
+ CPPUNIT_ASSERT_EQUAL(OUString("foo"), last);
+ }
+ {
+ OUString path, last;
+ CPPUNIT_ASSERT(utl::splitLastFromConfigurationPath(u"/foo/bar/baz", path, last));
+ CPPUNIT_ASSERT_EQUAL(OUString("/foo/bar"), path);
+ CPPUNIT_ASSERT_EQUAL(OUString("baz"), last);
+ }
+ {
+ // Trailing slash accepted for backwards compatibility (cf
+ // . "for backwards compatibility, ignore a final slash" comment in
+ // Data::resolvePathRepresentation, configmgr/source/data.cxx):
+ OUString path, last;
+ CPPUNIT_ASSERT(utl::splitLastFromConfigurationPath(u"/foo/bar/baz/", path, last));
+ CPPUNIT_ASSERT_EQUAL(OUString("/foo/bar"), path);
+ CPPUNIT_ASSERT_EQUAL(OUString("baz"), last);
+ }
+ {
+ OUString path, last;
+ CPPUNIT_ASSERT(utl::splitLastFromConfigurationPath(
+ u"/foo/bar/baz['abc']/baz['de&amp;f']", path, last));
+ CPPUNIT_ASSERT_EQUAL(OUString("/foo/bar/baz['abc']"), path);
+ CPPUNIT_ASSERT_EQUAL(OUString("de&f"), last);
+ }
+ {
+ OUString path, last;
+ CPPUNIT_ASSERT(!utl::splitLastFromConfigurationPath(u"foo", path, last));
+ CPPUNIT_ASSERT_EQUAL(OUString(""), path);
+ CPPUNIT_ASSERT_EQUAL(OUString("foo"), last);
+ }
+ {
+ // In accordance with the documentation, this sets last to "foo/" ("If
+ // <var>_sInPath</var> could not be parsed as a valid configuration path, this is set to
+ // <var>_sInPath</var>"):
+ OUString path, last;
+ CPPUNIT_ASSERT(!utl::splitLastFromConfigurationPath(u"foo/", path, last));
+ CPPUNIT_ASSERT_EQUAL(OUString(""), path);
+ CPPUNIT_ASSERT_EQUAL(OUString("foo/"), last);
+ }
+ {
+ // Some broken input missing a leading slash happens to be considered OK:
+ OUString path, last;
+ CPPUNIT_ASSERT(utl::splitLastFromConfigurationPath(u"foo/bar/baz", path, last));
+ CPPUNIT_ASSERT_EQUAL(OUString("foo/bar"), path);
+ CPPUNIT_ASSERT_EQUAL(OUString("baz"), last);
+ }
+ }
+
+ CPPUNIT_TEST_SUITE(Test);
+ CPPUNIT_TEST(testSplitLastFromConfigurationPath);
+ CPPUNIT_TEST_SUITE_END();
+};
+
+CPPUNIT_TEST_SUITE_REGISTRATION(Test);
+}
+
+CPPUNIT_PLUGIN_IMPLEMENT();
+
+/* vim:set shiftwidth=4 softtabstop=4 expandtab cinoptions=b1,g0,N-s cinkeys+=0=break: */
diff --git a/unotools/qa/unit/testGetEnglishSearchName.cxx b/unotools/qa/unit/testGetEnglishSearchName.cxx
new file mode 100644
index 0000000000..f20f9c8d46
--- /dev/null
+++ b/unotools/qa/unit/testGetEnglishSearchName.cxx
@@ -0,0 +1,73 @@
+/* -*- 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 <cppunit/TestFixture.h>
+#include <cppunit/extensions/HelperMacros.h>
+#include <cppunit/plugin/TestPlugIn.h>
+#include <unotools/fontdefs.hxx>
+
+class Test: public CppUnit::TestFixture
+{
+public:
+ void testSingleElement();
+
+ CPPUNIT_TEST_SUITE(Test);
+ CPPUNIT_TEST(testSingleElement);
+
+ CPPUNIT_TEST_SUITE_END();
+};
+
+void Test::testSingleElement()
+{
+ // lowercase
+ OUString test1 = GetEnglishSearchFontName( u"SYMBOL" );
+ CPPUNIT_ASSERT_EQUAL( OUString("symbol"),test1);
+ //trailing whitespaces
+ test1 = GetEnglishSearchFontName( u"Symbol " );
+ CPPUNIT_ASSERT_EQUAL(OUString("symbol"),test1);
+ //no longer remove script suffixes
+ test1 = GetEnglishSearchFontName( u"Symbol(SIP)" );
+ CPPUNIT_ASSERT_EQUAL(OUString("symbol(sip)"),test1);
+ test1 = GetEnglishSearchFontName( u"CM Roman CE" );
+ CPPUNIT_ASSERT_EQUAL( OUString("cmromance"),test1);
+ //remove special characters; leave semicolon, numbers
+ test1 = GetEnglishSearchFontName( u"sy;mb?=ol129" );
+ CPPUNIT_ASSERT_EQUAL( OUString("sy;mbol129"),test1);
+
+ //transformation
+
+ //for Japanese fontname
+ // IPAMincho
+ static constexpr OUStringLiteral aIPAMincho=u"ipa\u660e\u671d";
+ OUString test_ja_JP1 = GetEnglishSearchFontName(aIPAMincho);
+ CPPUNIT_ASSERT_EQUAL( OUString("ipamincho"),test_ja_JP1);
+ // IPAGothic
+ static constexpr OUStringLiteral aIPAGothic=u"ipa\u30b4\u30b7\u30c3\u30af";
+ OUString test_ja_JP2 = GetEnglishSearchFontName(aIPAGothic);
+ CPPUNIT_ASSERT_EQUAL( OUString("ipagothic"),test_ja_JP2);
+ // HiraginoKakuGothic
+ static constexpr OUStringLiteral aHiraginoKakuGothic=u"\u30D2\u30E9\u30AE\u30CE\u89D2\u30B4\u30B7\u30C3\u30AF";
+ OUString test_ja_JP3 = GetEnglishSearchFontName(aHiraginoKakuGothic);
+ CPPUNIT_ASSERT_EQUAL( OUString("hiraginosans"),test_ja_JP3);
+ // HiraginoMincho Pro N
+ static constexpr OUStringLiteral aHiraginoMinchoProN=u"\u30D2\u30E9\u30AE\u30CE\u660E\u671Dpron";
+ OUString test_ja_JP4 = GetEnglishSearchFontName(aHiraginoMinchoProN);
+ CPPUNIT_ASSERT_EQUAL( OUString("hiraginominchopron"),test_ja_JP4);
+ // HiraginoMaruGothic Pro N
+ static constexpr OUStringLiteral aHiraginoMaruGothicProN
+ =u"\u30D2\u30E9\u30AE\u30CE\u4E38\u30B4pron";
+ OUString test_ja_JP5 = GetEnglishSearchFontName(aHiraginoMaruGothicProN);
+ CPPUNIT_ASSERT_EQUAL( OUString("hiraginomarugothicpron"),test_ja_JP5);
+}
+
+CPPUNIT_TEST_SUITE_REGISTRATION(Test);
+CPPUNIT_PLUGIN_IMPLEMENT();
+
+/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/unotools/qa/unit/testRecodeString.cxx b/unotools/qa/unit/testRecodeString.cxx
new file mode 100644
index 0000000000..b24a4a27e0
--- /dev/null
+++ b/unotools/qa/unit/testRecodeString.cxx
@@ -0,0 +1,45 @@
+/* -*- 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 <config_options.h>
+
+#include <cppunit/TestFixture.h>
+#include <cppunit/extensions/HelperMacros.h>
+#include <cppunit/plugin/TestPlugIn.h>
+
+#include <unotools/fontcvt.hxx>
+#include <unotools/fontdefs.hxx>
+
+class Test : public CppUnit::TestFixture
+{
+public:
+ void testRecodeString();
+
+ CPPUNIT_TEST_SUITE(Test);
+ CPPUNIT_TEST(testRecodeString);
+
+ CPPUNIT_TEST_SUITE_END();
+};
+
+void Test::testRecodeString()
+{
+// note, the below won't work with mergelibs as the class is not visible to the linker
+#if !ENABLE_MERGELIBS
+ ConvertChar const* pConversion = ConvertChar::GetRecodeData(u"starbats", u"opensymbol");
+ OUString aStr(u"u"_ustr);
+ pConversion->RecodeString(aStr, 0, 1);
+ CPPUNIT_ASSERT_EQUAL(u""_ustr, aStr);
+#endif
+}
+
+CPPUNIT_TEST_SUITE_REGISTRATION(Test);
+CPPUNIT_PLUGIN_IMPLEMENT();
+
+/* vim:set shiftwidth=4 softtabstop=4 expandtab: */