Quellcodebibliothek Statistik Leitseite products/Sources/formale Sprachen/C/LibreOffice/sc/qa/uitest/range_name/   (Office von Apache Version 25.8.3.2©)  Datei vom 5.10.2025 mit Größe 3 kB image not shown  

Quelle  tdf119954.py   Sprache: 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/.
#
from uitest.framework import UITestCase
from uitest.uihelper.calc import enter_text_to_cell
from uitest.uihelper.common import get_url_for_data_file, type_text
from uitest.uihelper.keyboard import select_all

from libreoffice.calc.document import get_cell_by_position
from libreoffice.uno.propertyvalue import mkPropertyValues


# Bug 119954 - Using a second defined database range in formula expression switches to first range.
class tdf119954(UITestCase):
   def test_tdf119954_second_db_range(self):
        with self.ui_test.load_file(get_url_for_data_file("tdf119954.ods")) as calc_doc:
            xCalcDoc = self.xUITest.getTopFocusWindow()
            gridwin = xCalcDoc.getChild("grid_window")
            #* new document
            #* in A1 enter 1
            #* in C3 enter 2
            #* on A1 define a database range 'aaa' with $Sheet1.$A$1
            #* on C3 define a database range 'bbb' with $Sheet2.$C$3
            #* in any cell enter formula =bbb
            #  => result is 1 instead of 2
            #* place cell cursor on that formula cell again
            #  => see that the formula is =aaa instead of =bbb

            gridwin.executeAction("SELECT", mkPropertyValues({"CELL""A1"}))
            with self.ui_test.execute_modeless_dialog_through_command(".uno:DefineDBName"as xDefineNameDlg:
                xEntryBox = xDefineNameDlg.getChild("entry")
                type_text(xEntryBox, "aaa")
                add = xDefineNameDlg.getChild("add")
                assign = xDefineNameDlg.getChild("assign")
                add.executeAction("CLICK", tuple())

            gridwin.executeAction("SELECT", mkPropertyValues({"CELL""A1"}))
            with self.ui_test.execute_modeless_dialog_through_command(".uno:DefineDBName"as xDefineNameDlg:
                xEntryBox = xDefineNameDlg.getChild("entry")
                add = xDefineNameDlg.getChild("add")
                assign = xDefineNameDlg.getChild("assign")
                select_all(xEntryBox)
                type_text(xEntryBox, "bbb")
                select_all(assign)
                type_text(assign, "$Sheet2.$C$3")
                add.executeAction("CLICK", tuple())

            enter_text_to_cell(gridwin, "B2""=bbb")
            gridwin.executeAction("TYPE", mkPropertyValues({"KEYCODE""RETURN"}))
            self.assertEqual(get_cell_by_position(calc_doc, 0, 1, 1).getValue(), 2)

            enter_text_to_cell(gridwin, "C2""=aaa")
            gridwin.executeAction("TYPE", mkPropertyValues({"KEYCODE""RETURN"}))
            self.assertEqual(get_cell_by_position(calc_doc, 0, 2, 1).getValue(), 1)

            self.xUITest.executeCommand(".uno:Undo")
            self.xUITest.executeCommand(".uno:Undo")
            self.assertEqual(get_cell_by_position(calc_doc, 0, 2, 1).getValue(), 0)
            self.assertEqual(get_cell_by_position(calc_doc, 0, 1, 1).getValue(), 0)
            self.assertEqual(get_cell_by_position(calc_doc, 0, 1, 2).getFormula(), "")
            self.assertEqual(get_cell_by_position(calc_doc, 0, 1, 1).getFormula(), "")

            # check cancel button
            with self.ui_test.execute_modeless_dialog_through_command(".uno:DefineDBName", close_button="cancel"):
                pass

# vim: set shiftwidth=4 softtabstop=4 expandtab:

Messung V0.5
C=96 H=94 G=94

¤ Dauer der Verarbeitung: 0.12 Sekunden  (vorverarbeitet)  ¤

*© Formatika GbR, Deutschland






Wurzel

Suchen

Beweissystem der NASA

Beweissystem Isabelle

NIST Cobol Testsuite

Cephes Mathematical Library

Wiener Entwicklungsmethode

Haftungshinweis

Die Informationen auf dieser Webseite wurden nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit, noch Qualität der bereit gestellten Informationen zugesichert.

Bemerkung:

Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.