Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/smysnk/sikuli-framework

SikuliFramework provides an object-oriented abstraction on top of Sikuli to assist with interacting GUI elements, such as sets of buttons, checkboxes, radio buttons, windows and dialogue hierarchies for GUI automation and testing.
https://github.com/smysnk/sikuli-framework

Last synced: about 1 month ago
JSON representation

SikuliFramework provides an object-oriented abstraction on top of Sikuli to assist with interacting GUI elements, such as sets of buttons, checkboxes, radio buttons, windows and dialogue hierarchies for GUI automation and testing.

Awesome Lists containing this project

README

        

SikuliFramework - GUI Automation Framework for Sikuli
================

SikuliFramework provides an object-oriented abstraction on top of [Sikuli](http://www.sikuli.org) to assist with interacting GUI elements, such as sets of buttons, checkboxes, radio buttons, windows and dialogue hierarchies for GUI automation and testing.

**What is Sikuli?**

Sikuli is a visual technology to automate and test graphical user interfaces (GUI) using images (screenshots) of the software under test.
- [Wikipedia](http://en.wikipedia.org/wiki/Sikuli)

## Common problems with traditional "Sikuli scripts"

Most traditional "Sikuli scripts" are created by capturing baseline images around a series of steps required to solve a particular problem. This allows for the quick creation of a script to solve a problem. There are however a few inherent problems with creating scripts in this method, these include:

- Maintainability issues
- Baseline images are usually very specific to a test and cannot be reused
- If the any of the baseline images change, multiple baseline images need be fixed for 1 change in the UI
- No enforced naming convention for baseline pictures (Everyone has a different way of naming things)
- [Fragile tests](http://xunitpatterns.com/Fragile%20Test.html)
- "Sikuli script" often devolve into "hacky" code to get the job done, but it is hard to create truly maintainable tests
- Use of wait(seconds) function depends on computer being fairly fast or increased time is needed, lots of time is wasted waiting around, decreases the readability of tests if there are wait commands everywhere
- Operations are performed without validating whether the system is actually in sync
- Clicking a checkbox, is the checkbox actually selected after the operation?
- Entering text, is the text entered as you expect it?
- Did clicking a button actually perform the action you expected it to? A regular Sikuli script will only fail after it cannot find an image it is expecting to present on the screen

**SikuliFramework** was created to solve some of the complexities and also offers the following benefits:

- Cleaner, more readable code
- Provides structure to the naming of baseline images
- Dynamic resolution of image assets (Designate different images based on OS)
- Encourages baseline reuse (Rather than capturing images to solve your immediate task, capture to solve all tasks)
- Higher accuracy matching GUI components due to use of Regions
- Tight integration with [RobotFramework](http://code.google.com/p/robotframework/) - Inspired by [Mike's cognition's Blog](http://blog.mykhailo.com/2011/02/how-to-sikuli-and-robot-framework.html)
- Encourages code reuse in RobotFramework test libraries
- Streamlines baseline creation for assertions (baselines are created automatically during the initial run of the script)
- Solves some of Sikuli's common downfalls (false-positives, context issues)
- Greatly improved reports for debugging and general-purpose
- Increases the robustness of test scripts (less dependant on speed of the machine, resolution, other problems)

## Code Examples

#### Work with applications in a more natural object-oriented way

calculator = Calculator()

# Chain together operations on the same window
calculator[Calculator.BUTTON_2].click()
[Calculator.BUTTON_PLUS].click()
[Calculator.BUTTON_2].click()
[Calculator.BUTTON_EQUALS].click()

# Built-in assertions methods for testing purposes
calculator[Calculator.SCREEN].assertEquals("4")

#### Integrates with RobotFramework to create extremely readable tests

*Setting*
Library keywords/CalculatorLib.py WITH NAME Calculator

*Test Case*
Add Two Numbers
Calculator.Launch
Calculator.Click Two
Calculator.Click Plus
Calculator.Click Two
Calculator.Click Equals
${Screen}= Calculator.Select Display
Calculator.AssertEquals ${Display} 4

![RobotFramework Results Log](https://github.com/smysnk/sikuli-framework/raw/master/docs/images/robo_example.png)

#### Augments RobotFramework's log.html message statements, adding inline hyperlinking to captured images

![RobotFramework Results Log Hyperlinking](https://github.com/smysnk/sikuli-framework/raw/master/docs/images/robo_log_hyperlink.png)

### Map out special GUI elements such as a TextBox, Radio, Checkbox + more and interact with them as such

calculator[Calculator.SCREEN].type("25")

### Map out the resulting actions of clicking a button

# Create initial application context
textedit = TextEdit()

# Result of clicking the TextEdit button is a TextEditMenu
textEditMenu = textedit[TextEdit.MENU_BAR][MenuBar.TEXTEDIT].click()

# Perform actions on the new context created from the result of the previous action
textEditMenu[TextEditMenu.QUIT].click()

## Getting Started

[Documentation + Tutorials](https://github.com/smysnk/sikuli-framework/wiki)

--------------------------------------

Created by Joshua Bellamy-Henn