summaryrefslogtreecommitdiff
path: root/sc/qa
diff options
context:
space:
mode:
authorXisco Fauli <xiscofauli@libreoffice.org>2021-12-30 17:13:08 +0100
committerXisco Fauli <xiscofauli@libreoffice.org>2021-12-30 20:26:02 +0100
commitb779831ae89a7b921ec3d8658009a191e2270525 (patch)
tree59843e7d0242a3a52725b55739cb3b2183133854 /sc/qa
parent572cc53ec16b0a022a5158483920e1a6f1c174b9 (diff)
tdf#127484: sc: Add UItest
Change-Id: I7c15750ae42d78bfb714638e44c7b761f5c22b47 Reviewed-on: https://gerrit.libreoffice.org/c/core/+/127759 Tested-by: Jenkins Reviewed-by: Xisco Fauli <xiscofauli@libreoffice.org>
Diffstat (limited to 'sc/qa')
-rw-r--r--sc/qa/uitest/calc_tests3/tdf127484.py54
-rw-r--r--sc/qa/uitest/data/tdf127484.html28
2 files changed, 82 insertions, 0 deletions
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>