OKW - OpenKeyWord is a powerful extension to your existing test-framework such as
- JUnit
- TestNG
- Cucumber ( Cucumber Calculator Example )
OKW is absolutely free, both for open source projects and commercial projects.
Here you can find the OKW Wiki-Pages:
Here you can find all OKW modules in Maven repository.
The fastest and easiest way is:
- Create a Maven Project.
- Add your unit test framework like JUnit as Maven dependency.
- Add an OpenKeyWord GUI-Adapter: At the moment OKW supports Selenium only, but OKW is basically open for all GUI-testing-tools with a java-API and can be adapted easily.
<dependency>
<groupId>de.openkeyword</groupId>
<artifactId>se</artifactId>
<version>?.?.?</version>
</dependency>
- Maven: update project.
Now you can start with GUI-Test description with OKW-Keywords.
The OKW-frame describes your GUI and is a technical-functional mapping. See the simple example "Calculator".
The Steps you have to do are:
- Define for all test relevant GUI-Element a functional name (FN).
- Find the locators which identifies a GUI-Object. The goal is: OKW has to identify the GUI-Objects clearly. The OKW Selenium GUI-adapter uses XPATH as Locator.
- Add GUI-Adapter (e.g. SeBrowserChild or SeTextField) for the specific GUI-Object to the Frame.
- Define functional name with OKW annotation like this: '@OKW( FN = "Display" )'.
- Assign the GUI-Adapter with the specific locator.
Here is a simple OKW-frame as example.
package okw.gui.frames.frmCalculator;
import okw.OKW;
import okw.gui.adapter.selenium.*;
@OKW(FN = "Calculator")
public class frmCalculator extends SeBrowserChild {
@OKW( FN = "Display" )
public SeTextField Display = new SeTextField( "//INPUT[@name='Display']" );
@OKW( FN = "1" )
public SePushButton N1 = new SePushButton( "//input[@value=' 1 ']");
@OKW( FN = "2" )
public SePushButton N2 = new SePushButton( "//input[@value=' 2 ']");
@OKW( FN = "3" )
public SePushButton N3 = new SePushButton( "//input[@value=' 3 ']");
@OKW( FN = "4" )
public SePushButton N4 = new SePushButton( "//input[@value=' 4 ']");
@OKW( FN = "5" )
public SePushButton N5 = new SePushButton( "//input[@value=' 5 ']");
@OKW( FN = "6" )
public SePushButton N6 = new SePushButton( "//input[@value=' 6 ']");
@OKW( FN = "7" )
public SePushButton N7 = new SePushButton( "//input[@value=' 7 ']");
@OKW( FN = "8" )
public SePushButton N8 = new SePushButton( "//input[@value=' 8 ']");
@OKW( FN = "9" )
public SePushButton N9 = new SePushButton( "//input[@value=' 9 ']");
@OKW( FN = "0" )
public SePushButton N0 = new SePushButton( "//input[@value=' 0 ']");
@OKW( FN = "." )
public SePushButton Punkt = new SePushButton( "//INPUT[@type='button' and @value='*.*']" );
@OKW( FN = "+" )
public SePushButton Plus = new SePushButton( "//input[@type='button' and @value=' + ']" );
@OKW( FN = "-" )
public SePushButton Minus = new SePushButton( "//input[@type='button' and @value=' - ']" );
@OKW( FN = "/" )
public SePushButton Durch = new SePushButton( "//input[@type='button' and @value=' / ']" );
@OKW( FN = "*" )
public SePushButton Mal = new SePushButton( "//input[@type='button' and @value=' * ']" );
@OKW( FN = "=" )
public SePushButton Gleich = new SePushButton( "//input[@type='button' and @value=' = ']" );
@OKW( FN = "C" )
public SePushButton Clear = new SePushButton( "//input[@type='reset' and @value=' C ']" );
@OKW( FN = "sqrt" )
public SePushButton Sqrt = new SePushButton( "//input[class='button'] type='button' value='sqrt '" );
public frmCalculator() {
// define Locator for Calculator main-window
super( "//title[text()='Taschenrechner']/../.." );
}
}
A test case with OKW-Keywords is simple and easy to understand. You understand every single step. The test case is not littered with unnecessary things like incomprehensible technical terms. This terrible technical matters are outsourced to the GUI-frame and GUI-adapter.
@Test
public void tc_Calculator_Addition() throws Exception
{
EN.BeginTest( "tc_Calculator_Addition" );
EN.StartApp( "Firefox" );
EN.SetValue( "URL", "https://www2.informatik.hu-berlin.de/Themen/www/selfhtml/javascript/beispiele/anzeige/taschenrechner.htm" );
EN.SelectWindow( "Calculator" );
EN.ClickOn( "1" );
EN.ClickOn( "+" );
EN.ClickOn( "1" );
EN.ClickOn( "=" );
EN.VerifyValue( "Display", "2" );
EN.StopApp( ApplicationName );
EN.EndTest();
}