User Defined Menu Items: Unterschied zwischen den Versionen
| Cg (Diskussion | Beiträge) | Cg (Diskussion | Beiträge)  | ||
| Zeile 99: | Zeile 99: | ||
| only appear in new windows. There, you have to open a new window (via the main menu), then close the previous window. | only appear in new windows. There, you have to open a new window (via the main menu), then close the previous window. | ||
| === Asynchronous Actions === | === Asynchronous (Background) Actions === | ||
| By default, custom menu actions are blocking. This means that the UI is not responding while the menu operation | By default, custom menu actions are blocking. This means that the UI is not responding while the menu operation | ||
Version vom 26. Juni 2015, 12:30 Uhr
You can add your own custom menu items to expecco's main menu, and connect them to an action which is executed, when the menu item is selected.
Thus is very useful to automate common tasks, such as setup/shutdown of test systems, perform configurations, create test data etc.
Inhaltsverzeichnis
Useful Operations of a Custom Menu[Bearbeiten]
The following is a partial list of what can and has been done with this feature in the past (by customers):
- Startup / Shutdown of the System Under Test (usually blocks which execute shell scripts)
- Startup / Shutdown of Java Bridge connections
- Creation of test data files
- Creation of attachments in the item tree
- Extracting an attachment's contents and opening an external editor on it
- Opening a Java GUI on an attachment's contents via the Java Bridge
- Bulk generation of empty TestCase templates from an imported CSV file
Defining a Custom Menu Operation[Bearbeiten]
To add your own menu function, perform the following steps:
- create a folder in the left item tree and give it a useful name (such as "Custom Menu Functions")
- create action blocks there. The blocks should not have any input pins. For a first example, sinply create a compound action, which opens a confirmation dialog.
- give the block a useful name - the block's name will later be shown as the menu item's label.
- navigate to the testsuite's "Misc" page
- drag the folder (Custom Menu Operations) into the "GUI-Extensions"-"Operation Menu" field.
And "Accept" the change (click on "Accept").
You are now ready to use the new operation; you will find a new menu item named "Hello" in the "Extra" menu:
which ,when selected, executes your "Hello" action:
Debugging Custom Menu Operations[Bearbeiten]
Custom menu functions are harder to debug than regular action blocks, because when executed, there is no test/demo page, in which an activity-log is shown. By default, if any error occurs inside the menu operation, it is simply cancelled. A short error message is shown in the lower information area, though.
You can place a breakpoint in an elementary block, and enable the "Debug all Exceptions" flag in the "Execution Settings". You can also send trace messages to the Transcript or Stdout. Sorry, but currently, breakpoints on an activity step or single stepping are currently not possible. We recommend, that the action is first tested in a regular "Test/Demo" page.
Useful Building Blocks for Custom Menu Operations[Bearbeiten]
Because custom menu functions are used heavily by many customers, a library of useful operations ("Expecco Reflection Library") has been created and can be imported into your test suite.
This library contains many useful action blocks to interact with the running expecco itself. For example, to get a handle to the current editor, to add items to the tree or current diagram, to fetch or modify the text being edited etc.
You will also find a few more examples in this library, for example on how to open an external editor on a selected attachment, and how to auto-generate complex activity blocks.
Example Using the Reflection Library: Edit Attachment in External Editor[Bearbeiten]
The following example action is found in the reflection library:
the corresponding menu function can be invoked while editing an activity diagram, with an attachment step being selected. (I.e. it saves the navigation to the attachment item, the click on the edit button, the click on accept in the attachment editor, and navigating back to the diagram). If that is a kind of operation which you have to perform many times per day, you will certainly appreciate that.
Organizing the Custom Menu[Bearbeiten]
By default, custom menu operations are shown in the "Extra Menu", one menu item per action block found in the folder. If the list becomes longer, it should be organized into a hierarchical list of submenu items.
For this, simply add sub-folders to the "Custom Menu Functions" folder, and group the operations as required. The custom menu will follow the folder structure.
Getting a Separate Menu[Bearbeiten]
If you prefer a separate "Operations" top-menu item, check the "In Top Menu" toggle, beside the operation folder field in the test suite's "Misc" page.
Then, custom operations get their own top-level menu and will not be shown in the "Extra" menu. (notice that older expecco versions seem to have a little bug, in that the new top-level menu will only appear in new windows. There, you have to open a new window (via the main menu), then close the previous window.
Asynchronous (Background) Actions[Bearbeiten]
By default, custom menu actions are blocking. This means that the UI is not responding while the menu operation is being executed. This is ok for typical operations as listed above, but is inconvenient if the menu operation is itself a long time running operation.
It is especially inconvenient, if the operation consists of a daemon process, for example to simulate a communication partner, a web service, a monitor or other task, which has to run in parallel with the test execution.
To make a custom operation eecute in the background (i.e. in parallel), place an ampersand character ("&") behind the action#s name (eg. rename the action to something like "Start Foo&". Then, when selected via the menu, the action will be started as a background task, and expecco will immediately return from the menu action.
The background task will run until terminated either via the "Extras"-"Debugging"-"Stop all Executions" menu function, or via the process monitor, which is also available via the "Extras"-"Tools"-"Process Monitor" menu item.







