Topics covered in the SenseTalk Reference include:
- About SenseTalk: An overview of SenseTalk and how it works.
- Key Elements: A one-hour introduction to SenseTalk for experienced programmers and inquiring minds.
- The Basics: To use SenseTalk effectively, you'll need to understand values, containers, expressions, and control structures.
- Objects and Messages: Gain a thorough understanding of messages and handlers, and objects and their helpers.
- Working with Databases: Read the following information to better understand how you can use SenseTalk scripting to work with databases.
- Commands and Functions: Learn how to manipulate text, perform calculations, and more.
- GUI Automation Commands and Functions: SenseTalk methods for interacting with systems under test (SUTs). You can provide mouse or keyboard commands, search for images, or control connected mobile devices.
- Local and Global Properties: In SenseTalk, local and global properties are system-wide values that determine behaviors of the run environment.
For reference tables of Eggplant Functional commands and functions, see and respectively.
Commands and functions are used similarly, but there are some significant differences:
- Functions always have return values; commands might have return values.
- Functions are typically used as parameters to commands.
- Commands must be written alone, not as part of a statement; functions must be part of a statement.
- Separate command and function parameters with commas:
Example: Click "SomeImage", "SomeOtherImage"
- Enclose function parameters in parentheses:
Example: ImageLocation("ThisImage", "ThatImage")
Commands and functions in Eggplant Functionaluse a variety of data types: numbers, coordinates, strings, and property lists.
Single numbers passed as parameters are not enclosed in quotation marks or parentheses.
Example: ScrollWheelUp 10
Time parameters are measured in seconds, unless you indicate otherwise. SenseTalk understands the terms weeks, days, hours, minutes, seconds, and milliseconds.
Examples: Wait 75
Wait 1 minute 15 seconds
When numbers are given as coordinates, they are enclosed in parentheses.
Example: Click (40,65)
Eggplant Functional also allows vector arithmetic to generate a location relative to a known position.
Examples: Click ((30,35) + (100,5))
Click (ImageLocation("SomeButton")+ (100,5))
Strings, such as file names and text literals, are enclosed in quotation marks.
Example: Click "CancelButton"
TypeText "Here is some text."
Note: Double angle-brackets << >> can enclose text that contains quotation marks and large blocks of text with return characters.
Property lists define or identify objects by listing certain properties. Each property comprises a key, which identifies what the property represents, and a value, which defines the property for the object.
Example: (ImageName: "MenuButton", HotSpot: (10, 23))
The example above describes an image that is the same as the saved image called MenuButton, but with a different hot spot location: (10,23). The key ImageName represents the saved image that this property list is based on. The value of ImageName is MenuButton, the actual name of the image.
Property lists are always enclosed in parentheses, with a colon between each key and its value. Quick Reference: Property Lists contains tables of the types of property lists used in Eggplant Functional. For more information, see Property Lists.