From 267c6f2ac71f92999e969232431ba04678e7437e Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Mon, 15 Apr 2024 07:54:39 +0200 Subject: Adding upstream version 4:24.2.0. Signed-off-by: Daniel Baumann --- unotools/qa/python/test_tempfile.py | 149 ++++++++++++++++++++++++++ unotools/qa/unit/configpaths.cxx | 115 ++++++++++++++++++++ unotools/qa/unit/testGetEnglishSearchName.cxx | 73 +++++++++++++ unotools/qa/unit/testRecodeString.cxx | 45 ++++++++ 4 files changed, 382 insertions(+) create mode 100644 unotools/qa/python/test_tempfile.py create mode 100644 unotools/qa/unit/configpaths.cxx create mode 100644 unotools/qa/unit/testGetEnglishSearchName.cxx create mode 100644 unotools/qa/unit/testRecodeString.cxx (limited to 'unotools/qa') 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 + +#include +#include +#include +#include + +#include + +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 , 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 , 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 , 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&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 + // _sInPath could not be parsed as a valid configuration path, this is set to + // _sInPath"): + 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 +#include +#include +#include + +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 + +#include +#include +#include + +#include +#include + +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: */ -- cgit v1.2.3