sc/qa/uitest/calc_tests3/tdf127484.py |   54 ++++++++++++++++++++++++++++++++++
 sc/qa/uitest/data/tdf127484.html      |   28 +++++++++++++++++
 2 files changed, 82 insertions(+)

New commits:
commit b779831ae89a7b921ec3d8658009a191e2270525
Author:     Xisco Fauli <xiscofa...@libreoffice.org>
AuthorDate: Thu Dec 30 17:13:08 2021 +0100
Commit:     Xisco Fauli <xiscofa...@libreoffice.org>
CommitDate: Thu Dec 30 20:26:02 2021 +0100

    tdf#127484: sc: Add UItest
    
    Change-Id: I7c15750ae42d78bfb714638e44c7b761f5c22b47
    Reviewed-on: https://gerrit.libreoffice.org/c/core/+/127759
    Tested-by: Jenkins
    Reviewed-by: Xisco Fauli <xiscofa...@libreoffice.org>

diff --git a/sc/qa/uitest/calc_tests3/tdf127484.py 
b/sc/qa/uitest/calc_tests3/tdf127484.py
new file mode 100644
index 000000000000..83233621726d
--- /dev/null
+++ b/sc/qa/uitest/calc_tests3/tdf127484.py
@@ -0,0 +1,54 @@
+# -*- 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/.
+#
+
+from uitest.framework import UITestCase
+from uitest.uihelper.common import get_state_as_dict
+from uitest.uihelper.common import select_pos
+from libreoffice.uno.propertyvalue import mkPropertyValues
+from uitest.uihelper.common import get_url_for_data_file
+from libreoffice.calc.document import get_cell_by_position
+
+class tdf127484(UITestCase):
+
+    def test_tdf127484(self):
+
+        with self.ui_test.create_doc_in_start_center("calc") as calc_doc:
+
+            with 
self.ui_test.execute_dialog_through_command(".uno:InsertExternalDataSource", 
close_button="") as xDialog:
+                xUrl = xDialog.getChild("url")
+                xUrl.executeAction("TYPE", mkPropertyValues({"TEXT": 
get_url_for_data_file("tdf127484.html")}))
+
+                with self.ui_test.execute_blocking_action(xUrl.executeAction, 
args=("TYPE", mkPropertyValues({"KEYCODE": "RETURN"}))):
+                    pass
+
+                xRanges = xDialog.getChild("ranges")
+                self.assertEqual("3", get_state_as_dict(xRanges)["Children"])
+
+                self.assertEqual("HTML_all", 
get_state_as_dict(xRanges.getChild("0"))["Text"])
+                self.assertEqual("HTML_tables", 
get_state_as_dict(xRanges.getChild("1"))["Text"])
+
+                # Without the fix in place, this test would have failed with
+                # AssertionError: 'HTML_1 - He-Man and Skeletor facts' != 
'HTML_1'
+                self.assertEqual("HTML_1 - He-Man and Skeletor facts", 
get_state_as_dict(xRanges.getChild("2"))["Text"])
+
+                xRanges.getChild("0").executeAction("DESELECT", tuple())
+                xRanges.getChild("2").executeAction("SELECT", tuple())
+
+                # FIXME: close_dialog_through_button fails here
+                xOkBtn = xDialog.getChild("ok")
+                xOkBtn.executeAction("CLICK", tuple())
+
+            self.assertEqual("", get_cell_by_position(calc_doc, 0, 0, 
0).getString())
+            self.assertEqual("Role", get_cell_by_position(calc_doc, 0, 0, 
1).getString())
+            self.assertEqual("Weapon", get_cell_by_position(calc_doc, 0, 0, 
2).getString())
+            self.assertEqual("Dark secret", get_cell_by_position(calc_doc, 0, 
0, 3).getString())
+            self.assertEqual("He-Man", get_cell_by_position(calc_doc, 0, 1, 
0).getString())
+            self.assertEqual("Skeletor", get_cell_by_position(calc_doc, 0, 2, 
0).getString())
+
+# vim: set shiftwidth=4 softtabstop=4 expandtab:
diff --git a/sc/qa/uitest/data/tdf127484.html b/sc/qa/uitest/data/tdf127484.html
new file mode 100644
index 000000000000..d479c3f9cb7c
--- /dev/null
+++ b/sc/qa/uitest/data/tdf127484.html
@@ -0,0 +1,28 @@
+<!doctype html>
+<html>
+       <body>
+        <table>
+            <caption>He-Man and Skeletor facts</caption>
+            <tr>
+                <td> </td>
+                <th scope="col" class="heman">He-Man</th>
+                <th scope="col" class="skeletor">Skeletor</th>
+            </tr>
+            <tr>
+                <th scope="row">Role</th>
+                <td>Hero</td>
+                <td>Villain</td>
+            </tr>
+            <tr>
+                <th scope="row">Weapon</th>
+                <td>Power Sword</td>
+                <td>Havoc Staff</td>
+            </tr>
+            <tr>
+                <th scope="row">Dark secret</th>
+                <td>Expert florist</td>
+                <td>Cries at romcoms</td>
+            </tr>
+        </table>
+       </body>
+</html>

Reply via email to