macOS Convenience API
Note: The macOS Convenience API is only available for Squish for macOS editions.
The Squish documentation uses the term widget when referring to GUI objects. macOS developers may be more familiar with the term view for this concept.
macOS Convenience Function Parameters
Some of the macOS convenience functions can take a modifierState
argument which indicates which special keys are pressed at the time of a mouse click. And some of the functions can also take a button
argument which indicates which mouse button was clicked.
The modifierState
is an integer used as a bit-flag. Its value can be 0
(no modifiers) or one or more of: 1
(Shift), 2
(Control), 4
(Command), 8
(Option), with multiple modifiers or-ed together (e.g., 1|2
for Shift+Control).
The button
is an integer: 0
signifies the "primary" mouse button (most commonly the left button), and 1
signifies the right button.
macOS Convenience Functions
activateItem(objectOrName)
This function activates the objectOrName
menu item. This menu item must be a reference to (or a name that identifies) an NSMenuItem
. The menu item can be part of the application menu or a menu item inside an NSPopUpButton
.
macOS Universal Access
To replay menu activations on macOS as well as use the nativeType(keys) and nativeMouseClick(x, y, button) functions, you have to enable accessibility support in the System Preferences for certain processes. The system will open up a popup dialog when starting the Squish IDE the first time that allows you to directly go the preferences dialog to enable accessibility support for the Squish IDE.
To open the dialog, select System Preferences and choose Security & Privacy. Then choose the Privacy tab and select Accessibility on the left side.
To make changes, click the lock symbol in the lower left and enter the credentials of an administrative user. Then check the Squishide or Terminal app which needs permissions, from the list.
At any given time, there will be only one Squish IDE instance that has access to the accessibility API and hence can run scripts that automate menus, use the nativeType(keys) or the nativeMouseClick(x, y, button) function. In order to use another Squish IDE, for example from another Squish installation on the same system, you need to remove the existing entry completely from the list and then start the other instance of the Squish IDE. Then enable accessibility support again when the dialog pops up.
Finally, it may sometimes happen that macOS always asks for enabling the accessibility support during the startup of the Squish IDE. In such cases it helps to completely reset the database for Accessibility-enablement and clear out the whole list. This can be done using the tccutil
from macOS:
tccutil reset Accessibility
After executing the command, restart the Squish IDE to trigger the Accessibility-enablement popup again.
chooseFile([filePath, filePath, ...])
Automates operating the Cocoa file chooser dialog (NSOpenPanel
) during test replay. It must be called immediately after the mouseClick
that opens the file chooser. The list of strings given as a parameter will be fed to the AUT as the selected files. Use it to avoid error-prone automation of the NSOpenPanel
through native input. The file dialog can be cancelled by passing an empty array to this function.
The test script is responsible for making sure that the given paths are plausible to the AUT, e.g. they could actually be selected in the file chooser.
If chooseFile
is not invoked after an NSOpenPanel
was triggered, the NSOpenPanel
will open normally after a delay. The delay can be configured in <SQUISHDIR>/etc/macwrapper.ini
.
chooseFile(filePath)
A convenience overload for chooseFile that takes just one filePath
string.
clearWebObjectCache()
This function clears the cache for hierarchical names for objects in a WebView. This can be useful in cases where a web application removes some elements of a web page after interacting with it and then the same hierarchical name used before should find a different object. Without clearing the cache in this situation the old object will be retrieved from the cache when searching for the hierarchical name after the website has changed its content. The cache however is necessary to keep lookup for hierarchical performant and scalable for deeper hierarchies.
doubleClick(objectOrName)
doubleClick(objectOrName, x, y)
doubleClick(objectOrName, x, y, modifierState, button)
This function double-clicks the mouse on the specified objectOrName
widget.
By default the object is clicked in the middle, but this can be changed by passing object-relative coordinates, x
and y
. By default button 0 (the primary button) is used, but this can be changed by specifying the optional button
argument. Similarly a default modifier state of 0 (no modifiers) is used, but this can be changed by specifying the modifierState
argument. Note that to specify the modifier, the button must also be specified, and to specify the modifier, the position must be specified. See macOS Convenience Function Parameters for which values are valid for the modifierState
and for the button
arguments.
installEventHandler(eventName, handlerFunctionName)
This function installs a global event handler. The script function named in handlerFunctionName
(which must be passed as a string, not as a function reference, except for Python, which supports passing a function reference, too), will be called when an event of the eventName
type occurs.
The eventName
can be the name of any of the following event types:
- "Crash" – occurs if the AUT crashes
- "SheetOpened" – occurs when a macOS sheet is shown (note that this only applies to Cocoa applications)
- "WindowOpened" – occurs when a macOS toplevel window is shown (note that this only applies to Cocoa applications)
- "Timeout" – occurs when the Squish response timeout is reached
When the SheetOpened
event occurs, the function named in handlerFunctionName
is called. The function is passed one argument—the window object that opened the sheet. If you want to access the sheet itself, call the attachedSheet
function on the NSWindow
object.
When the WindowOpened
event occurs, the function named in handlerFunctionName
is called. The function is passed one argument—the window object that was opened. The event occurs only for toplevel windows (NSWindow
and NSPanel
objects), but it does not occur for windows that are shown as sheets. Use the SheetOpened
event if you are interested in sheets.
Note: In Python scripts, you can specify the callback function to invoke by passing an actual function or a lambda function.
For examples, see How to Use Event Handlers.
Note: The installEventHandler
function will only work if it is called after the AUT has been started by using the ApplicationContext startApplication(autName) function.
mouseClick(objectOrName)
mouseClick(objectOrName, x, y)
mouseClick(objectOrName, x, y, modifierState, button)
This function clicks the mouse on the specified objectOrName
widget.
By default the object is clicked in the middle, but this can be changed by passing object-relative coordinates, x
and y
. By default button 0 (the primary button) is used, but this can be changed by specifying the optional button
argument. Similarly a default modifier state of 0 (no modifiers) is used, but this can be changed by specifying the modifierState
argument. Note that to specify the modifier, the button must also be specified, and to specify the modifier, the position must be specified. See macOS Convenience Function Parameters for which values are valid for the modifierState
and for the button
arguments.
mouseDrag(objectOrName, x, y, dx, dy)
mouseDrag(objectOrName, x, y, dx, dy, modifierState, button)
This function performs a mouse drag from the objectOrName
widget to a position that is horizontally offset by dx
pixels and vertically offset by dy
pixels from position x
, y
in the objectOrName
widget's coordinates.
By default button 0 (the primary button) is used, but this can be changed by specifying the optional button
argument. Similarly a default modifier state of 0 (no modifiers) is used, but this can be changed by specifying the modifierState
argument. Note that to specify the modifier, the button must also be specified, and to specify the modifier, the position must be specified. See macOS Convenience Function Parameters for which values are valid for the modifierState
and for the button
arguments.
scrollToObject(objectOrName)
This function ensures that the objectOrName
widget is visible in the scroll widget that contains it, by scrolling if necessary.
If there are nested scroll widgets, the innermost one that contains the objectOrName
widget is the one that will be scrolled.
Currently this function only works for NSView
subclasses and for items in a NSTableView
and NSOutlineView
. If you need support for other classes, contact froglogic support.
type(objectOrName, text)
This function types the specified text
(as if the user had used the keyboard) into the objectOrName
editable widget. If the text is surrounded by angle brackets (<>), it is interpreted as a key combination, e.g "<Ctrl+Return>"
. The input is case-sensitive, so type(object, "R")
is different from type(object, "r")
.
The following non-printable keys are supported in key combinations: <Ctrl>
, <Command>
, <Shift>
, <Option>
, <Up>
, <Down>
, <Left>
, <Right>
, <Del>
, <Return>
, <Tab>
, <Backtab>
, <Esc>
, and <Backspace>
.
uninstallEventHandler(eventName, handlerFunctionName)
This function uninstalls an event handler that has been previously installed using installEventHandler(eventName, handlerFunctionName).
—deprecated— clickButton(objectOrName)
This function is identical to mouseClick(objectOrName). It is included only for compatibility with old scripts. It should not be used in new scripts since it may eventually be removed from Squish.
—deprecated— clickTab(objectOrName)
This function is identical to mouseClick(objectOrName). It is included only for compatibility with old scripts. It should not be used in new scripts since it may eventually be removed from Squish.
© 2024 The Qt Company Ltd.
Documentation contributions included herein are the copyrights of
their respective owners.
The documentation provided herein is licensed under the terms of the GNU Free Documentation License version 1.3 as published by the Free Software Foundation.
Qt and respective logos are trademarks of The Qt Company Ltd. in Finland and/or other countries worldwide. All other trademarks are property
of their respective owners.