# -*- tab-width: 4; indent-tabs-mode: nil; py-indent-offset: 4 -*- # # 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 uitest.debug import sleep from uitest.uihelper.calc import enter_text_to_cell from libreoffice.calc.document import get_cell_by_position from libreoffice.uno.propertyvalue import mkPropertyValues #uitest sc - move/copy sheet dialog class moveCopySheet(UITestCase): def test_copy_move_sheet(self): writer_doc = self.ui_test.create_doc_in_start_center("calc") xCalcDoc = self.xUITest.getTopFocusWindow() gridwin = xCalcDoc.getChild("grid_window") document = self.ui_test.get_component() #default - 1 sheet; select the sheet (is selected), dialog move/copy sheet self.ui_test.execute_dialog_through_command(".uno:Move") xDialog = self.xUITest.getTopFocusWindow() #new name = newName newName = xDialog.getChild("newName") newName.executeAction("TYPE", mkPropertyValues({"KEYCODE":"CTRL+A"})) newName.executeAction("TYPE", mkPropertyValues({"KEYCODE":"BACKSPACE"})) newName.executeAction("TYPE", mkPropertyValues({"TEXT":"newName"})) xOKBtn = xDialog.getChild("ok") self.ui_test.close_dialog_through_button(xOKBtn) #verify, the file has 2 sheets; first one "newName" is selected self.assertEqual(document.Sheets.getCount(), 2) # dialog move/copy sheet ; Move is selected; select -move to end position - ; New Name = moveName self.ui_test.execute_dialog_through_command(".uno:Move") xDialog = self.xUITest.getTopFocusWindow() insertBefore = xDialog.getChild("insertBefore") xTreeEntry = insertBefore.getChild('2') xTreeEntry.executeAction("SELECT", tuple()) newName = xDialog.getChild("newName") self.assertEqual(get_state_as_dict(newName)["Text"], "newName") newName.executeAction("TYPE", mkPropertyValues({"KEYCODE":"CTRL+A"})) newName.executeAction("TYPE", mkPropertyValues({"KEYCODE":"BACKSPACE"})) newName.executeAction("TYPE", mkPropertyValues({"TEXT":"moveName"})) xOKBtn = xDialog.getChild("ok") self.ui_test.close_dialog_through_button(xOKBtn) # Verify, the file has 2 sheets; first one is "Sheet1" ; second one is "moveName" self.assertEqual(document.Sheets.getCount(), 2) self.assertEqual(document.Sheets[0].Name, "Sheet1") self.assertEqual(document.Sheets[1].Name, "moveName") # Verify that the cancel button does not do anything self.ui_test.execute_dialog_through_command(".uno:Move") xDialog = self.xUITest.getTopFocusWindow() xCancelBtn = xDialog.getChild("cancel") self.ui_test.close_dialog_through_button(xCancelBtn) self.assertEqual(document.Sheets.getCount(), 2) self.assertEqual(document.Sheets[0].Name, "Sheet1") self.assertEqual(document.Sheets[1].Name, "moveName") #Check copy option self.ui_test.execute_dialog_through_command(".uno:Move") xDialog = self.xUITest.getTopFocusWindow() xCopy = xDialog.getChild("copy") xCopy.executeAction("CLICK", tuple()) sheetName = "moveName_2" newName = xDialog.getChild("newName") self.assertEqual(get_state_as_dict(newName)["Text"], sheetName) xOKBtn = xDialog.getChild("ok") self.ui_test.close_dialog_through_button(xOKBtn) self.assertEqual(document.Sheets.getCount(), 3) self.assertEqual(document.Sheets[0].Name, sheetName) self.assertEqual(document.Sheets[1].Name, "Sheet1") self.assertEqual(document.Sheets[2].Name, "moveName") self.ui_test.close_doc() # vim: set shiftwidth=4 softtabstop=4 expandtab: