summaryrefslogtreecommitdiffstats
path: root/unotools/qa
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
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')
-rw-r--r--unotools/qa/python/test_tempfile.py149
-rw-r--r--unotools/qa/unit/configpaths.cxx115
-rw-r--r--unotools/qa/unit/testGetEnglishSearchName.cxx73
-rw-r--r--unotools/qa/unit/testRecodeString.cxx45
4 files changed, 382 insertions, 0 deletions
diff --git a/unotools/qa/python/test_tempfile.py b/unotools/qa/python/test_tempfile.py
new file mode 100644
index 0000000000..0d417dbbe9
--- /dev/null
+++ b/unotools/qa/python/test_tempfile.py
@@ -0,0 +1,149 @@
+#! /usr/bin/env python
+# -*- tab-width: 4; indent-tabs-mode: nil; py-indent-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/.
+#
+
+import unittest
+
+import uno
+from org.libreoffice.unotest import UnoInProcess
+
+
+class TestTempFile(unittest.TestCase):
+ """Test temporary file object created from com.sun.star.io.TempFile"""
+
+ @classmethod
+ def setUpClass(cls):
+ cls._uno = UnoInProcess()
+ cls._uno.setUp()
+
+ @classmethod
+ def tearDownClass(cls):
+ cls._uno.tearDown()
+
+ def setUp(self):
+ self.file_data = uno.ByteSequence(b"some data")
+
+ service_manager = self._uno.getContext().getServiceManager()
+ if service_manager is None:
+ raise RuntimeError("Cannot create service factory!")
+
+ try:
+ self.file_access = service_manager.createInstance("com.sun.star.ucb.SimpleFileAccess")
+ if self.file_access is None:
+ raise RuntimeError("Cannot get simple access!")
+ except Exception as e:
+ raise RuntimeError(f"Cannot get simple file access! {e}")
+
+ self.temp_file = service_manager.createInstance("com.sun.star.io.TempFile")
+ has_xtempfile_if = bool([
+ 1 for type_info in self.temp_file.getTypes()
+ if type_info.typeName == "com.sun.star.io.XTempFile"
+ ])
+ if not has_xtempfile_if:
+ raise RuntimeError("Cannot get XTempFile interface.")
+
+ def close_temp_file(self) -> None:
+ stream = self.temp_file.getOutputStream()
+ if stream is None:
+ raise RuntimeError("Cannot get output stream")
+ stream.closeOutput()
+ stream = self.temp_file.getInputStream()
+ if stream is None:
+ raise RuntimeError("Cannot get input stream")
+ stream.closeInput()
+ print("Tempfile closed successfully.")
+
+ def read_bytes_with_stream(self) -> uno.ByteSequence:
+ input_stream = self.temp_file.getInputStream()
+ if input_stream is None:
+ raise RuntimeError("Cannot get input stream from tempfile.")
+ nbytes, read_data = input_stream.readBytes(None, len(self.file_data))
+ print("Read", nbytes, "bytes from tempfile successfully.")
+ return read_data
+
+ def read_directly_from_temp_file(self, file_url: str) -> uno.ByteSequence:
+ print("Attempting to read directly from", file_url)
+ input_stream = self.file_access.openFileRead(file_url)
+ if input_stream is None:
+ raise RuntimeError("Cannot create input stream from URL.")
+ nbytes, read_data = input_stream.readBytes(None, len(self.file_data))
+ print("Read", nbytes, "bytes directly from tempfile successfully.")
+ return read_data
+
+ def write_bytes_with_stream(self) -> None:
+ output_stream = self.temp_file.getOutputStream()
+ if output_stream is None:
+ raise RuntimeError("Cannot get output stream.")
+ output_stream.writeBytes(self.file_data)
+ output_stream.flush()
+ print("Write", len(self.file_data), "bytes to tempfile successfully.")
+
+ def get_temp_file_url(self) -> str:
+ uri = self.temp_file.Uri
+ if not uri:
+ raise RuntimeError("Temporary file not valid.")
+ return uri
+
+ def get_temp_file_name(self) -> str:
+ file_name = self.temp_file.ResourceName
+ if not file_name:
+ raise RuntimeError("Temporary file not valid.")
+ return file_name
+
+ def test_01(self):
+ file_uri = self.get_temp_file_url()
+ file_name = self.get_temp_file_name()
+ print("Tempfile URL:", file_uri)
+ print("Tempfile name:", file_name)
+ self.assertTrue(
+ file_uri.endswith(file_name.replace("\\", "/")),
+ "FILE NAME AND URL DO NOT MATCH.",
+ )
+
+ # write to the stream using the service.
+ self.write_bytes_with_stream()
+
+ # check the result by reading from the service.
+ self.temp_file.seek(0)
+ read_data = self.read_bytes_with_stream()
+ self.assertEqual(self.file_data, read_data, "Tempfile outputs false data!")
+
+ # check the result by reading from the file directly.
+ read_data = self.read_directly_from_temp_file(file_uri)
+ self.assertEqual(self.file_data, read_data, "Tempfile contains false data!")
+
+ # close the object(by closing input and output), check that the file
+ # was removed.
+ self.temp_file.RemoveFile = False
+ # After tempfile is closed, file name cannot be got from a TempFile object.
+ file_name = self.temp_file.ResourceName
+ self.close_temp_file()
+ self.assertTrue(
+ self.file_access.exists(file_name), "TempFile mistakenly removed.",
+ )
+
+ # Finally, cleanup this temp file.
+ self.file_access.kill(file_name)
+
+ def test_02(self):
+ self.write_bytes_with_stream()
+ file_url = self.get_temp_file_url()
+ # let the service not to remove the URL.
+ self.temp_file.RemoveFile = False
+ # close the tempfile by closing input and output.
+ self.close_temp_file()
+ # check that the file is still available.
+ read_data = self.read_directly_from_temp_file(file_url)
+ self.assertEqual(self.file_data, read_data, "Tempfile contains false data!")
+
+
+if __name__ == '__main__':
+ unittest.main()
+
+# vim: set shiftwidth=4 softtabstop=4 expandtab:
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: */