This chapter provides instructions on configuring and using the OpenScript Oracle EBS/Forms Functional Test Module, which provides support for functional testing of Oracle EBS/Forms web applications.
The Oracle EBS/Forms Functional Test Module provides support for functional testing of Oracle EBS/Forms web applications. The Oracle EBS/Forms Functional Test Module is an extension to the Web Functional Test Module.
The Oracle EBS/Forms Functional Test Module is an extension module to the OpenScript Web Functional Test Module that extends the Web testing with Oracle EBS/Forms Functional Test recording and playback capabilities. The Oracle EBS/Forms Functional Test Module is fully integrated with the OpenScript platform including the Results view, Details view, Properties view, Console/Problems views, Preferences, Step Groups, Script Manager, and Workspace Manager.
The Oracle EBS/Forms Functional Test recorder displays commands in the Tree View in easy-to-understand commands. By default, script commands are grouped into Steps Groups by the Web page on which they were performed. Each Step Group contains one or more script commands corresponding to recorded actions that were performed on the page. The default name for the Step Group is the Web page Title (as specified in the "Title" tag).
OpenScript shows the results of Oracle EBS/Forms Functional Test script playback in the Results view. The Results view shows results for each script command (including duration and summary for failures). The Results Report compiles the same information into an HTML Results Report. Results can be exported from the OpenScript GUI in standard format (CSV / HTML). Results are also generated for unattended playback through the command line.
The Oracle EBS/Forms Functional Test Module API includes a "forms" class that provides additional programming functionality.
Supports Oracle E-Business Suite Release 12 (Forms 10g) running on Sun JRE. Note that E-Business Suite versions running on Jinitiator are not supported with this module. If your E-Business Suite version runs using Jinitiator, you should use Oracle Application Testing Suite version 12.3.0.x (or previous versions).
Records Forms actions in the applet.
Plays back recorded Forms actions/commands which consist of an event plus object identified by its attributes (for example: forms.textField(28, "//forms:textField[(@name='DIST_LIST_NAME_0')]").input("LOREM IPSUM")).
Provides full script code view integration to support script generation for the Oracle EBS/Forms Functional Test Module. The Oracle EBS/Forms Functional Test Module includes an additional API to support Oracle EBS/Forms Functional Test protocol code scripting.
Allows users to parameterize user inputs to Oracle EBS/Forms Functional Test scripts and drive those inputs from an external data file (Databank).
Allows users to insert Tests to validate Oracle EBS/Forms content on playback.
Provides additional automation of all Oracle EBS/Forms GUI components using options/settings that are specific to Oracle EBS/Forms Functional Test scripts within the Oracle EBS/Forms Functional Test categories in the preferences interface.
Reports playback results for Oracle EBS/Forms Functional Test scripts in the Results and Console views.
The Oracle EBS/Forms Functional Test Script Module API. The Oracle EBS/Forms Functional Test Application Programming Interface include Java code methods specific to functional testing of Oracle EBS/Forms applications.
The New Project wizard (Select New from the File menu) includes an "Oracle EBS/Forms " option in the Functional Test group to use when creating Oracle EBS/Forms functional testing projects in OpenScript. The Oracle EBS/Forms Functional Test Script Module records Oracle EBS/Forms applications using Object Identification. OpenScript captures user actions and records them to the OpenScript script nodes in a highly readable sequence of navigations and actions.
The Oracle EBS/Forms Functional Test Module recorder has the following prerequisites:
Before recording any script in Forms Functional Test Module, you must run the Forms/EBS application at least once before attempting to record a script with OpenScript on that machine. This ensures that required JRE has been installed and also verifies that forms applications can run successfully on that machine inside of Internet Explorer.
If you must statically enable the EBS/Forms automation, use the enable/disable EBS/Forms automation command line tool when performing testing in a multi-user OpenScript environment. The command line tool will set the EBS/Forms automation as enabled or disabled and remove the Manage EBS/Forms automation menu option from the Tools menu to prevent user conflicts.
Upon installation of the Oracle Application Testing Suite, an administrator should enable/disable the EBS/Forms automation using the command line tool for all OpenScript users on the machine. In the case of a QA Farm environment, the EBS/Forms automation should be enabled/disabled using the command line tool on each farm server.
After enabling the EBS/Forms automation, complete the configuration by disabling (hiding) the Enable/Disable options on the Tools menu in the OpenScript UI to avoid user conflicts.
The enable/disable EBS/Forms automation command line tool consist of a FormsAutomationEnabler.bat and a FormsFTcmdLineEnabler.jar .jar file used by the batch file. The enable/disable EBS/Forms automation command line tool usage is as follows:
Change directory to the OpenScript directory (or Agent directory for Agent only install) under the installation directory. For example:
cd c:\OracleATS\OpenScript -or- cd c:\OracleATS\Agent
Run or call FormsAutomationEnabler.bat -cmd value, where cmd is either enableForms or disableMenus and value is true or false. Users that want to run from both the agent and OpenScript UI will need to enable EBS/Forms automation in both places. For example, to enable EBS/Forms automation:
FormsAutomationEnabler.bat -enableForms true
To disable the Manage EBS Forms automation Tools menu option in the OpenScript UI:
FormsAutomationEnabler.bat -disableMenus true
To disable the EBS/Forms automation:
FormsAutomationEnabler.bat -enableForms false
To enable the Manage EBS Forms automation Tools menu option in the OpenScript UI:
FormsAutomationEnabler.bat -disableMenus false
Caution:
Always disable the OpenScript EBS/Forms automation when testing is complete. The EBS/Forms automation may use a JRE version earlier than the latest version. The earlier JRE version may not include the most up-to-date security patches.Always disable the EBS/Forms automation before uninstalling OpenScript and installing a newer version. Automation must be disabled in order to remove extra files from the JRE.
The Oracle EBS/Forms Functional Test Module records standard Oracle EBS/Forms components for Oracle E-Business Suite Release 12 (Forms 10g) running on Sun JRE and E-Business Suite Release 11i (Forms 6i). The Recorder creates functional and regression test scripts for automating testing of Oracle EBS/Forms applications.
Oracle EBS/Forms are applet based controls and the Oracle EBS/Forms Functional Test Module provides the object/attribute information for OpenScript to record interactions with those controls. Actions will be captured in the test script as OpenScript "forms" commands. For event-driven actions on Forms windows that do not trigger Forms messages, AWT event actions will be captured in the test script as OpenScript "applet" commands. Other components are standard Web controls which are captured as standard OpenScript "web" commands using Web Functional Test object attributes. Object Identification attributes can later be modified by users through the Preferences global settings for new scripts or for already recorded commands in the tree view or code view. Recording can be configured through Internet Explorer only as the Oracle EBS/Forms Functional Test Module does not support Firefox.
The Oracle EBS/Forms Functional Test Module provides a record toolbar button that lets you initiate the Oracle EBS/Forms recorder and capture Web/Oracle EBS/Forms page actions to the script view. The record toolbar includes start and stop recording toolbar buttons. OpenScript recorders also open a floating toolbar that can be used while recording without having to switch between the browser and OpenScript.
To set Oracle EBS/Forms Functional Test record preferences:
Start OpenScript.
Select OpenScript Preferences from the View menu.
Expand the OpenScript node and the Record category.
Select Oracle EBS/Forms Functional.
Click the tabs and set the preferences. See Section 2.5.5, "Oracle EBS/Forms Functional Test Preferences" for descriptions of the Record Preferences settings.
Click OK.
The Oracle EBS/Forms Functional Test Module uses object identification to specify attributes used to identify Oracle EBS/Forms objects. The Oracle EBS/Forms Functional Test Module uses the same predefined path attributes for common Web objects as the Web Functional Test Module; however, Oracle EBS/Forms Test Automation provides additional attributes to identify forms controls. Object paths are specified in XPath format. For example the object identification path appears as follows in Java code commands:
//forms:textField[(@name='DIST_LIST_NAME_0')]
You can set the default Web object attributes in the Oracle EBS/Forms Functional Test Module Record Preferences. You can also edit object attributes in recorded scripts in the tree view or the code view.
In addition to the predefined object identification, you can add an Object Library to the script to record paths into a library file. Object Library files may be shared and reused across other scripts. The Object Library files provide a more convenient "short name" for objects to provide for more convenient programming.
The Oracle EBS/Forms Functional Test Module includes object identifiers that specify how the recorder identifies Browser objects. You can add object identifiers or edit the existing object identifiers in the Record preferences.
To add or edit an object identifier:
Select the OpenScript Preferences from the View menu.
Expand the Record node and select Forms Functional Test.
Click the Object Identification tab. This tab lets you specify the Oracle EBS/Forms object identification attributes, as follows:
Active Profile: Specifies which object identification profile to use as the active profile. Profiles define a specific set of object identifiers to use when recording EBS/Forms functional tests. Use the Add Profile option to create a new custom profile.
Name: Shows the name(s) of the defined Oracle EBS/Forms object identifiers.
Attributes: Shows the pattern(s) specified for the defined Oracle EBS/Forms object identifiers.
Add Profile: Opens a dialog box for specifying a new Oracle EBS/Forms object identifier profile.
Add Object: Opens a dialog box for specifying a new Oracle EBS/Forms object identifier.
Edit: Opens a dialog box for editing the selected Oracle EBS/Forms object identifier.
Delete: Deletes the selected Oracle Forms object identifier.
Export: Opens a dialog box for exporting the currently selected Forms object identifier profile to an XML file.
Import: Opens a dialog box for importing a saved object identifier profile XML file.
Revert: Reverts the default EBS/Forms object identification profile to the default profile. Any change to the default profile are removed.
For each object element, you specify a name (typically an Oracle Forms object attribute), an operator, a value and a value type. As you add object elements, OpenScript builds the object identifier using logical OR between each object identifier element. Click Edit to change between logical OR and AND.
Click Add or select an existing object identifier and click Edit.
If adding a new object identifier, enter a name for the object identifier.
Add or edit object elements for the object identifier.
See the Web Functional Test Module for additional information about adding and editing Object Identifiers.
Click OK. The object identifier is added to the record preferences.
To record Oracle EBS/Forms Functional Test scripts:
Start OpenScript.
Set the Oracle EBS/Forms Functional Test Recording preferences.
Select New from the File menu.
Expand the Functional Testing group.
Select Oracle EBS/Forms (The Oracle EBS/Forms script combines both Web and Oracle EBS/Forms technologies as part of the same script).
Click Next.
Select the Repository and Workspace.
Enter a script name.
Click Finish. A new Script tree is created in the Script View.
Select Record from the Script menu. The browser automatically opens when you start recording.
Load the web page where you want to start recording into the browser.
Navigate the web site to record page objects, actions, and navigations. The page objects, actions, and navigations will be added to the node of the script tree specified by the Set Record Section setting (the Run node is the default).
When finished navigating pages, close the browser.
Select Stop from the Script menu or click the Stop button on the OpenScript toolbar.
Expand the Run node of the script to view the page objects, actions, and navigation nodes in the script tree.
You can customize the script using the menu options or the Code View for specific testing requirements.
Note:
Do not close the script editor view or script project while recording or playing back scripts. Doing so could result in unpredictable behavior in the OpenScript application.For event-driven actions on Forms windows that do not trigger Forms messages, AWT event actions will be captured in the test script as OpenScript "applet" commands. The following components and actions are supported on JRE 1.5 or later version:
| Component | Actions | XPath Identifier | 
|---|---|---|
| DTree | selectNode, collapseNode, expandNode, activateNode | TJavaDTree | 
| ExpansionTrackingTree | selectNode, extendToNode, toggleNode, collapseNode, expandNode, activateNode, selectPopupMenu | TJavaExpansionTree | 
| Grid | selectCell, focusCell, editCell | TJavaGrid | 
| InfiniteScrollbar | scroll | TJavaInfiniteScrollBar | 
| LWCheckBox | setCheck, isChecked | TJavaCheckbox | 
| LWChoice | selectItem, selectItemByIndex | TJavaCombobox | 
| LWList | select | TJavaList | 
| LWMenu | menuClick | TJavaAppWindow | 
| LWTextArea | replaceSelection, setSelectedRange | TJavaTextView | 
| LWTextField | setText, setSelectedRange | TJavaTextfield | 
| Ocgle Dcm layout edit | selectItem, deselectAll, move, resize, doubleClickItem, rangeSelect, createObject, deleteSelected | |
| PushButton | buttonClick | TJavaButton | 
| SchedulerWBTimeBrowser | resize, move, selectPopupMenu | TJavaTimeBrowser | 
| SchedulerWBTreeBrowser | collapseNode, expandNode, selectNode, doubleClickNode, selectPopupMenu | TJavaTreeBrowser | 
| TabBar | select | TJavaTabBar | 
| Timeline | selectPopupMenu | TJavaTimeline | 
| ToolBar | clickItemByIndex, clickItemByLabel | TJavaToolBar | 
Script commands for event-driven actions appear in the script in the following format:
applet.object(objectId).action(parameters);
The objectId includes the recorded ID and the XPath identifier. The recorded ID is a sequence number generated during recording. The XPath identifier for most components a 2-level path that identifies the window and component with each level starting with /applet:, as follows:
"/applet:TJavaWindow[@identifier]/applet:XPathIdentifier[@identifier]")
The @identifier is the component text or position index of the specific window or control. The position index is 0-based by component type starting with first of the type to appear in source. The XPathIdentifier is specific to the component type. For example, the XPathIdentifier for a Pushbutton is TJavaButton, as follows:
"/applet:TJavaWindow[@text='Editor' or @posIndex='3']
   /applet:TJavaButton[@text='Search' or @posIndex='2']")
A full command with method and action appears as follows:
applet.button(54,"/applet:TJavaWindow[@text='Editor'and @posIndex='3'] /applet:TJavaButton[@text='Search' and @posIndex='2']") .buttonClick();
The action specifies any required parameters, as follows:
applet.comboBox(54,"/applet:TJavaWindow[@text='Editor'and @posIndex='3']
   /applet:TJavaCombobox[@posIndex='2']")
   .selectItem("item");
The XPath for menu actions is a single-level path that identifies the window, as follows:
"/applet:TJavaAppWindow[@text='Oracle Applications - Vision' or @posIndex='0']")
The menuClick action specifies the menu item to click as a parameter, as follows:
applet.appWindow(103,"/applet:TJavaAppWindow[@text='Oracle Applications - Vision' 
      or @posIndex='0']")
   .menuClick("Window|1 Navigator - CRL 11i Projects");
Use Ctrl-space in the Java Code view to open an Intellisense window listing action parameters.
OpenScript plays back recorded Oracle EBS/Forms actions/commands which consist of an event plus an object identified by its attributes (for example: forms.textField(28, "//forms:textField[(@name='DIST_LIST_NAME_0')]").input("LOREM IPSUM")). The actions used for playback will either be those that are recorded or specified manually in the Java Code view. Playback can be configured through IE only as the Oracle EBS/Forms Functional Test Module does not support Firefox. Unattended playback is supported through Oracle Test Manager or third-party tools using OpenScript's command line interface. Oracle EBS/Forms Functional Test scripts do not play in Oracle Load Testing.
The Oracle EBS/Forms Functional Test Module provides playback and iterate toolbar buttons that allows users to start the script playback for either a single playback through the script or multiple iterations using data from a databank file. Playback results for Oracle EBS/Forms Functional scripts can be viewed in the Results and Console views.
To set Oracle EBS/Forms Functional Test Playback preferences:
Start OpenScript.
Select OpenScript Preferences from the View menu.
Expand the OpenScript node and the Playback category.
Select Oracle EBS/Forms Functional Test.
Expand the groups and set the preference. See Section 2.4.6, "Oracle EBS/Forms Functional Test Preferences" for descriptions of the Playback Preferences settings.
Click OK.
To play back Oracle EBS/Forms Functional scripts:
Start OpenScript.
Open the Oracle EBS/Forms Functional script to play back.
Select Playback from the Script menu or click the toolbar button.
You can view the progress of the script playback in the Console View. You can review the results of script playback in the Results View.
To play back Oracle EBS/Forms Functional scripts with iterations:
Start OpenScript.
Open the Oracle EBS/Forms Functional script to play back.
Select Iterate from the Script menu or click the toolbar button.
Select Use Databanks.
Select which databank file to specify the settings for if more than one database is configured for the script.
Specify the settings for the databank file.
Select the Run no more than [ ] iterations option and set the iteration count to the desired number of playback iterations. See Section 4.2.4, "Playing Back Scripts With Iterations" for additional information about iteration settings.
Click OK.
You can view the progress of the script playback in the Console View. You can review the results of script playback in the Results View.
Once a script has been created/recorded, you can make modifications to customize the script for your specific testing needs.
The Oracle EBS/Forms Module includes actions for Oracle EBS/Forms objects that can be added to a script.
To add Forms actions to a script:
Record a EBS/Forms Functional Test script.
Select the script node where you want to add the action.
Select the Script menu and then select Other from the Add sub menu.
Expand the Forms Action node.
Expand an action node and select the action.
Click OK.
Enter the object identification path for the object. You can use the Capture or Select menu options to capture or select an object path.
Enter any required values to use for the object action.
Click OK. The action node is added to the script tree.
In the Java Code view, a forms.object(objectId).action(parameters) method will be added to the script code:
forms.textField(27, "//forms:textField[(@name='DIST_LIST_APPLICATION_0')]").openDialog();
The Forms Action node includes actions for objects such as BlockScroller, Button, Calendar, CheckBox, ChoiceBox, EditBox, EditorDialog, FlexWindow, HelpDialog, InfoBox, List, ListOfValues, Notification, Calculator, RadioGroup, ResponseBox, SchedulingDataClient, SpreadTable, StatusBar, TabbedRegion, TextField, Tree, TreeList. Other object actions have corresponding Java code methods.
The Oracle EBS/Forms Functional Test Module includes a script Application Programming Interface (API) specific to Oracle EBS/Forms functional testing. The Oracle EBS/Forms Functional Test Module recorder creates the Java code that corresponds to the Tree View and displays the Oracle EBS/Forms Functional Test commands in the Java Code view using easy-to-understand function names. The Java Code view commands correspond to the Tree View and you can edit your scripts in either view.
You can use the Oracle EBS/Forms Functional Test API to enhance recorded scripts with additional testing functionality. Commands that are specific to the Oracle EBS/Forms Functional Testing Module are part of the "forms" class. For event-driven actions on Forms windows that do not trigger Forms messages, AWT event actions will be captured in the test script as OpenScript "applet" commands. Additional functional test methods are available in the "web" and "ft" classes. You can also leverage other commands from other enabled classes (services) or general Java commands in your scripts.
Some examples of the Oracle EBS/Forms Testing Module API include:
Forms Action
Button
Calendar
Checkbox
Choice Box
Edit Box
Editor Dialog
Flex Window
Form Window
HelpDialog
Info Box
List
ListOfValues
Notification
RadioGroup
ResponseBox
SchedulingDataClient
SpreadTable
StatusBar
TabbedRegion
TextField
Tree
TreeList
OtsHGridTable
Many API methods can be added using the Oracle EBS/Forms Functional Test Module Tree View. Additional methods can be added using the Java Code view. Use Ctrl-space in the Java Code view to open an Intellisense window listing available procedures. See the API Reference in the OpenScript help for additional programming information.