Compound Network Editor/en: Unterschied zwischen den Versionen
| Cg (Diskussion | Beiträge) | Cg (Diskussion | Beiträge)  | ||
| (155 dazwischenliegende Versionen von 3 Benutzern werden nicht angezeigt) | |||
| Zeile 1: | Zeile 1: | ||
| [[Bild:Network Editor Disable.png|thumb|300px|Network Editor]] | [[Bild:Network Editor Disable.png|thumb|300px|Network Editor]] | ||
| The network editor is used to view and edit activity diagrams of [[Compound Block|compound blocks]]. It  | The network (or ''diagram'') editor is used to view and edit activity diagrams of [[Compound Block|compound blocks]]. It is found on the "''Network''" tab when a compound block is selected in the navigation tree. | ||
| Activity diagrams are the core feature behind expecco's workflow engine. They are similar to  [[CompoundBlock_Element/en#Relationship_to_UML_Activity_Diagrams|UML activity diagrams]] and [[CompoundBlock_Element/en#Relationship_to_Petri_Nets|Petri Nets]], but even more so to [[CompoundBlock_Element/en#Relationship_to IEC1131 Function Block Diagrams|IEC 1131 Functional Block Diagrams]] [https://en.wikipedia.org/wiki/Function_block_diagram]    | |||
| To the right, you see an example for an activity diagram in a network editor with the additional [[Input Pin|input]] (left) and [[Output Pin|output pins]] (right), which  | |||
| represent the pins of the edited block's schema. | |||
| To the right, you see an example for an activity diagram in an editor with the additional [[DiagramElements-Pin#Input Pin|input]] (left) and [[DiagramElements-Pin#Output Pin|output pins]] (right). These represent the pins of the edited action block's schema  | |||
| <br>(notice, that the screenshot was taken with changed preferences in effect. | |||
| By default, it shows a white background and rectangular steps). | |||
| <br> | <br> | ||
| == Toolbar == | == Toolbar == | ||
| [[Bild:Network Editor Toolbar.png]] | [[Bild:Network Editor Toolbar.png|600px]] | ||
| The editor's toolbar area consists of multiple rows. The top row (Execution & Editor) has functions related to test execution and for customizing the editor view. The next row contains most often used functions dealing with triggers and connections, and the last row presents functions to arrange (align) steps.  | |||
| Notice, that the menu arrangement might have changed slightly in newer expecco releases (some functions have been placed into a pull-down submenu). | |||
| All toolbar functions are also found in the right button popup menu. | |||
| The toolbar area consists of two different toolbars. The upper toolbar (Execution & Editor Toolbar)have a group of functions related to the test execution and a group of functions for customizing the editor view. The second toolbar (Edit Function Toolbar) contains special editing functions. | |||
| <br> | |||
| === Execution & Editor Toolbar === | === Execution & Editor Toolbar === | ||
| In the left function group of the toolbar you will find the buttons concerning the test execution. | In the left function group of the toolbar you will find the buttons concerning the test execution of the single block being edited. | ||
| <br><br> | <br><br> | ||
| *[[Bild:Icon_Breakpoint.png]] Add/Remove a breakpoint to/from the selected step(s). The breakpoint will cause the execution to halt before  | *[[Bild:Icon_Breakpoint.png]] Add/Remove a breakpoint to/from the selected step(s). The breakpoint will cause the execution to halt before about to be executed. This allows to analyze the system under test during test execution in a defined state. After a breakpoint the test run can be continued either normally or in single stepping mode. | ||
| <p></p> | |||
| *[[Bild:Icon Run.png]] Start a test run (of the edited Block only). This allows for a changed block's functionality to be checked immediately, without a need to create an extra compound block or a testplan-item for it to be executed. If the edited block needs input values or other prerequisite setup for the test run, these should be defined in the tab named "Test/Demo" (which is the rightmost tab of the editor). | *[[Bild:Icon Run.png]] Start a test run (of the edited Block only) or continue after a breakpoint or execution pause. This allows for a changed block's functionality to be checked immediately, without a need to create an extra compound block or a testplan-item for it to be executed. If the edited block needs input values or other prerequisite setup for the test run, these should be defined in the tab named "''Test/Demo''" (which is the rightmost tab of the editor). | ||
| <p></p> | |||
| *[[Bild:Icon_RunWithDebugMode.png]] Start a test run but open a debugger window in case of test failure. This kind of run is helpful during test development or error analysis. It  | *[[Bild:Icon_RunWithDebugMode.png]] Start a test run but open a debugger window in case of test failure, even if the debugger is currently disabled in the settings. This kind of run is helpful during test development or error analysis. It enables debugging mode without changing the settings. | ||
| < | <p></p> | ||
| In the right area of the toolbar you will find the following functions for customizing the editor. | In the right area of the toolbar you will find the following functions for customizing the editor. | ||
| <br><br> | <br><br> | ||
| *[[Bild:Icon Zoom In.png]] Scale down the size of the objects displayed in the diagram ("zoom out") | *[[Bild:Icon Zoom In.png]] Scale down the size of the objects displayed in the diagram ("''zoom out''"). | ||
| *[[Bild:Icon Zoom Out.png]] Scale up the size of the objects displayed in the diagram ("zoom-in"). | *[[Bild:Icon Zoom Out.png]] Scale up the size of the objects displayed in the diagram ("''zoom-in''"). | ||
| <p></p> | |||
| *[[Bild:Icon Toggle Grid.png]] Toggle the grid display. The grid is displayed as a field of dots that spans the complete diagram area. Displaying the grid is a purely visual assistance, and does not affect the functionality in any way. | *[[Bild:Icon Toggle Grid.png]] Toggle the grid display. The grid is displayed as a field of dots that spans the complete diagram area. Displaying the grid is a purely visual assistance, and does not affect the functionality in any way. | ||
| *[[Bild:Icon Align To Grid.png]] Toggle the automatic grid alignment. When turned on, all motions of steps or connection-edges, will be aligned to the grid, to give some constant gap stepping to the diagram. | *[[Bild:Icon Align To Grid.png]] Toggle the automatic grid alignment. When turned on, all motions of steps or connection-edges, will be aligned to the grid, to give some constant gap stepping to the diagram. By default, grid alignment is on. | ||
| <p></p> | |||
| *[[Bild:Icon_Show_Annotations.png]] [[Bild:Icon_Hide_Annotations.png]]  | *[[Bild:Icon_Show_Annotations.png]] [[Bild:Icon_Hide_Annotations.png]] Toggle if annotations are shown in the editing area. Turning off annotations is sometimes useful if you have annotations for a big graphic background image. | ||
| <br> | <br> | ||
| === Edit Function Toolbar ===  | |||
| === Edit Function Toolbar === | |||
| All functions described below are available through the popUp menu (right-click) in the editor. | All functions described below are available through the popUp menu (right-click) in the editor. | ||
| The menu is context sensitive. This means, that depending on the current selection, different menus are shown.  | The menu is context sensitive. This means, that depending on the current selection, different menus are shown. The most common functions are also provided in an extra toolbar. These toolbar buttons duplicate corresponding functions from the context menus. | ||
| <br><br> | <br><br> | ||
| ==== Geometry Functions ==== | |||
| *[[Bild:Icon Align Left.png]] Align all selected steps to have the same ordinate for their left border. Does not resize steps. | *[[Bild:Icon Align Left.png]] Align all selected steps to have the same ordinate for their left border. Does not resize steps. | ||
| *[[Bild:Icon Align Right.png]] Align all selected steps to have the same ordinate for their right border. Does not resize steps. | *[[Bild:Icon Align Right.png]] Align all selected steps to have the same ordinate for their right border. Does not resize steps. | ||
| *[[Bild:Icon Align Top.png]] Align all selected steps to have the same ordinate for their top border. Does not resize steps. | *[[Bild:Icon Align Top.png]] Align all selected steps to have the same ordinate for their top border. Does not resize steps. | ||
| *[[Bild:Icon Align Bottom.png]] Align all selected steps to have the same ordinate for their bottom border. Does not resize steps. | *[[Bild:Icon Align Bottom.png]] Align all selected steps to have the same ordinate for their bottom border. Does not resize steps. | ||
| <br> | |||
| *[[Bild:Icon Align Left Right.png]] Align all selected steps to have the same ordinate for their right and left border. Steps are resized to match the first selected step's geometry. | *[[Bild:Icon Align Left Right.png]] Align all selected steps to have the same ordinate for their right and left border. Steps are resized to match the first selected step's geometry. | ||
| *[[Bild:Icon Align Top Bottom.png]] Align all selected steps to have the same ordinate for their top and bottom border. Steps are resized to match the first selected step's geometry. | *[[Bild:Icon Align Top Bottom.png]] Align all selected steps to have the same ordinate for their top and bottom border. Steps are resized to match the first selected step's geometry. | ||
| <br> | |||
| *[[Bild:Icon Center Horizontally.png]] Align all selected steps along their vertical centerline. Steps are moved horizontally to be aligned to the first selected step's centerline. | *[[Bild:Icon Center Horizontally.png]] Align all selected steps along their vertical centerline. Steps are moved horizontally to be aligned to the first selected step's centerline. | ||
| *[[Bild:Icon Center Vertically.png]] Align all selected steps along their horizontal centerline. Steps are moved vertically to be aligned to the first selected step's centerline. | *[[Bild:Icon Center Vertically.png]] Align all selected steps along their horizontal centerline. Steps are moved vertically to be aligned to the first selected step's centerline. | ||
| <br> | |||
| *[[Bild:Icon Spread Horizontally.png]] Spread all selected steps for equal horizontal spacing between them. The first and last selected steps are not moved, but define the overall area taken by the group. | *[[Bild:Icon Spread Horizontally.png]] Spread all selected steps for equal horizontal spacing between them. The first and last selected steps are not moved, but define the overall area taken by the group. | ||
| *[[Bild:Icon Spread Vertically.png]] Spread all selected steps for equal vertical spacing between them. The first and last selected steps are not moved, but define the overall area taken by the group. | *[[Bild:Icon Spread Vertically.png]] Spread all selected steps for equal vertical spacing between them. The first and last selected steps are not moved, but define the overall area taken by the group. | ||
| <br> | |||
| *[[Bild:Icon Resize to Max.png]] Resize all selected steps to match the largest step within the selection. | *[[Bild:Icon Resize to Max.png]] Resize all selected steps to match the largest step within the selection. | ||
| *[[Bild:Icon Resize to Min. | *[[Bild:Icon Resize to Min.png]] Resize all selected steps to match the smallest step within the selection. | ||
| <br> | |||
| *[[Bild:Icon Spread Right.png]] | *[[Bild:Icon Spread Right.png]]Increases all horizontal distances by the same factor. Dimensions are not changed. This effectively spreads all selected steps towards the right. | ||
| *[[Bild:Icon Spread Bottom.png]] Increases all vertical distances by the same factor. Dimensions are not changed. This effectively spreads all selected steps towards the bottom. | *[[Bild:Icon Spread Bottom.png]] Increases all vertical distances by the same factor. Dimensions are not changed. This effectively spreads all selected steps towards the bottom. | ||
| *[[Bild:Icon Spread BottomRight.png]] Increases all distances by the same factor. Dimensions are not changed. This effectively spreads all selected steps towards the bottom-right edge. | *[[Bild:Icon Spread BottomRight.png]] Increases all distances by the same factor. Dimensions are not changed. This effectively spreads all selected steps towards the bottom-right edge. | ||
| <br> | |||
| *[[Bild:Icon Resize Selection By.png]] (new in 2.8) Asks for a scale factor and resizes all selected items by that scale factor. The blocks remain at their origin and are resized to the right/bottom. This is useful if you find one or multiple blocks to be too small. | |||
| *[[Bild:Icon Scale Selection By.png]] (new in 2.8) Asks for a scale factor and scales some or all of the diagram by that scale factor. The whole affected (sub-) diagram is scaled, both moving steps and resizing steps so that their relative sizes and positions remain the same. This is useful if you find the overall look of you diagram too crowded and/or need more space for connections, freeze values or textual annotations. | |||
| ==== Execution Behavior Functions ==== | |||
| *[[Bild:Icon Toggle Autostart.png]] Toggle the [[DiagramElements-Step#Autostart | "autostart"-property]] of the selected steps. | *[[Bild:Icon Toggle Autostart.png]] Toggle the [[DiagramElements-Step#Autostart | "autostart"-property]] of the selected steps. | ||
| *[[Bild:Icon Toggle IgnoreException.png]] Toggle the [[DiagramElements-Step# | *[[Bild:Icon Toggle IgnoreException.png]] Toggle the [[DiagramElements-Step#Ignore Exceptions | "ignore exceptions"-property]] of the selected steps. | ||
| *[[Bild:Icon Toggle SkipInLog.png]] Toggle the [[DiagramElements-Step# | *[[Bild:Icon Toggle SkipInLog.png]] Toggle the [[DiagramElements-Step#Suppress Log | "ignore in trace/log"-property]] of the selected steps. Notice, that more trace options are found in the popup menu. | ||
| *[[Bild:Icon Toggle EIP.png]] Toggle the [[DiagramElements-Pin#Enable Input Pin|enable input pin]] of the selected steps.  | |||
| *[[Bild:Icon Toggle EOP.png]] Toggle the [[DiagramElements-Pin#Enable Output Pin|enable output pin]] of the selected steps.  | |||
| *[[Bild:Icon Execute Sequential.png]] Interconnect the selected steps for sequential execution via [[DiagramElements-Pin#Enable Output Pin|enable output pin]]-[[DiagramElements-Pin#Enable Input Pin|enable input pin]] connections. The steps will be connected in the order they were selected. | |||
| *[[Bild:Icon Remove Connection.png]] Remove all selected connections. | |||
| *[[Bild:Icon Recompute Connection.png]] Recompute all selected connections. | |||
| <br> | <br> | ||
| *[[Bild:Icon Toggle EIP.png]] Toggle the [[DiagramElements-Pin#Enable Input Pin|trigger in-pin]] of the selected steps. | |||
| *[[Bild:Icon Toggle EOP.png]] Toggle the [[DiagramElements-Pin#Enable Output Pin|trigger out-pin]] of the selected steps. | |||
| == Tasks == | |||
| *[[Bild:Icon Execute Sequential.png]] Interconnect the selected steps for sequential execution via a chain of [[DiagramElements-Pin#Enable Output Pin|trigger-out]] -> [[DiagramElements-Pin#Enable Input Pin|trigger-in]] connections. Any number of steps can be chained, the steps will be connected in the order they were selected (top-left to bottom-right, if you did a shift-select). | |||
| === Adding Steps === | |||
| When a block is dropped into a diagram, a so-called step is created. A rectangular box appears, which represents the newly created step. The step is initially selected, indicated by the red outline. (Selected items always appear outlined with the selection color, which is red by default, but can be changed in the [[Settings|settings]].) | |||
| Usually, when creating steps, they are initially displayed with a red exclamation mark symbol to the top right of the representation box. This symbol indicates that the step (as it is currently set up) would not run when the diagram is executed. This is the case if the step has no [[Input Pin|triggering inputs]] connected, no  [[Enable Input Pin|direct trigger]], and also no autostart flag activated. If nothing of those is the case, the step will be marked in this manner. It is usually (but not necessarily) not intended to have unconnected steps in a diagram (sometimes, you may leave them in a diagram for documentation purposes). | |||
| Steps can be added to the activity diagram either by drag & drop or via the pop Up-menu.  | |||
| To use drag&drop, drag one ore more items from a navigation tree and drop them into the network editor's display area. If multiple blocks are selected in the navigation tree, they can be dragged in one motion all together. Be aware that the navigation tree of the browser serves both as a source for drag AND to select the block to be edited. If you select and hold down the mouse button, this initiates a drag&drop operation. If you simply click and release the mouse button, this performs a select operation (and you may end up in another diagram). It is therefore sometimes difficult to use this one single tree as a drag source, and it is a therefore good idea to tear off a separate floating navigation tree. These floating windows do not affect the edited-block selection. | |||
| To use the pop Up-menu, select one of the "New Step" items. You can either have an existing action block placed ("existing action") or create a new action. If an existing action is chosen, a dialog pops up, asking for the type of action to add. For new actions, a corresponding new item is automatically created as empty action in the left navigation tree.  | |||
| A very useful function is "Place New Step and Connect" (new in rel1.7). This is enabled if you have a number of pins of existing steps already selected, and will offer a list of matching steps that are useful with that pin selection (i.e. the number of pins and their data types must match). | |||
| All of the menu-initiated step creation functions allow for the action to be chosen from a filtered list of available actions. The filter operates by looking at the name and tag(s) of the actions. If multiple filtering words are entered (separated by semicolons), only actions which contain ALL of those string match patterns will be shown. For example, to get a list of all selenium actions which deal with text validation, enter a filter string like "selenium;text". | |||
| <br> | <br> | ||
| *[[Bild:Icon Remove Connection.png]] Remove all selected connections. | |||
| === Selecting Steps === | |||
| *[[Bild:Icon Recompute Connection.png]] Recompute all selected connections. This "autorouter" tries to find a reasonable shortest path for the connection, trying to not cover other elements. However, you can manually change the path by dragging line segments of the connection path, and/or by inserting extra segments (see connection specific options menu below). | |||
| Steps can be selected by left-clicking on it. Additional steps are selected by holding down the Shift-key in conjunction to the left mouse button. In a similar way, pressing the Control-key (CTRL or STRG) toggles steps into or out of the selection. | |||
| Another possibility to select multiple steps at a time is to mark a selection rectangle area with the mouse, which selects all steps (and other elements) that are within that area. | |||
| Finally, pressing CTRL-a selects all elements of the diagram. This is useful to shift the whole diagram within the page (to make more space at the top, for example). | |||
| <br> | <br> | ||
| === Arranging Steps === | |||
| To move steps to a different location, you can click on it, hold the button, and move it with the mouse. While moving, an equally sized shadow box shows where the new position would be. | |||
| Selected steps can also be moved via the cursor keys. | |||
| If the clicked step was not selected yet when picking it, it will be selected and moved solely. If, on the other hand, the clicked step was part of a current multi selection, the whole selection is picked and moved, including all connections between them. | |||
| When you place steps outside the current diagram boundaries, these will automatically be extended to fit the new position of the moved steps. | |||
| Additional arrangement-functions (spreading, aligning etc.) are found in the context-menu and the tool bar menu. | |||
| <br> | |||
| === Interconnecting Pins === | |||
| Steps exchange data and control information via connected pins. In principle, you can only connect [[Output Pin|output pins]] to [[Input Pin|input pins]], because the intention of a connection is to pass output values from an output to an input. However, an attempt to connect two outputs lets the editor search for the corresponding input pin and create a valid input-output connection. | |||
| To create a connection, click on one of the two pins you want to interconnect, keep the mouse button pressed, and move the mouse to the other pin. To keep track of what you do, a rubber-band line is drawn from the starting pin to your mouse position. The mouse-symbol is changed to a "thumb-down" while over an invalid target pin. When you release the mouse button over a valid target pin, a rectangular connection will automatically be created. If the target pin is not suitable for the operation, no connection is created. | |||
| Note that interconnecting pins underlies certain restrictions: | |||
| *You cannot connect an output pin to another output pin, nor an input pin to another input pin (1). | |||
| *Inside the network, the roles of the compound actions input/output pins are reversed (i.e. the compound's input pins a treated like outputs inside the network). | |||
| *You can only interconnect input and output pins that have compatible [[Datatype|datatypes]]. Usually, you interconnect pins of the same data type, or to a related data type, like an integer output to a float input. An input pin with the "any" data type can be interconnected to any other pin, but not vice versa; an "any" output pin can only be connected to another "any" input pin, unless you add a cast or conversion step in between (2). | |||
| You are not bound to the wiring arrangement as it is created automatically. Instead, you can click on a connection to select it, and then move each of its edges individually to a different ordinate. However, the connections will be automatically laid out again when you move or substitute a step which is involved in this connection. | |||
| To transpose an edge, left-click on the edge, hold the button down, and then drag the edge to the desired position. During motion, a ghost line is drawn to keep track of what you are doing. | |||
| You can also add new edges to the connection, by selecting it, right-clicking the edge into which a new angle branch shall be inserted, and the choosing the "Split Connection" option from the context menu. | |||
| There is one more special display mode for connections: If a connection already exists, but a later data type change to either the input or the output pin violates the data type compatibility of the connection, the connection will be drawn as a dotted line. It can be edited like before, but remains deactivated until the data type compatibility is restored in any valid manner. | |||
| (1) this has been somewhat relaxed in the 1.7.2 release: if you try to connect two inputs, the connection will be done to the already connected output. This makes it easier to place and connect more actions to an existing output if the diagram is big and the output is far away. | |||
| (2) starting with the 1.7.3 release, an "unsafe" connection can be created by pressing the CTRL-key during the connect. This creates a non-type-safe connection. Use this with care, for a temporary workaround, until either a pin's type has been changed, or an appropriate converter has been added. | |||
| <br> | |||
| == Indicators == | == Indicators == | ||
| <br> | |||
| *[[Bild:AutoexecIndicator.png]] The step has the auto exec option flag set. The step will start even without a triggering input. This flag is required for steps of which all pins are non-triggering (for example, because they are "frozen" to fix values), or to steps which have no input pin at all. | *[[Bild:AutoexecIndicator.png]] The step has the auto exec option flag set. The step will start even without a triggering input. This flag is required for steps of which all pins are non-triggering (for example, because they are "frozen" to fix values), or to steps which have no input pin at all. | ||
| *[[Bild:DoNotExecuteIndicator.png]] Shown for skipped steps. Skipping steps is often useful during test-development, to skip over either unfinished actions, or when proceeding development after a change, to skip over already executed steps. When the test goes into production, however, all skip-flags should be removed. | *[[Bild:DoNotExecuteIndicator.png]] Shown for skipped steps. Skipping steps is often useful during test-development, to skip over either unfinished actions, or when proceeding development after a change, to skip over already executed steps. When the test goes into production, however, all skip-flags should be removed. | ||
| *[[Bild:UnlimitedParallelityIndicator.png]] Shown for steps which fork a new activity for every incoming set of values. If this flag is not set, incoming values are remembered in the  | *[[Bild:UnlimitedParallelityIndicator.png]] Shown for steps which fork a new activity for every incoming set of values. If this flag is not set, incoming values are remembered in the step's input baskets, and will be processed sequentially. Notice that in releases prior to 1.9, the default execution mode was "parallel" and the user had to change this to "sequential" via an explicit menu action. Starting with 1.9, the default when placing new steps is now "sequential". Therefore, when you load old test-suites into a post-1.9 expecco editor, you will see these indicators all over the place. | ||
| *[[Bild:IgnoreExceptions.png]] Shown for steps which ignore exceptions. | *[[Bild:IgnoreExceptions.png]] Shown for steps which ignore exceptions. | ||
| *[[Bild:noLog.png]] Shown for steps which are not traced in the activity log. | *[[Bild:noLog.png]] Shown for steps which are not traced in the activity log. | ||
| *[[Bild:BreakPointed.png]] The step has a breakpoint set. When reached during a test run, the  | *[[Bild:BreakPointed.png]] The step has a breakpoint set. When reached during a test run, the executor will pause and wait for either the "Run/Continue" or the "Single-Step" button to be pressed. | ||
| <br> | <br> | ||
| == Attributes Dialog == | |||
| Double click on the step or a connection to open the attribute dialog (*). | |||
| This allows for the colors, look, and name of the step to be changed. | |||
| <br><br> | |||
| (*) this depends on your preferences settings: you can alternatively specify that a double click on a step adds another tab to the expecco user interface, in which the step's definition is edited. | |||
|   | |||
| <br> | |||
| == Common Options (Context Menu) == | == Common Options (Context Menu) == | ||
| [[Bild:Context Menu Common. | [[Bild:Context Menu Common.png|thumb|204px|Common Options]] | ||
| When nothing is selected in the editor: | When nothing is selected in the editor: | ||
| Zeile 151: | Zeile 111: | ||
| *'''Cut, Copy, and Paste'''<br>These commands are valid for all selectable items. They appear in other context menus when applicable. | *'''Cut, Copy, and Paste'''<br>These commands are valid for all selectable items. They appear in other context menus when applicable. | ||
| *'''New Text Annotation'''<br>This option creates a new textual [[Annotation|annotation]]. | *'''New Text Annotation'''<br>This option creates a new textual [[Annotation/en|annotation]]. | ||
| *'''New Legend'''<br>This option creates a legend, which is a text-annotation with info-macro (see [[Annotation|annotation]]). | *'''New Legend'''<br>This option creates a legend, which is a text-annotation with info-macro (see [[Annotation|annotation]]). | ||
| *'''New Image Annotation'''<br>This option creates a new image [[Annotation|annotation]]. | *'''New Image Annotation'''<br>This option creates a new image [[Annotation/en|annotation]]. | ||
| *'''New Step'''<br>This option allows the quick creation of steps. When selected, a dialog appears to specify the type of action. Then, specify the position by moving the mouse to the desired upper-left corner. | *'''New Step'''<br>This option allows the quick creation of steps. When selected, a dialog appears to specify the type of action. Then, specify the position by moving the mouse to the desired upper-left corner. | ||
| Zeile 162: | Zeile 122: | ||
|   |   | ||
| <br> | <br> | ||
| == Step Specific Options (Context Menu) == | == Step Specific Options (Context Menu) == | ||
| [[Bild:Context Menu Step. | [[Bild:Context Menu Step.png|thumb|250px|Step Options]] | ||
| When one or more steps are selected in the editor: | When one or more steps are selected in the editor: | ||
| <br> | <br> | ||
| *'''Rename'''<br>This option allows to rename the selected step. Selecting it opens a text input field at the top of the step's representation box. Starting with expecco2.8, multiline step names are possible by separating the lines with a "\" (backslash) character. A double-click on a step opens an attributes dialog, in which the name can also be edited.<P>Notice that steps which have never been given an explicit name will always show the name of their underlying action block (from the tree) as their name. Thus, the name of a step will follow any changes done there. However, once renamed, the step's name will remain whatever has been entered here. To enforce the old state where the step's name follows the action's name, rename and enter an empty name (i.e. select and cut the name in the rename-field). | |||
| *'''Rename'''<br>This option allows to rename the selected step. Selecting it opens a text input field at the top of the step's representation box. | |||
| *'''Special Pins'''<br>This sub menu allows adding special pins for the selected step. For more information see: [[Pin]] | *'''Special Pins'''<br>This sub menu allows adding special pins for the selected step. For more information see: [[Pin]] | ||
| [[Bild:Context Menu Special Pins. | [[Bild:Context Menu Special Pins.png|thumb|133px|Special Pins]] | ||
| === Controlling Execution === | |||
| *'''Execution'''<br>This sub menu provides several execution related options. Its functions include the switching of special trigger types, parallelism settings, and execution modes. | *'''Execution'''<br>This sub menu provides several execution related options. Its functions include the switching of special trigger types, parallelism settings, and execution modes. | ||
| [[Bild:Context Menu Execution. | [[Bild:Context Menu Execution.png|thumb|208px|Execution]] | ||
| :*'''Autostart'''<br>This check box allows to switch the autostart mode on or off. Steps with this option on are started automatically each time the work flow is executed. You can recognize them by the yellow flash symbol on the top left of the step's representation box. | :*'''Autostart'''<br>This check box allows to switch the autostart mode on or off. Steps with this option on are started automatically each time the work flow is executed. You can recognize them by the yellow flash symbol on the top left of the step's representation box. | ||
| Zeile 181: | Zeile 143: | ||
| :*'''Breakpoint'''<br>This check box allows to set or remove a breakpoint for the selected step. | :*'''Breakpoint'''<br>This check box allows to set or remove a breakpoint for the selected step. | ||
| :*'''Immediately fork new Activity-process'''<br>This check box serves to switch the activity  | :*'''Immediately fork new Activity-process'''<br>This check box serves to switch the fork new activity thread mode on or off. When this option is checked, an activity will immediately executed in a parallel thread; if it is off, the executor gives the block some time to execute sequentially, and later starts a new thread. To indicate that immediate-fork mode is on, a parallelism symbol is displayed at the top right of the step's representation box, but only if there is at least one triggering input pin or a direct trigger pin connected, or autostart activated. | ||
| :*'''Limit Parallelism To...'''<br>This option is used to adjust a maximum number for the activities executed in parallel. When selected, a dialog box opens up, asking to input the maximum number.<br>Initially, no limit is set. If a limit is specified in the dialog, the number appears to the top right of the step's representation box, but only if there is at least one triggering input pin or a direct trigger pin connected, or autostart activated. | :*'''Limit Parallelism To...'''<br>This option is used to adjust a maximum number for the activities executed in parallel. When selected, a dialog box opens up, asking to input the maximum number.<br>Initially, no limit is set. If a limit is specified in the dialog, the number appears to the top right of the step's representation box, but only if there is at least one triggering input pin or a direct trigger pin connected, or autostart activated. | ||
| :*'''Unlimited Parallelism'''<br>This option is the counterpart to the 'Limit Parallelism To...' option. It is only available when a limit is adjusted for the selected step, and annuls this limitation. | :*'''Unlimited Parallelism'''<br>This option is the counterpart to the 'Limit Parallelism To...' option. It is only available when a limit is adjusted for the selected step, and annuls this limitation. | ||
| === Controlling Logging and Tracing === | |||
| *'''Logging'''<br>This submenu provides several options to control the activity-log/trace. Its functions include the disabling of the log unconditionally, if finished with success or without success or if executed in a loop. Both the step itself and/or subactivities of the step can be controlled. The disabling of log/trace information may be required for long running test suites, to prevent reaching any memory limits (and also, to make the activity log more readable). | |||
| [[Bild:Context Menu Logging.png|thumb|208px|Logging]] | |||
| :*'''Skip'''<br>if this attribute is set, the activity will never be logged/traced. This function is also available via the editor's toolbar. | |||
| :*'''Skip If Successful'''<br>if this attribute is set, the activity will not be logged/traced if the step was executed successfully. | |||
| :*'''Skip If Not Successful'''<br>if this attribute is set, the activity will not be logged/traced if the step was executed unsuccessfully. | |||
| :*'''Skip If Looped'''<br>if this attribute is set, the activity will not be logged/traced if the step was executed in a loop. | |||
| :*'''Skip Subactivities'''<br>if this attribute is set, the activity's subactivities will never be logged/traced. This function is also available via the editor's toolbar. | |||
| :*'''Skip Subactivities If Successful'''<br>if this attribute is set, the activity's subactivities will not be logged/traced if the step was executed successfully. | |||
| :*'''Skip Subactivities If Not Successful'''<br>if this attribute is set, the activity's subactivities will not be logged/traced if the step was executed unsuccessfully. | |||
| :*'''Skip Subactivities If Looped'''<br>if this attribute is set, the activity's subactivities will not be logged/traced if the step was executed in a loop. | |||
| The user settings dialog ("''Settings''" -> "''Execution''" -> "''Logging''") contains a flag named "''Ignore all Skip in Trace Attributes''", which enforces trace information to be logged, even for steps with one of the above attributes. | |||
| This is very useful for debugging, to force the generate a full trace - even for suites which contain steps with suppressed logs. | |||
| *'''Operations'''<br>This sub menu provides several options for step substitutions. This includes replacing, substituting and expanding of single steps or compounds of steps. | *'''Operations'''<br>This sub menu provides several options for step substitutions. This includes replacing, substituting and expanding of single steps or compounds of steps. | ||
| [[Bild:Context Menu Operations. | [[Bild:Context Menu Operations.png|thumb|179px|Operations]] | ||
| :*'''Replace By...'''<br>This option replaces an existing step within the current diagram by a substitute step of a block to be chosen. To chose the substitute block, a dialog containing a selection list is opened, showing either all blocks available in the test suite, or only those which pins numbers are the same as that of the block to be substituted. This can be switched with the dialog's button which accordingly displays either "Blocks with same Number of Pins ..." or "All Blocks ...".<br>If the substitute step has less pins on a side than the one to be substituted, existing connections are kept only up to the number of pins of the new step. Connections between newly incompatible pin types are also lost. | :*'''Replace By...'''<br>This option replaces an existing step within the current diagram by a substitute step of a block to be chosen. To chose the substitute block, a dialog containing a selection list is opened, showing either all blocks available in the test suite, or only those which pins numbers are the same as that of the block to be substituted. This can be switched with the dialog's button which accordingly displays either "Blocks with same Number of Pins ..." or "All Blocks ...".<br>If the substitute step has less pins on a side than the one to be substituted, existing connections are kept only up to the number of pins of the new step. Connections between newly incompatible pin types are also lost. | ||
| Zeile 199: | Zeile 184: | ||
| <!--However, in contrast to the previous option, this one does not replace the expanded Step, instead the expanded compound is additionally inserted, and Connections formerly involving the expanded Step's Interfacing Pins are dropped and not yet substituted. The compound is not replacing the expanded Step, but it is ready to be quickly wired in.--> | <!--However, in contrast to the previous option, this one does not replace the expanded Step, instead the expanded compound is additionally inserted, and Connections formerly involving the expanded Step's Interfacing Pins are dropped and not yet substituted. The compound is not replacing the expanded Step, but it is ready to be quickly wired in.--> | ||
| :*'''Add Input...'''<br>This option allows the creation of additional input pins for the selected step. You will be asked to enter a name and a data type for the new pin. | :*'''Add Input...'''<br>This option allows the creation of additional input pins for the selected step. You will be asked to enter a name and a data type for the new pin. | ||
| :*'''Add Output...'''<br>This option allows the creation of additional output pins for the selected step. You will be asked to enter a name and a data type for the new pin. | :*'''Add Output...'''<br>This option allows the creation of additional output pins for the selected step. You will be asked to enter a name and a data type for the new pin. | ||
| Zeile 211: | Zeile 196: | ||
| --> | --> | ||
| <br> | <br> | ||
| == Pin Specific Options (Context Menu) == | == Pin Specific Options (Context Menu) == | ||
| [[Bild:Context Menu Input Pin. | [[Bild:Context Menu Input Pin.png|thumb|399px|Input Pin]] | ||
| [[Bild:Context Menu Output Pin. | [[Bild:Context Menu Output Pin.png|thumb|162px|Output Pin]] | ||
| When an input pin is selected in the editor: | When an input pin is selected in the editor: | ||
| <br> | <br> | ||
| *'''Freeze (as)'''<br>This option applies to all data input pins and trigger Input pins, except for the cancel pin. The identifier of the data type in the menu entry differs depending on the data type of the pin. It allows, for most standard data types, presetting the input value according to the data type, by typing a valid value into a text input field. | *'''Freeze (as)'''<br>This option applies to all data input pins and trigger Input pins, except for the cancel pin. The identifier of the data type in the menu entry differs depending on the data type of the pin. It allows, for most standard data types, presetting the input value according to the data type, by typing a valid value into a text input field. | ||
| *'''Read from Environment Variable...'''<br>This option applies to all data input and some trigger input pins. The option is only available if the selected pin is not connected to any value delivering output pin. Selecting this option causes a dialog to open up, allowing specifying the environment variable's name in a text input field. For more information see: [[Environment Freeze Value]] | *'''Read from Environment Variable...'''<br>This option applies to all data input and some trigger input pins. The option is only available if the selected pin is not connected to any value delivering output pin. Selecting this option causes a dialog to open up, allowing specifying the environment variable's name in a text input field. For more information see: [[Environment Freeze Value]] | ||
| Zeile 223: | Zeile 209: | ||
| *'''Unfreeze'''<br>This option applies to all data input and trigger input pins, but is only available if the selected pin is frozen to a value or to an environment variable. No matter if the pin was preset with a direct value or with an environment variable, the preset information will be lost, and the pin is connect able to adequate output pins again. | *'''Unfreeze'''<br>This option applies to all data input and trigger input pins, but is only available if the selected pin is frozen to a value or to an environment variable. No matter if the pin was preset with a direct value or with an environment variable, the preset information will be lost, and the pin is connect able to adequate output pins again. | ||
| *'''Show Data-type'''<br>This option opens a view which shows the  | *'''Show Data-type'''<br>This option opens a view which shows the pin's data type. | ||
| *'''Parameter'''<br>This check box applies to data input pins only. If checked, the pin will not be comprised in the triggering function for the data input pins. For more information see: [[Input Pin]] | *'''Parameter'''<br>This check box applies to data input pins only. If checked, the pin will not be comprised in the triggering function for the data input pins. For more information see: [[Input Pin]] | ||
| *'''Limit Basket Buffer To...'''<br>This option applies to all data input pins. Selecting this option causes a dialog to open up, allowing specifying the (integer) maximum number of values that the pin should keep in a buffer before suspending subsequent value delivering activities. After entering a valid number and confirming with "OK", the pin is limited to that number, which is indicated by displaying the number to the left top of the pin, as depicted to the right. | *'''Limit Basket Buffer To...'''<br>This option applies to all data input pins. Selecting this option causes a dialog to open up, allowing specifying the (integer) maximum number of values that the pin should keep in a buffer before suspending subsequent value delivering activities. After entering a valid number and confirming with "OK", the pin is limited to that number, which is indicated by displaying the number to the left top of the pin, as depicted to the right. | ||
| *'''Unlimited Basket Buffer'''<br>This option applies to all data input pins, but only appears if the selected pin has a basket buffer limit set. In this case, selecting this option will clear the limit, and the pin appears without a limit indication again. | *'''Unlimited Basket Buffer'''<br>This option applies to all data input pins, but only appears if the selected pin has a basket buffer limit set. In this case, selecting this option will clear the limit, and the pin appears without a limit indication again. | ||
| When an output pin is selected in the editor: | When an output pin is selected in the editor: | ||
| *'''Buffered'''<br>This check box applies to data output pins only. It serves to switch the buffering mode of the pin on or off. For more information see: [[Output Pin]] | *'''Buffered'''<br>This check box applies to data output pins only. It serves to switch the buffering mode of the pin on or off. For more information see: [[Output Pin]] | ||
| <br> | <br> | ||
| == Connection Specific Options (Context Menu) == | == Connection Specific Options (Context Menu) == | ||
| [[Bild:Context Menu Connection. | [[Bild:Context Menu Connection.png|thumb|238px|Connection]] | ||
| When a connection is selected in the editor: | When a connection is selected in the editor: | ||
| Zeile 250: | Zeile 237: | ||
| *'''Arrow'''<br>This check box allows to switch arrows on and off which help to keep track of the connection's direction. | *'''Arrow'''<br>This check box allows to switch arrows on and off which help to keep track of the connection's direction. | ||
| *'''Disable Type-check (force Valid)'''<br>This option disables the type check. So every input pin can be connected with any output pin  | *'''Disable Type-check (force Valid)'''<br>This option disables the type check. So every input pin can be connected with any output pin regardless of their [[Datatype Element|data types]]. | ||
| == Keyboard Shortcuts == | |||
| * <kbd>Ctrl-s</kbd><br>"''Save''"; same as clicking on the "''Accept''" or "''Save''" button. Makes the changes made to the diagram permanent (i.e. installs the new version of the action in the project tree)  | |||
| * <kbd>Ctrl-c</kbd><br>copy the selected element(s) into the clipboard (for paste) | |||
| * <kbd>Ctrl-x</kbd><br>cut the selected element(s) and place into the clipboard (for paste) | |||
| * <kbd>Ctrl-v</kbd><br>paste element(s) from the clipboard; if a pin is selected, the freeze value is set | |||
| * <kbd>Del</kbd><br>delete the selected elements (without placing them into the clipboard) | |||
| * <kbd>Ctrl-z</kbd><br>undo the previous edit operation | |||
|   | |||
| * <kbd>Ctrl-a</kbd><br>select all | |||
| * <kbd>Ctrl-e</kbd><br>select to end (i.e. all below) | |||
| * <kbd>Tab</kbd><br>select the next step which is below/right-of the selected one; wraps around to the first at the end | |||
| * <kbd>Shift-Tab</kbd><br>select the previous step which is above/left-of the selected one; wraps around to the last at the beginning | |||
|   | |||
| * <kbd>Cursor Up</kbd><br>if a non-pin is selected:moves the selected element(s) up (by one grid step). If <kbd>Shift</kbd> is also pressed, the element(s) are moved by 8 grid steps.<br>If a pin is selected, the previous pin is selected. | |||
| * <kbd>Cursor Down</kbd><br>similar, but moves the selected element(s) down. | |||
| * <kbd>Cursor Left</kbd><br>similar, but moves the selected element(s) to the left. | |||
| * <kbd>Cursor Right</kbd><br>similar, but moves the selected element(s) to the right. | |||
| * <kbd>Ctrl-Cursor Up</kbd><br>moves the selected pin up in the action's schema. | |||
| * <kbd>Ctrl-Cursor Down</kbd><br>moves the selected pin down in the action's schema. | |||
|   | |||
| * <kbd>Ctrl-n</kbd><br>opens the [[step selection dialog | "''New Step''" dialog]] to select an action and place a step for it | |||
| * <kbd>Ctrl-N</kbd><br>opens the "''New Action''" dialog to define a new action block in the tree and place a step for it | |||
| * <kbd>Ctrl-r</kbd><br>opens the "''Replace Step''" menu to select an action and replace the selected step by it | |||
| * <kbd>Ctrl-R</kbd><br>replace the selected step by the step in the clipboard | |||
| * <kbd>F2</kbd> ("Rename")<br>opens the "''Rename Step''" menu, asking for a new name for the selected step | |||
| * <kbd>Ctrl-t</kbd><br>adds a "''New Text Annotation''" (not really needed: just type on the background) | |||
| * <kbd>Ctrl-g</kbd><br>opens the "''New Graphic Annotation''" menu to select a bitmap image and place it as an annotation | |||
|   | |||
| * <kbd>Ctrl-p</kbd><br>toggles the selected pin's "''Parameter-Pin''" attribute. | |||
| * <kbd>Ctrl-e</kbd><br>freezes the pin from an environment variable. | |||
|   | |||
| * <kbd>Return</kbd><br>adds an extra editor-page on the selected step's action to the browser window | |||
| * <kbd>Alt-^</kbd><br>if a connection is selected: adds arrows to all of the connection's segments.<br>If no connection is selected and the mouse-pointer is above a segment, that segment's arrow-indicator is toggled. | |||
| * <kbd>Ctrl +</kbd><br>zoom in | |||
| * <kbd>Ctrl -</kbd><br>zoom out | |||
| <!-- * <kbd>Ctrl-0</kbd><br>reset zoom --> | |||
| == Tasks == | |||
| === Adding Steps === | |||
| When a block is dropped into a diagram (from the project tree view on the left, via the popup menu, via a <kbd>Ctrl-n</kbd> shortcut or by copy-paste), a so-called "step" is created. A rectangular box appears, which represents the newly created step. The step is initially selected, indicated by the red outline. Selected items always appear outlined with the selection color, which is red by default, but can be changed in the [[Settings|settings]]. | |||
| Usually, when creating steps, they are initially displayed with a red exclamation mark symbol at the top right of the representation box. This indicates that the step as it is currently set up, would not run when the diagram is executed. This is the case if the step has no [[DiagramElements-Pin#Input_Pins|triggering data inputs]] connected, no [[DiagramElements-Pin#Enable Input Pin| trigger input]], and also no autostart flag activated. If neither of those is the case, the step has no trigger, will not run and is therefore marked in this manner. It is usually (but not necessarily) not intended to have such passive (unexecuted) steps in a diagram. However, sometimes you may want to leave them in a diagram for documentation purposes, or for quick and dirty test actions in a playground. | |||
| Steps can be added to the activity diagram either by drag & drop, via the popup menu, by copy-paste or via the [[action selection dialog]] (keyboard shortcut <kbd>Ctrl-n</kbd>). | |||
| To use drag&drop, drag one ore more items from a navigation tree and drop them into the network editor's display area. If multiple blocks are selected in the navigation tree, they can be dragged in one motion all together. | |||
| Be aware that the navigation tree of the browser serves both as a source for drag AND to select the block to be edited. If you select AND keep holding down the mouse button, this initiates a drag&drop operation. If you simply click and release the mouse button, this performs a select operation (and you may end up in another diagram). | |||
| It is therefore sometimes difficult to use this one single tree as a drag source, and it is a therefore good idea to tear off a separate floating navigation tree or to split the navigation tree into one for navigation, and another for drag&drop. Floating and split windows do not affect the selection, but serve solely as a drag&drop source. | |||
| To use the popup-menu, select one of the "''New Step''" menu items. You can either have an existing action block placed or create a new action. If an existing action is chosen, a dialog pops up, asking for the type of action to add. There are a number of filter options, to help finding the right action in bigger test suites. | |||
| For new actions, a corresponding new item is automatically created as empty action in the left navigation tree. | |||
| A very useful function is "''Place New Step and Connect''". This is enabled if you have a number of pins of existing steps already selected. It will offer a list of matching steps that are useful with that pin selection (i.e. the number of pins and their data types must match). | |||
| All of the menu-initiated step creation functions allow for the action to be chosen from a filtered list of available actions. The filter operates by looking at the name and tag(s) of the actions. If multiple filtering words are entered (separated by semicolons), only actions which contain ALL of those string match patterns will be shown. For example, to get a list of all selenium actions which deal with text validation, enter a filter string like "selenium;text". | |||
| Block descriptions that are tagged as "obsolete" will never be shown in the popup-menus. | |||
| ==== Finding Useful Seps ==== | |||
| Press <kbd>Ctrl-n</kbd> (or select the corresponding right-click menu item) to get a "''New Step''"-dialog. | |||
| If you have an idea of how it might be named, enter that in the top name field search area. For example, "string", "dialog", "convert", etc. are usually good for searching. You can add multiple such name fragments, separated by ";" (semicolon). | |||
| If a pin is selected initially (to which you want to connect the new step), the search can be limited to actions which have matching pin types. I.e. if you have an output pin with "String"-type selected, only actions which take a string as input will be shown. The type-matching can be disabled via a check toggle. You can also have multiple in/outputs selected, to search for actions which have a corresponding set of matching out/inputs. | |||
| If you have no idea about how the action might be named, you can use the advanced "''Search-by-Result''" feature, found in the "''Action Finder''". This is opened via the button at the top-right of the "''New Step''" dialog. | |||
| The "''Action Finder''" lets you give input values and an expected output value, and it will search for actions which would produce that result. For example, if you search for an action to perform a string search, enter both a longer string, and part of it as inputs, and give the expected result - such as "true" as expected output. In this case, the ''Action Finder'' will find actions which detect that partial string ("'Includes String''"). If you give a position as expected result, it will find the "Index in String" action. | |||
| === Selecting Steps === | |||
| Steps are selected by a left-click. Additional steps are selected by holding down the Shift-key in conjunction to the left mouse button: similar to text selection, all steps between the previously selected one and the new clicked step are selected (in a top-left to bottom-right fashion). In a similar way, pressing the Control-key (<kbd>Ctrl</kbd> or <kbd>Strg</kbd>) toggles steps into or out of the selection. | |||
| Another possibility to select multiple steps at a time is to mark a selection rectangle area with the mouse ("''lasso''"), which selects all steps (and other elements) that are within that area. You have to click outside of any step (in the background area) to start a lasso selection. If you have many attachments or background graphics in your diagram, it may become hard to find an unoccupied background area. For this, you can toggle the visibility of all annotations, to get them "out of the way". | |||
| Finally, pressing <kbd>Ctrl-a</kbd> selects all elements of the diagram, and <kbd>Ctrl-e</kbd> selects the steps below the current selected step. These are useful to reposition all or bigger parts of the diagram within the page (for example, to make more space at the top). | |||
| <br> | |||
| === Arranging Steps === | |||
| To move steps to a different location, you can click on it, hold the button, and move it with the mouse. While moving, an equally sized shadow box shows where the new position would be. | |||
| Selected steps can also be moved via the cursor keys. | |||
| If the clicked step was not selected yet when picking it, it will be selected and moved solely. If, on the other hand, the clicked step was part of a current multi selection, the whole selection is picked and moved, including all connections between them. | |||
| When you place steps outside the current diagram boundaries, these will automatically be extended to fit the new position of the moved steps. | |||
| Additional arrangement-functions (spreading, aligning etc.) are found in the context-menu and the tool bar menu. | |||
| <br> | |||
| === Interconnecting Pins === | |||
| [[DiagramElements-Step|Steps]] exchange data and control information via connected [[DiagramElements-Pin|pins]]. | |||
| To create a connection, click on one of the two pins you want to interconnect, keep the mouse button pressed, and move the mouse to the other pin. To keep track of what you do, a rubber-band line is drawn from the starting pin to your mouse position. The mouse-symbol is changed to a "thumb-down" while over an invalid target pin, and the reason for being an invalid connection is shown in the lower info area. The mouse changes back to a regular arrow, when it reaches a valid partner pin. | |||
| When you release the mouse button over a valid target pin, a rectangular connection will automatically be created. If the target pin is not suitable for the operation, no connection is created. | |||
| Note that interconnecting pins underlies certain restrictions: | |||
| *You cannot connect an [[DiagramElements-Pin#Output Pin|output pin]] to another output pin, nor an [[DiagramElements-Pin#Input Pin|input pin]] to another input pin. However, the editor implements a very useful and noticeable UI scheme, in that it connects the input to the "SAME" output or value as the connected to input. (1). | |||
| *Inside the network, the roles of the compound actions input/output pins are reversed (i.e. the compound's input pins are treated like outputs inside the network). | |||
| *You can only interconnect input and output pins that have compatible [[Datatype|datatypes]]. Usually, you interconnect pins of the same data type, or to a related data type, like an integer output to a float input. An input pin with the "any" data type can be interconnected to any other pin, but not vice versa; an "any" output pin can only be connected to another "any" input pin, unless you add a cast or conversion step in between (2). In some situations, this type restriction may be too strict, and you want to connect pins, even if the types do not match. This happens, when pin types have been declared too strict on the input side or too generic on the output side. For example, a block generating values of type "Number" is too generic for an input which accepts only "Integers" (because other numbers may not be handled correctly). You can disable the type check and force a connection by pressing the <kbd>Ctrl</kbd> key while connecting two pins. The connection will be shown as a dashed line, to remind you, that this may cause trouble. By selecting "Disable Type Check" via the connection's right-button menu, you can tell the system that your types are OK, and it should no longer be shown as dashed line. | |||
| In principle, you can only connect [[DiagramElements-Pin#Output Pin|output pins]] to [[DiagramElements-Pin#Input Pin|input pins]], because the intention of a connection is to pass output values from an output to an input. However, an attempt to connect two outputs lets the editor search for the corresponding input pin and create a valid input-output connection. | |||
| You are not bound to the wiring arrangement as it is created automatically. Instead, you can click on a connection to select it, and then move each of its edges individually to a different ordinate. However, the connections will be automatically laid out again when you move or substitute a step which is involved in this connection. | |||
| To transpose an edge (i.e. resize a step), left-click on the edge, hold the button down, and then drag the edge to the desired position. During motion, a ghost line is drawn to keep track of what you are doing. | |||
| You can also add new edges to the connection, by selecting it, right-clicking the edge into which a new angle branch shall be inserted, and the choosing the "''Split Connection''" option from the context menu. | |||
| There is one more special display mode for connections: If a connection already exists, but a later data type change to either the input or the output pin violates the data type compatibility of the connection, the connection will be drawn as a dotted line (i.e. marked as "invalid"). It can be edited like before, but remains marked as invalid until the data type compatibility is restored in any valid manner. | |||
| 1) If you try to connect two inputs, the connection will be done to the already connected output. This makes it easier to place and connect more actions to an existing output if the diagram is big and the output is far away. If the target pin is frozen, the originating input will take over the same freeze value. | |||
| 2) An "unsafe" connection can be created by pressing the <kbd>Ctrl</kbd> key during the connect. This creates a non-type-safe connection. Use this with care, for a temporary workaround, until either a pin's type has been changed, or an appropriate converter has been added. | |||
| <br> | |||
| === Adding Annotations === | |||
| Textual and bitmap annotations (notes) can be placed into the diagram to provide additional information for and commentary. Use the popup-menu's "''New Annotation''" entry, and change the annotation's attributes as required. See [[DiagramElements-Annotation/en | Annotations]] for attributes of an annotation. | |||
| == Hints and Tricks == | |||
| === Skip in Trace Flags === | |||
| Often you are not interested in all execution details - especially if some compound is executed with success, a full log of all underlying subactivities is often not needed. | |||
| You can adjust the generated log both on the step and on the action level via flags from the "''Logging''" context menu.  | |||
| A suggested setting is "''Skip SubActivities if SuccessFul''", which will only generate the trace if the containing action finishes without success. Notice that the decision to keep sublets is made when the containing activity finishes - thus, if you have a long running action, a huge number of logs may have also been generated.<br>For this situation, use "''Skip Successful Subactivities''", which will skip subactivities as soon as they finish.  | |||
| === Using Colors === | |||
| You can highlight the main path through a network by giving the steps along it a different color from other helper steps, for example, logging or error handling steps. | |||
| Or vice versa, if you prefer. Also, connections can be given different color, depending on their semantic meaning (again, a typical example is to colorize error handling paths with a reddish color). | |||
| === Using Annotations as Background === | |||
| You can use an arbitrary background image and place your diagram elements above it. | |||
| Typical uses are company frames with logo, design and architecture pictures or other useful graphics which emphasizes on the structure of the network. | |||
| === Using Empty Annotations as Background Boxes === | |||
| You can also use empty rectangular text-annotations to group steps into functional groups (or example: data preparation, communication, validation).  | |||
| To do this, enter a space as text annotation, then resize the annotations's box, then give it a background color via its attributes. If boxes are reused often, copy-paste them from another (template) diagram. | |||
| === Select a Pin for Automatic Connection === | |||
| If you have a pin selected when a new step is dropped, pasted or created via the <kbd>Ctrl-n</kbd> dialog, and the new step has a compatible pin, these two pins will be automatically connected. | |||
| === Select a Connection to Insert a New Step into the Flow === | |||
| If you have a conenction selected when a new step is dropped, pasted or created via the <kbd>Ctrl-n</kbd> dialog, the new step will be inserted into the selected connection (if possible due to type restrictions). | |||
| === Select a Step for Automatic Trigger Connection === | |||
| If you have a step selected when a new step is dropped, pasted or created via the <kbd>Ctrl-n</kbd> dialog, the new step will be connected via a triggerOut-triggerIn connection. | |||
| === Select two Steps for Automatic Trigger Connections === | |||
| If you have two steps selected when a new step is dropped, pasted or created via the <kbd>Ctrl-n</kbd> dialog, the new step will be inserted into the execution sequence to be triggered by the first and then trigger the second selected step. | |||
| === Embedding a Pin Value in the Step's name === | |||
| If the step's name includes a "%i" character sequence, the i'th input pin value is sliced into the name in the activity log. | |||
| Thus, a name like "My Step (test run %1)" will, if the first input pin got a numeric value like "10", be printed as "My Step (test run 10)" in the log file. | |||
| Additional expansion keywords are: %(START), %(END) and %(STATE) to embed the step's start-time, end-time and result-state. Notice the parentheses around the keywords. | |||
| === Finding all Connections to/from a Pin === | |||
| Click on a connection near the input or output pin (on the first or last connection segment), while holding the Shift-Key. | |||
| === Hiding Connections in Complicated Diagrams === | |||
| You can change a connection's type to "''hidden''". Use this to make diagrams easier to read, | |||
| For other editors see: [[Editors]] | |||
| especially when you have many consuming input pins connected to a single source pin.  | |||
| The connection's endpoints will be shown when the mouse pointer is hovering a pin or if either endpoint pin is selected, but hidden otherwise. | |||
| [[Category: Editors]] | |||
| The full on-line documentation can be found under: [[Online Documentation]] | |||
Aktuelle Version vom 20. Februar 2025, 08:16 Uhr
The network (or diagram) editor is used to view and edit activity diagrams of compound blocks. It is found on the "Network" tab when a compound block is selected in the navigation tree.
Activity diagrams are the core feature behind expecco's workflow engine. They are similar to UML activity diagrams and Petri Nets, but even more so to IEC 1131 Functional Block Diagrams [1]
To the right, you see an example for an activity diagram in an editor with the additional input (left) and output pins (right). These represent the pins of the edited action block's schema 
(notice, that the screenshot was taken with changed preferences in effect.
By default, it shows a white background and rectangular steps).
Inhaltsverzeichnis
- 1 Toolbar
- 2 Indicators
- 3 Attributes Dialog
- 4 Common Options (Context Menu)
- 5 Step Specific Options (Context Menu)
- 6 Pin Specific Options (Context Menu)
- 7 Connection Specific Options (Context Menu)
- 8 Keyboard Shortcuts
- 9 Tasks
- 10 Hints and Tricks
- 10.1 Skip in Trace Flags
- 10.2 Using Colors
- 10.3 Using Annotations as Background
- 10.4 Using Empty Annotations as Background Boxes
- 10.5 Select a Pin for Automatic Connection
- 10.6 Select a Connection to Insert a New Step into the Flow
- 10.7 Select a Step for Automatic Trigger Connection
- 10.8 Select two Steps for Automatic Trigger Connections
- 10.9 Embedding a Pin Value in the Step's name
- 10.10 Finding all Connections to/from a Pin
- 10.11 Hiding Connections in Complicated Diagrams
 
Toolbar[Bearbeiten]
The editor's toolbar area consists of multiple rows. The top row (Execution & Editor) has functions related to test execution and for customizing the editor view. The next row contains most often used functions dealing with triggers and connections, and the last row presents functions to arrange (align) steps.
Notice, that the menu arrangement might have changed slightly in newer expecco releases (some functions have been placed into a pull-down submenu).
All toolbar functions are also found in the right button popup menu.
Execution & Editor Toolbar[Bearbeiten]
In the left function group of the toolbar you will find the buttons concerning the test execution of the single block being edited.
 Add/Remove a breakpoint to/from the selected step(s). The breakpoint will cause the execution to halt before about to be executed. This allows to analyze the system under test during test execution in a defined state. After a breakpoint the test run can be continued either normally or in single stepping mode. Add/Remove a breakpoint to/from the selected step(s). The breakpoint will cause the execution to halt before about to be executed. This allows to analyze the system under test during test execution in a defined state. After a breakpoint the test run can be continued either normally or in single stepping mode.
 Start a test run (of the edited Block only) or continue after a breakpoint or execution pause. This allows for a changed block's functionality to be checked immediately, without a need to create an extra compound block or a testplan-item for it to be executed. If the edited block needs input values or other prerequisite setup for the test run, these should be defined in the tab named "Test/Demo" (which is the rightmost tab of the editor). Start a test run (of the edited Block only) or continue after a breakpoint or execution pause. This allows for a changed block's functionality to be checked immediately, without a need to create an extra compound block or a testplan-item for it to be executed. If the edited block needs input values or other prerequisite setup for the test run, these should be defined in the tab named "Test/Demo" (which is the rightmost tab of the editor).
 Start a test run but open a debugger window in case of test failure, even if the debugger is currently disabled in the settings. This kind of run is helpful during test development or error analysis. It enables debugging mode without changing the settings. Start a test run but open a debugger window in case of test failure, even if the debugger is currently disabled in the settings. This kind of run is helpful during test development or error analysis. It enables debugging mode without changing the settings.
In the right area of the toolbar you will find the following functions for customizing the editor.
 Scale down the size of the objects displayed in the diagram ("zoom out"). Scale down the size of the objects displayed in the diagram ("zoom out").
 Scale up the size of the objects displayed in the diagram ("zoom-in"). Scale up the size of the objects displayed in the diagram ("zoom-in").
 Toggle the grid display. The grid is displayed as a field of dots that spans the complete diagram area. Displaying the grid is a purely visual assistance, and does not affect the functionality in any way. Toggle the grid display. The grid is displayed as a field of dots that spans the complete diagram area. Displaying the grid is a purely visual assistance, and does not affect the functionality in any way.
 Toggle the automatic grid alignment. When turned on, all motions of steps or connection-edges, will be aligned to the grid, to give some constant gap stepping to the diagram. By default, grid alignment is on. Toggle the automatic grid alignment. When turned on, all motions of steps or connection-edges, will be aligned to the grid, to give some constant gap stepping to the diagram. By default, grid alignment is on.
   Toggle if annotations are shown in the editing area. Turning off annotations is sometimes useful if you have annotations for a big graphic background image. Toggle if annotations are shown in the editing area. Turning off annotations is sometimes useful if you have annotations for a big graphic background image.
Edit Function Toolbar[Bearbeiten]
All functions described below are available through the popUp menu (right-click) in the editor.
The menu is context sensitive. This means, that depending on the current selection, different menus are shown. The most common functions are also provided in an extra toolbar. These toolbar buttons duplicate corresponding functions from the context menus.
Geometry Functions[Bearbeiten]
 Align all selected steps to have the same ordinate for their left border. Does not resize steps. Align all selected steps to have the same ordinate for their left border. Does not resize steps.
 Align all selected steps to have the same ordinate for their right border. Does not resize steps. Align all selected steps to have the same ordinate for their right border. Does not resize steps.
 Align all selected steps to have the same ordinate for their top border. Does not resize steps. Align all selected steps to have the same ordinate for their top border. Does not resize steps.
 Align all selected steps to have the same ordinate for their bottom border. Does not resize steps. Align all selected steps to have the same ordinate for their bottom border. Does not resize steps.
 Align all selected steps to have the same ordinate for their right and left border. Steps are resized to match the first selected step's geometry. Align all selected steps to have the same ordinate for their right and left border. Steps are resized to match the first selected step's geometry.
 Align all selected steps to have the same ordinate for their top and bottom border. Steps are resized to match the first selected step's geometry. Align all selected steps to have the same ordinate for their top and bottom border. Steps are resized to match the first selected step's geometry.
 Align all selected steps along their vertical centerline. Steps are moved horizontally to be aligned to the first selected step's centerline. Align all selected steps along their vertical centerline. Steps are moved horizontally to be aligned to the first selected step's centerline.
 Align all selected steps along their horizontal centerline. Steps are moved vertically to be aligned to the first selected step's centerline. Align all selected steps along their horizontal centerline. Steps are moved vertically to be aligned to the first selected step's centerline.
 Spread all selected steps for equal horizontal spacing between them. The first and last selected steps are not moved, but define the overall area taken by the group. Spread all selected steps for equal horizontal spacing between them. The first and last selected steps are not moved, but define the overall area taken by the group.
 Spread all selected steps for equal vertical spacing between them. The first and last selected steps are not moved, but define the overall area taken by the group. Spread all selected steps for equal vertical spacing between them. The first and last selected steps are not moved, but define the overall area taken by the group.
 Resize all selected steps to match the largest step within the selection. Resize all selected steps to match the largest step within the selection.
 Resize all selected steps to match the smallest step within the selection. Resize all selected steps to match the smallest step within the selection.
 Increases all horizontal distances by the same factor. Dimensions are not changed. This effectively spreads all selected steps towards the right. Increases all horizontal distances by the same factor. Dimensions are not changed. This effectively spreads all selected steps towards the right.
 Increases all vertical distances by the same factor. Dimensions are not changed. This effectively spreads all selected steps towards the bottom. Increases all vertical distances by the same factor. Dimensions are not changed. This effectively spreads all selected steps towards the bottom.
 Increases all distances by the same factor. Dimensions are not changed. This effectively spreads all selected steps towards the bottom-right edge. Increases all distances by the same factor. Dimensions are not changed. This effectively spreads all selected steps towards the bottom-right edge.
 (new in 2.8) Asks for a scale factor and resizes all selected items by that scale factor. The blocks remain at their origin and are resized to the right/bottom. This is useful if you find one or multiple blocks to be too small. (new in 2.8) Asks for a scale factor and resizes all selected items by that scale factor. The blocks remain at their origin and are resized to the right/bottom. This is useful if you find one or multiple blocks to be too small.
 (new in 2.8) Asks for a scale factor and scales some or all of the diagram by that scale factor. The whole affected (sub-) diagram is scaled, both moving steps and resizing steps so that their relative sizes and positions remain the same. This is useful if you find the overall look of you diagram too crowded and/or need more space for connections, freeze values or textual annotations. (new in 2.8) Asks for a scale factor and scales some or all of the diagram by that scale factor. The whole affected (sub-) diagram is scaled, both moving steps and resizing steps so that their relative sizes and positions remain the same. This is useful if you find the overall look of you diagram too crowded and/or need more space for connections, freeze values or textual annotations.
Execution Behavior Functions[Bearbeiten]
 Toggle the  "autostart"-property of the selected steps. Toggle the  "autostart"-property of the selected steps.
 Toggle the  "ignore exceptions"-property of the selected steps. Toggle the  "ignore exceptions"-property of the selected steps.
 Toggle the  "ignore in trace/log"-property of the selected steps. Notice, that more trace options are found in the popup menu. Toggle the  "ignore in trace/log"-property of the selected steps. Notice, that more trace options are found in the popup menu.
 Toggle the trigger in-pin of the selected steps. Toggle the trigger in-pin of the selected steps.
 Toggle the trigger out-pin of the selected steps. Toggle the trigger out-pin of the selected steps.
 Interconnect the selected steps for sequential execution via a chain of trigger-out -> trigger-in connections. Any number of steps can be chained, the steps will be connected in the order they were selected (top-left to bottom-right, if you did a shift-select). Interconnect the selected steps for sequential execution via a chain of trigger-out -> trigger-in connections. Any number of steps can be chained, the steps will be connected in the order they were selected (top-left to bottom-right, if you did a shift-select).
 Remove all selected connections. Remove all selected connections.
 Recompute all selected connections. This "autorouter" tries to find a reasonable shortest path for the connection, trying to not cover other elements. However, you can manually change the path by dragging line segments of the connection path, and/or by inserting extra segments (see connection specific options menu below). Recompute all selected connections. This "autorouter" tries to find a reasonable shortest path for the connection, trying to not cover other elements. However, you can manually change the path by dragging line segments of the connection path, and/or by inserting extra segments (see connection specific options menu below).
Indicators[Bearbeiten]
 The step has the auto exec option flag set. The step will start even without a triggering input. This flag is required for steps of which all pins are non-triggering (for example, because they are "frozen" to fix values), or to steps which have no input pin at all. The step has the auto exec option flag set. The step will start even without a triggering input. This flag is required for steps of which all pins are non-triggering (for example, because they are "frozen" to fix values), or to steps which have no input pin at all.
 Shown for skipped steps. Skipping steps is often useful during test-development, to skip over either unfinished actions, or when proceeding development after a change, to skip over already executed steps. When the test goes into production, however, all skip-flags should be removed. Shown for skipped steps. Skipping steps is often useful during test-development, to skip over either unfinished actions, or when proceeding development after a change, to skip over already executed steps. When the test goes into production, however, all skip-flags should be removed.
 Shown for steps which fork a new activity for every incoming set of values. If this flag is not set, incoming values are remembered in the step's input baskets, and will be processed sequentially. Notice that in releases prior to 1.9, the default execution mode was "parallel" and the user had to change this to "sequential" via an explicit menu action. Starting with 1.9, the default when placing new steps is now "sequential". Therefore, when you load old test-suites into a post-1.9 expecco editor, you will see these indicators all over the place. Shown for steps which fork a new activity for every incoming set of values. If this flag is not set, incoming values are remembered in the step's input baskets, and will be processed sequentially. Notice that in releases prior to 1.9, the default execution mode was "parallel" and the user had to change this to "sequential" via an explicit menu action. Starting with 1.9, the default when placing new steps is now "sequential". Therefore, when you load old test-suites into a post-1.9 expecco editor, you will see these indicators all over the place.
 The step has a breakpoint set. When reached during a test run, the executor will pause and wait for either the "Run/Continue" or the "Single-Step" button to be pressed. The step has a breakpoint set. When reached during a test run, the executor will pause and wait for either the "Run/Continue" or the "Single-Step" button to be pressed.
Attributes Dialog[Bearbeiten]
Double click on the step or a connection to open the attribute dialog (*).
This allows for the colors, look, and name of the step to be changed.
(*) this depends on your preferences settings: you can alternatively specify that a double click on a step adds another tab to the expecco user interface, in which the step's definition is edited.
 
Common Options (Context Menu)[Bearbeiten]
When nothing is selected in the editor:
- Undo
 Allows you to undo previous editing steps. The list of undo-able operations is cleared as soon as you apply your changes (by pressing the accept button). Once accepted, only major changes can be undone via the global undo function, which restores the previously accepted version(s).
- Cut, Copy, and Paste
 These commands are valid for all selectable items. They appear in other context menus when applicable.
- New Text Annotation
 This option creates a new textual annotation.
- New Legend
 This option creates a legend, which is a text-annotation with info-macro (see annotation).
- New Image Annotation
 This option creates a new image annotation.
- New Step
 This option allows the quick creation of steps. When selected, a dialog appears to specify the type of action. Then, specify the position by moving the mouse to the desired upper-left corner.
- Recompute all Connections
 This option recomputes of all connections in the diagram (routing algorithm).
 
Step Specific Options (Context Menu)[Bearbeiten]
When one or more steps are selected in the editor:
- Rename
 This option allows to rename the selected step. Selecting it opens a text input field at the top of the step's representation box. Starting with expecco2.8, multiline step names are possible by separating the lines with a "\" (backslash) character. A double-click on a step opens an attributes dialog, in which the name can also be edited.Notice that steps which have never been given an explicit name will always show the name of their underlying action block (from the tree) as their name. Thus, the name of a step will follow any changes done there. However, once renamed, the step's name will remain whatever has been entered here. To enforce the old state where the step's name follows the action's name, rename and enter an empty name (i.e. select and cut the name in the rename-field). 
- Special Pins
 This sub menu allows adding special pins for the selected step. For more information see: Pin
Controlling Execution[Bearbeiten]
- Execution
 This sub menu provides several execution related options. Its functions include the switching of special trigger types, parallelism settings, and execution modes.
- Autostart
 This check box allows to switch the autostart mode on or off. Steps with this option on are started automatically each time the work flow is executed. You can recognize them by the yellow flash symbol on the top left of the step's representation box.
 
- Autostart
- Sequential Execution
 This option interconnects the selected steps for sequential execution. The steps will be connected in the order they were selected.
 
- Sequential Execution
- Breakpoint
 This check box allows to set or remove a breakpoint for the selected step.
 
- Breakpoint
- Immediately fork new Activity-process
 This check box serves to switch the fork new activity thread mode on or off. When this option is checked, an activity will immediately executed in a parallel thread; if it is off, the executor gives the block some time to execute sequentially, and later starts a new thread. To indicate that immediate-fork mode is on, a parallelism symbol is displayed at the top right of the step's representation box, but only if there is at least one triggering input pin or a direct trigger pin connected, or autostart activated.
 
- Immediately fork new Activity-process
- Limit Parallelism To...
 This option is used to adjust a maximum number for the activities executed in parallel. When selected, a dialog box opens up, asking to input the maximum number.
 Initially, no limit is set. If a limit is specified in the dialog, the number appears to the top right of the step's representation box, but only if there is at least one triggering input pin or a direct trigger pin connected, or autostart activated.
 
- Limit Parallelism To...
- Unlimited Parallelism
 This option is the counterpart to the 'Limit Parallelism To...' option. It is only available when a limit is adjusted for the selected step, and annuls this limitation.
 
- Unlimited Parallelism
Controlling Logging and Tracing[Bearbeiten]
- Logging
 This submenu provides several options to control the activity-log/trace. Its functions include the disabling of the log unconditionally, if finished with success or without success or if executed in a loop. Both the step itself and/or subactivities of the step can be controlled. The disabling of log/trace information may be required for long running test suites, to prevent reaching any memory limits (and also, to make the activity log more readable).
- Skip
 if this attribute is set, the activity will never be logged/traced. This function is also available via the editor's toolbar.
 
- Skip
- Skip If Successful
 if this attribute is set, the activity will not be logged/traced if the step was executed successfully.
 
- Skip If Successful
- Skip If Not Successful
 if this attribute is set, the activity will not be logged/traced if the step was executed unsuccessfully.
 
- Skip If Not Successful
- Skip If Looped
 if this attribute is set, the activity will not be logged/traced if the step was executed in a loop.
 
- Skip If Looped
- Skip Subactivities
 if this attribute is set, the activity's subactivities will never be logged/traced. This function is also available via the editor's toolbar.
 
- Skip Subactivities
- Skip Subactivities If Successful
 if this attribute is set, the activity's subactivities will not be logged/traced if the step was executed successfully.
 
- Skip Subactivities If Successful
- Skip Subactivities If Not Successful
 if this attribute is set, the activity's subactivities will not be logged/traced if the step was executed unsuccessfully.
 
- Skip Subactivities If Not Successful
- Skip Subactivities If Looped
 if this attribute is set, the activity's subactivities will not be logged/traced if the step was executed in a loop.
 
- Skip Subactivities If Looped
The user settings dialog ("Settings" -> "Execution" -> "Logging") contains a flag named "Ignore all Skip in Trace Attributes", which enforces trace information to be logged, even for steps with one of the above attributes. This is very useful for debugging, to force the generate a full trace - even for suites which contain steps with suppressed logs.
- Operations
 This sub menu provides several options for step substitutions. This includes replacing, substituting and expanding of single steps or compounds of steps.
- Replace By...
 This option replaces an existing step within the current diagram by a substitute step of a block to be chosen. To chose the substitute block, a dialog containing a selection list is opened, showing either all blocks available in the test suite, or only those which pins numbers are the same as that of the block to be substituted. This can be switched with the dialog's button which accordingly displays either "Blocks with same Number of Pins ..." or "All Blocks ...".
 If the substitute step has less pins on a side than the one to be substituted, existing connections are kept only up to the number of pins of the new step. Connections between newly incompatible pin types are also lost.
 
- Replace By...
- Make New Compound Block...
 This option allows to replace whole compounds of the diagram by an automatically generated new compound block, which then contains all the steps that were selected, when necessary creating additional input and output pins to keep the wiring semantics unaffected.
 
- Make New Compound Block...
- Make New Web Parameter Block...
 This option allows to replace whole compounds of the diagram by an automatically generated new web parameter block, which then contains all the steps that were selected and has a special pin to read parameters from for example a csv file. This can be useful e.g. to fill in form.
 
- Make New Web Parameter Block...
- Expand Compound Step...
 This option is kind of the counterpart to the previously described 'Make New Compound Block ...' option. It duplicates all internal Steps inside the selected Step's Internal Network, and inserts the complete duplicate set in the left area of the work flow Editor's view. It does not only duplicate the Steps, but also the wiring, and the Step's attributes (triggers, pin settings, execution settings etc.). The selection changes upon the inserted Steps, so they can be moved to a fitting location collectively.
 
- Expand Compound Step...
- Add Input...
 This option allows the creation of additional input pins for the selected step. You will be asked to enter a name and a data type for the new pin.
 
- Add Input...
- Add Output...
 This option allows the creation of additional output pins for the selected step. You will be asked to enter a name and a data type for the new pin.
 
- Add Output...
- Attributes...
 This option allows to change different attributes like the color for single steps.
- References...
 This option shows all references on the selected step. For example its block description.
- Add Extra Page on Selected Item
Pin Specific Options (Context Menu)[Bearbeiten]
When an input pin is selected in the editor:
- Freeze (as)
 This option applies to all data input pins and trigger Input pins, except for the cancel pin. The identifier of the data type in the menu entry differs depending on the data type of the pin. It allows, for most standard data types, presetting the input value according to the data type, by typing a valid value into a text input field.
- Read from Environment Variable...
 This option applies to all data input and some trigger input pins. The option is only available if the selected pin is not connected to any value delivering output pin. Selecting this option causes a dialog to open up, allowing specifying the environment variable's name in a text input field. For more information see: Environment Freeze Value
- Unfreeze
 This option applies to all data input and trigger input pins, but is only available if the selected pin is frozen to a value or to an environment variable. No matter if the pin was preset with a direct value or with an environment variable, the preset information will be lost, and the pin is connect able to adequate output pins again.
- Show Data-type
 This option opens a view which shows the pin's data type.
- Parameter
 This check box applies to data input pins only. If checked, the pin will not be comprised in the triggering function for the data input pins. For more information see: Input Pin
- Limit Basket Buffer To...
 This option applies to all data input pins. Selecting this option causes a dialog to open up, allowing specifying the (integer) maximum number of values that the pin should keep in a buffer before suspending subsequent value delivering activities. After entering a valid number and confirming with "OK", the pin is limited to that number, which is indicated by displaying the number to the left top of the pin, as depicted to the right.
- Unlimited Basket Buffer
 This option applies to all data input pins, but only appears if the selected pin has a basket buffer limit set. In this case, selecting this option will clear the limit, and the pin appears without a limit indication again.
When an output pin is selected in the editor:
- Buffered
 This check box applies to data output pins only. It serves to switch the buffering mode of the pin on or off. For more information see: Output Pin
Connection Specific Options (Context Menu)[Bearbeiten]
When a connection is selected in the editor:
- Disconnect
 This option simply removes the connection.
- Recompute Connection
 This option initiates an automatic re-layout of the connection's edges. There is no guarantee that this will meet your expectations. However, trying it is low risk, because the change can be immediately undone with the "Undo" option.
- Split Segment
 This option causes the selected connection to split into multiple parts. By this, you get four additional edges which are each individually transposable.
- Join Segments
 This option is the counterpart for the "Split Segments" option. It joins previously split connections.
- Arrow
 This check box allows to switch arrows on and off which help to keep track of the connection's direction.
- Disable Type-check (force Valid)
 This option disables the type check. So every input pin can be connected with any output pin regardless of their data types.
Keyboard Shortcuts[Bearbeiten]
- Ctrl-s
 "Save"; same as clicking on the "Accept" or "Save" button. Makes the changes made to the diagram permanent (i.e. installs the new version of the action in the project tree)
- Ctrl-c
 copy the selected element(s) into the clipboard (for paste)
- Ctrl-x
 cut the selected element(s) and place into the clipboard (for paste)
- Ctrl-v
 paste element(s) from the clipboard; if a pin is selected, the freeze value is set
- Del
 delete the selected elements (without placing them into the clipboard)
- Ctrl-z
 undo the previous edit operation
- Ctrl-a
 select all
- Ctrl-e
 select to end (i.e. all below)
- Tab
 select the next step which is below/right-of the selected one; wraps around to the first at the end
- Shift-Tab
 select the previous step which is above/left-of the selected one; wraps around to the last at the beginning
- Cursor Up
 if a non-pin is selected:moves the selected element(s) up (by one grid step). If Shift is also pressed, the element(s) are moved by 8 grid steps.
 If a pin is selected, the previous pin is selected.
- Cursor Down
 similar, but moves the selected element(s) down.
- Cursor Left
 similar, but moves the selected element(s) to the left.
- Cursor Right
 similar, but moves the selected element(s) to the right.
- Ctrl-Cursor Up
 moves the selected pin up in the action's schema.
- Ctrl-Cursor Down
 moves the selected pin down in the action's schema.
- Ctrl-n
 opens the "New Step" dialog to select an action and place a step for it
- Ctrl-N
 opens the "New Action" dialog to define a new action block in the tree and place a step for it
- Ctrl-r
 opens the "Replace Step" menu to select an action and replace the selected step by it
- Ctrl-R
 replace the selected step by the step in the clipboard
- F2 ("Rename")
 opens the "Rename Step" menu, asking for a new name for the selected step
- Ctrl-t
 adds a "New Text Annotation" (not really needed: just type on the background)
- Ctrl-g
 opens the "New Graphic Annotation" menu to select a bitmap image and place it as an annotation
- Ctrl-p
 toggles the selected pin's "Parameter-Pin" attribute.
- Ctrl-e
 freezes the pin from an environment variable.
- Return
 adds an extra editor-page on the selected step's action to the browser window
- Alt-^
 if a connection is selected: adds arrows to all of the connection's segments.
 If no connection is selected and the mouse-pointer is above a segment, that segment's arrow-indicator is toggled.
- Ctrl +
 zoom in
- Ctrl -
 zoom out
Tasks[Bearbeiten]
Adding Steps[Bearbeiten]
When a block is dropped into a diagram (from the project tree view on the left, via the popup menu, via a Ctrl-n shortcut or by copy-paste), a so-called "step" is created. A rectangular box appears, which represents the newly created step. The step is initially selected, indicated by the red outline. Selected items always appear outlined with the selection color, which is red by default, but can be changed in the settings.
Usually, when creating steps, they are initially displayed with a red exclamation mark symbol at the top right of the representation box. This indicates that the step as it is currently set up, would not run when the diagram is executed. This is the case if the step has no triggering data inputs connected, no trigger input, and also no autostart flag activated. If neither of those is the case, the step has no trigger, will not run and is therefore marked in this manner. It is usually (but not necessarily) not intended to have such passive (unexecuted) steps in a diagram. However, sometimes you may want to leave them in a diagram for documentation purposes, or for quick and dirty test actions in a playground.
Steps can be added to the activity diagram either by drag & drop, via the popup menu, by copy-paste or via the action selection dialog (keyboard shortcut Ctrl-n).
To use drag&drop, drag one ore more items from a navigation tree and drop them into the network editor's display area. If multiple blocks are selected in the navigation tree, they can be dragged in one motion all together.
Be aware that the navigation tree of the browser serves both as a source for drag AND to select the block to be edited. If you select AND keep holding down the mouse button, this initiates a drag&drop operation. If you simply click and release the mouse button, this performs a select operation (and you may end up in another diagram).
It is therefore sometimes difficult to use this one single tree as a drag source, and it is a therefore good idea to tear off a separate floating navigation tree or to split the navigation tree into one for navigation, and another for drag&drop. Floating and split windows do not affect the selection, but serve solely as a drag&drop source.
To use the popup-menu, select one of the "New Step" menu items. You can either have an existing action block placed or create a new action. If an existing action is chosen, a dialog pops up, asking for the type of action to add. There are a number of filter options, to help finding the right action in bigger test suites.
For new actions, a corresponding new item is automatically created as empty action in the left navigation tree.
A very useful function is "Place New Step and Connect". This is enabled if you have a number of pins of existing steps already selected. It will offer a list of matching steps that are useful with that pin selection (i.e. the number of pins and their data types must match).
All of the menu-initiated step creation functions allow for the action to be chosen from a filtered list of available actions. The filter operates by looking at the name and tag(s) of the actions. If multiple filtering words are entered (separated by semicolons), only actions which contain ALL of those string match patterns will be shown. For example, to get a list of all selenium actions which deal with text validation, enter a filter string like "selenium;text".
Block descriptions that are tagged as "obsolete" will never be shown in the popup-menus.
Finding Useful Seps[Bearbeiten]
Press Ctrl-n (or select the corresponding right-click menu item) to get a "New Step"-dialog.
If you have an idea of how it might be named, enter that in the top name field search area. For example, "string", "dialog", "convert", etc. are usually good for searching. You can add multiple such name fragments, separated by ";" (semicolon). If a pin is selected initially (to which you want to connect the new step), the search can be limited to actions which have matching pin types. I.e. if you have an output pin with "String"-type selected, only actions which take a string as input will be shown. The type-matching can be disabled via a check toggle. You can also have multiple in/outputs selected, to search for actions which have a corresponding set of matching out/inputs.
If you have no idea about how the action might be named, you can use the advanced "Search-by-Result" feature, found in the "Action Finder". This is opened via the button at the top-right of the "New Step" dialog. The "Action Finder" lets you give input values and an expected output value, and it will search for actions which would produce that result. For example, if you search for an action to perform a string search, enter both a longer string, and part of it as inputs, and give the expected result - such as "true" as expected output. In this case, the Action Finder will find actions which detect that partial string ("'Includes String"). If you give a position as expected result, it will find the "Index in String" action.
Selecting Steps[Bearbeiten]
Steps are selected by a left-click. Additional steps are selected by holding down the Shift-key in conjunction to the left mouse button: similar to text selection, all steps between the previously selected one and the new clicked step are selected (in a top-left to bottom-right fashion). In a similar way, pressing the Control-key (Ctrl or Strg) toggles steps into or out of the selection.
Another possibility to select multiple steps at a time is to mark a selection rectangle area with the mouse ("lasso"), which selects all steps (and other elements) that are within that area. You have to click outside of any step (in the background area) to start a lasso selection. If you have many attachments or background graphics in your diagram, it may become hard to find an unoccupied background area. For this, you can toggle the visibility of all annotations, to get them "out of the way".
Finally, pressing Ctrl-a selects all elements of the diagram, and Ctrl-e selects the steps below the current selected step. These are useful to reposition all or bigger parts of the diagram within the page (for example, to make more space at the top).
Arranging Steps[Bearbeiten]
To move steps to a different location, you can click on it, hold the button, and move it with the mouse. While moving, an equally sized shadow box shows where the new position would be. Selected steps can also be moved via the cursor keys.
If the clicked step was not selected yet when picking it, it will be selected and moved solely. If, on the other hand, the clicked step was part of a current multi selection, the whole selection is picked and moved, including all connections between them.
When you place steps outside the current diagram boundaries, these will automatically be extended to fit the new position of the moved steps.
Additional arrangement-functions (spreading, aligning etc.) are found in the context-menu and the tool bar menu.
Interconnecting Pins[Bearbeiten]
Steps exchange data and control information via connected pins.
To create a connection, click on one of the two pins you want to interconnect, keep the mouse button pressed, and move the mouse to the other pin. To keep track of what you do, a rubber-band line is drawn from the starting pin to your mouse position. The mouse-symbol is changed to a "thumb-down" while over an invalid target pin, and the reason for being an invalid connection is shown in the lower info area. The mouse changes back to a regular arrow, when it reaches a valid partner pin. When you release the mouse button over a valid target pin, a rectangular connection will automatically be created. If the target pin is not suitable for the operation, no connection is created.
Note that interconnecting pins underlies certain restrictions:
- You cannot connect an output pin to another output pin, nor an input pin to another input pin. However, the editor implements a very useful and noticeable UI scheme, in that it connects the input to the "SAME" output or value as the connected to input. (1).
- Inside the network, the roles of the compound actions input/output pins are reversed (i.e. the compound's input pins are treated like outputs inside the network).
- You can only interconnect input and output pins that have compatible datatypes. Usually, you interconnect pins of the same data type, or to a related data type, like an integer output to a float input. An input pin with the "any" data type can be interconnected to any other pin, but not vice versa; an "any" output pin can only be connected to another "any" input pin, unless you add a cast or conversion step in between (2). In some situations, this type restriction may be too strict, and you want to connect pins, even if the types do not match. This happens, when pin types have been declared too strict on the input side or too generic on the output side. For example, a block generating values of type "Number" is too generic for an input which accepts only "Integers" (because other numbers may not be handled correctly). You can disable the type check and force a connection by pressing the Ctrl key while connecting two pins. The connection will be shown as a dashed line, to remind you, that this may cause trouble. By selecting "Disable Type Check" via the connection's right-button menu, you can tell the system that your types are OK, and it should no longer be shown as dashed line.
In principle, you can only connect output pins to input pins, because the intention of a connection is to pass output values from an output to an input. However, an attempt to connect two outputs lets the editor search for the corresponding input pin and create a valid input-output connection.
You are not bound to the wiring arrangement as it is created automatically. Instead, you can click on a connection to select it, and then move each of its edges individually to a different ordinate. However, the connections will be automatically laid out again when you move or substitute a step which is involved in this connection.
To transpose an edge (i.e. resize a step), left-click on the edge, hold the button down, and then drag the edge to the desired position. During motion, a ghost line is drawn to keep track of what you are doing.
You can also add new edges to the connection, by selecting it, right-clicking the edge into which a new angle branch shall be inserted, and the choosing the "Split Connection" option from the context menu.
There is one more special display mode for connections: If a connection already exists, but a later data type change to either the input or the output pin violates the data type compatibility of the connection, the connection will be drawn as a dotted line (i.e. marked as "invalid"). It can be edited like before, but remains marked as invalid until the data type compatibility is restored in any valid manner.
1) If you try to connect two inputs, the connection will be done to the already connected output. This makes it easier to place and connect more actions to an existing output if the diagram is big and the output is far away. If the target pin is frozen, the originating input will take over the same freeze value.
2) An "unsafe" connection can be created by pressing the Ctrl key during the connect. This creates a non-type-safe connection. Use this with care, for a temporary workaround, until either a pin's type has been changed, or an appropriate converter has been added.
Adding Annotations[Bearbeiten]
Textual and bitmap annotations (notes) can be placed into the diagram to provide additional information for and commentary. Use the popup-menu's "New Annotation" entry, and change the annotation's attributes as required. See Annotations for attributes of an annotation.
Hints and Tricks[Bearbeiten]
Skip in Trace Flags[Bearbeiten]
Often you are not interested in all execution details - especially if some compound is executed with success, a full log of all underlying subactivities is often not needed. You can adjust the generated log both on the step and on the action level via flags from the "Logging" context menu.
A suggested setting is "Skip SubActivities if SuccessFul", which will only generate the trace if the containing action finishes without success. Notice that the decision to keep sublets is made when the containing activity finishes - thus, if you have a long running action, a huge number of logs may have also been generated.
For this situation, use "Skip Successful Subactivities", which will skip subactivities as soon as they finish. 
Using Colors[Bearbeiten]
You can highlight the main path through a network by giving the steps along it a different color from other helper steps, for example, logging or error handling steps. Or vice versa, if you prefer. Also, connections can be given different color, depending on their semantic meaning (again, a typical example is to colorize error handling paths with a reddish color).
Using Annotations as Background[Bearbeiten]
You can use an arbitrary background image and place your diagram elements above it. Typical uses are company frames with logo, design and architecture pictures or other useful graphics which emphasizes on the structure of the network.
Using Empty Annotations as Background Boxes[Bearbeiten]
You can also use empty rectangular text-annotations to group steps into functional groups (or example: data preparation, communication, validation).
To do this, enter a space as text annotation, then resize the annotations's box, then give it a background color via its attributes. If boxes are reused often, copy-paste them from another (template) diagram.
Select a Pin for Automatic Connection[Bearbeiten]
If you have a pin selected when a new step is dropped, pasted or created via the Ctrl-n dialog, and the new step has a compatible pin, these two pins will be automatically connected.
Select a Connection to Insert a New Step into the Flow[Bearbeiten]
If you have a conenction selected when a new step is dropped, pasted or created via the Ctrl-n dialog, the new step will be inserted into the selected connection (if possible due to type restrictions).
Select a Step for Automatic Trigger Connection[Bearbeiten]
If you have a step selected when a new step is dropped, pasted or created via the Ctrl-n dialog, the new step will be connected via a triggerOut-triggerIn connection.
Select two Steps for Automatic Trigger Connections[Bearbeiten]
If you have two steps selected when a new step is dropped, pasted or created via the Ctrl-n dialog, the new step will be inserted into the execution sequence to be triggered by the first and then trigger the second selected step.
Embedding a Pin Value in the Step's name[Bearbeiten]
If the step's name includes a "%i" character sequence, the i'th input pin value is sliced into the name in the activity log. Thus, a name like "My Step (test run %1)" will, if the first input pin got a numeric value like "10", be printed as "My Step (test run 10)" in the log file.
Additional expansion keywords are: %(START), %(END) and %(STATE) to embed the step's start-time, end-time and result-state. Notice the parentheses around the keywords.
Finding all Connections to/from a Pin[Bearbeiten]
Click on a connection near the input or output pin (on the first or last connection segment), while holding the Shift-Key.
Hiding Connections in Complicated Diagrams[Bearbeiten]
You can change a connection's type to "hidden". Use this to make diagrams easier to read, especially when you have many consuming input pins connected to a single source pin. The connection's endpoints will be shown when the mouse pointer is hovering a pin or if either endpoint pin is selected, but hidden otherwise.












