Scheme Editor/en: Unterschied zwischen den Versionen
| Cg (Diskussion | Beiträge) | Cg (Diskussion | Beiträge)  | ||
| (46 dazwischenliegende Versionen von 2 Benutzern werden nicht angezeigt) | |||
| Zeile 23: | Zeile 23: | ||
| Special pins are added with the "''Special Pins''" menu, and removed by selecting the pin and deleting it (via key or menu). | Special pins are added with the "''Special Pins''" menu, and removed by selecting the pin and deleting it (via key or menu). | ||
| These special pins are described in [[DiagramElements-Pin/en#Special_Pins_of_Script_Action_Blocks | "Special Pins of Script Action Blocks"]] and also in [[Expecco_Scripting_API | "Expecco Scripting API"]] | These special pins are described in [[DiagramElements-Pin/en#Special_Pins_of_Script_Action_Blocks | "Special Pins of Script Action Blocks"]], [[DiagramElements-Pin/en#Special_Pins_of_Bridged_Action_Blocks | "Special Pins of Bridged Action Blocks"]]  and also in [[Expecco_Scripting_API | "Expecco Scripting API"]] | ||
| ⚫ | |||
| === Renaming of Pins === | === Renaming of Pins === | ||
| The name of a pin can be changed (*) by clicking on the name field, which then turns into an input text field. There, type in a new name for the pin. The pin will be renamed when either the Enter key is pressed, or the input field is left (i.e. clicking on any other element in the editor). | The name of a pin can be changed (*) by clicking on the name field, which then turns into an input text field. There, type in a new name for the pin. The pin will be renamed when either the <kbd>Enter</kbd> key is pressed, or the input field is left (i.e. clicking on any other element in the editor). | ||
| The Escape key cancels the rename operation. | The <kbd>Escape</kbd> key cancels the rename operation. | ||
| For a subset of the supported programming languages, the editor will rewrite the code to use the new name. | |||
| ⚫ | |||
| ⚫ | |||
| ===== Restrictions on Pin Naming for Elementary Blocks ===== | ===== Restrictions on Pin Naming for Elementary Blocks ===== | ||
| In elementary blocks, pin names are not only used for description purpose but also to access the pin's value in the action's source code (i.e. for actions written in a textual programming language). Therefore, some naming restrictions apply to ensure that the pin name represents a valid identifier in the block's code (i.e. it must be a valid variable identifier in the programming language of the action's code, which can be JavaScript, Smalltalk, Groovy etc.).  | In elementary blocks, pin names are not only used for description purpose but also to access the pin's value in the action's source code (i.e. for actions written in a textual programming language). Therefore, some naming restrictions apply to ensure that the pin name represents a valid identifier in the block's code (i.e. it must be a valid variable identifier in the programming language of the action's code, which can be JavaScript, Smalltalk, Groovy, Python, C etc.).  | ||
| In practice, the identifier should be a sequence of letters, digits or the underline character (_), where the very first character should not be a digit. It may also not be a keyword of the language (i.e. "<code>function</code>" in Groovy, "<code>if</code>" in JavaScript or "<code>self</code>" in Smalltalk).  | In practice, the identifier should be a sequence of letters, digits or the underline character (_), where the very first character should not be a digit. It may also not be a keyword of the language (i.e. "<code>function</code>" in Groovy, "<code>if</code>" in JavaScript or "<code>self</code>" in Smalltalk).  | ||
| Such restrictions do not apply to compound blocks; however, if you ever plan to convert or generate elementary code, it is a good idea to restrict your naming there too. | |||
| ===== Restrictions on Pin Naming for JavaScript and Groovy Elementary Blocks ===== | ===== Restrictions on Pin Naming for JavaScript and Groovy Elementary Blocks ===== | ||
| Zeile 40: | Zeile 46: | ||
| It is a good practice to name pins as "''inPin1''" or "''textPin''" or "''xxxPin''" in general, to avoid such conflicts right from the beginning. Such naming convention also make the code more readable, as it reduces chances for confusing the name of a pin with a name of a variable used for a pin's data value (remember: in the code, the pin-name refers to the pin - not the pin's value). | It is a good practice to name pins as "''inPin1''" or "''textPin''" or "''xxxPin''" in general, to avoid such conflicts right from the beginning. Such naming convention also make the code more readable, as it reduces chances for confusing the name of a pin with a name of a variable used for a pin's data value (remember: in the code, the pin-name refers to the pin - not the pin's value). | ||
| ===== Restrictions on Pin Naming for Other Languages ===== | |||
| Similar restrictions apply to the other supported languages (Python, C, etc.). | |||
| === Edit Functions for Existing Pins === | === Edit Functions for Existing Pins === | ||
| For all other pin operations, the pin to be modified has to be selected first.  | |||
| ⚫ | |||
| To select a pin, click on it with the left mouse button.  | |||
| ⚫ | You can select multiple pins: keep the <span style="box-shadow: 1px 1px 2px rgba(0,0,0,0.3);"><kbd>Ctrl</kbd></span> key down while clicking, to toggle the pin into or out of the selection. Press the <kbd>Shift</kbd>-key while clicking to select all pins in between the previously selected pin and the clicked-on pin. | ||
| You can also select multiple pins with a rectangle-drag operation (click outside, keep holding the mouse button, and drag to the other corner, to select all pins inside the rectangle). | |||
| The selected pin(s) will appear highlighted in a red color. | The selected pin(s) will appear highlighted in a red color. | ||
| Zeile 48: | Zeile 64: | ||
| === Setup / Change Datatype === | === Setup / Change Datatype === | ||
| Each pin has a [[Datatype|data type]] attribute that determines which kind of data is expected or generated by the pin. Every new pin initially gets the data type that was last used; initially the [[Datatype#General_Types|data type "Any"]] is assigned by default. This type is also used as default, whenever no other reasonable data type can be predicted. The pin's data type is displayed beside the pin, outside of the representation box. The data type for a pin can be changed in the context menu, through its "''datatype''" sub-menu, which brings up a list of available types.  | Each pin has a [[Datatype|data type]] attribute that determines which kind of data is expected or generated by the pin. Every new pin initially gets the data type that was last used; initially the [[Datatype#General_Types|data type "Any"]] is assigned by default. This type is also used as default, whenever no other reasonable data type can be predicted. The pin's data type is displayed beside the pin, outside of the representation box. The data type for a pin can be changed in the context menu, through its "''datatype''" sub-menu, which brings up a list of available types.  | ||
| Note that when you have already placed [[DiagramElements-Step|step]] instances of the modified action block in any activity diagram, a change in the data type of a pin may affect existing connections in which the pin is involved. If the new type is incompatible with a connection, it is drawn as dotted line in the diagram, or when a preset value becomes incompatible, the value is displayed in a red color. | |||
| === Default Values for Pins === | === Default Values for Pins === | ||
| Zeile 88: | Zeile 106: | ||
| :This option 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. | :This option 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. | ||
| ;Parameter (Non Consuming;Non Triggering) | ;Parameter (Non Consuming; Non Triggering) | ||
| :This option determines whether the select input pin is a parameter pin. For more information see: [[DiagramElements-Pin#Input Pin | :This option determines whether the select input pin is a parameter pin. For more information see: [[DiagramElements-Pin#Input Pin|Diagram Elements - Input Pin]]. | ||
| ;Telegram (Non Consuming;Non Triggering;Deliver While Executing) | ;Telegram (Non Consuming; Non Triggering; Deliver While Executing) | ||
| :This option determines whether the selected input pin is a telegram pin. For more Information see: [[DiagramElements-Pin# | :This option determines whether the selected input pin is a telegram pin. For more Information see: [[DiagramElements-Pin/en#Telegram_and_Mailbox_Pins|Telegram Pin]]. | ||
| ;Buffered | ;Buffered | ||
| Zeile 107: | Zeile 125: | ||
| ====Special Attributes==== | ====Special Attributes==== | ||
| =====Input Pins===== | |||
| The input pin behavior can be controlled in more detail here. Individual control of the triggering/non-triggering, consuming/non-consuming and | The input pin behavior can be controlled in more detail here. Individual control of the triggering/non-triggering, consuming/non-consuming and | ||
| buffered/passed-through attributes is offered here. | buffered/passed-through attributes is offered here. | ||
| ;Consuming / Non-Consuming | ;Consuming / Non-Consuming | ||
| :This option determines whether the input pin consumes its input value from the input basket or leaves it. Non-consuming pins are sometimes required, when the step is executed in a loop, and the input value should be reused for each iteration. Also, frozen parameter pins should be defined as non-consuming, as otherwise, the freeze value is only available once (in the first loop iteration) | :This option determines whether the input pin consumes its input value from the input basket or leaves it. Non-consuming pins are sometimes required, when the step is executed in a loop, and the input value should be reused for each iteration. Also, frozen parameter pins should be defined as non-consuming, as otherwise, the freeze value is only available once (in the first loop iteration). | ||
| :More info in: [[DiagramElements-Pin#Consuming_vs._Non-Consuming | Diagram Elements-Pin]]. | |||
| ;Triggering / Non Triggering | ;Triggering / Non Triggering | ||
| :This option determines whether the input pin is considered in the action triggering process or not. Triggering pins must have a value present in order for an activity to be created. Non-triggering pins are not | :This option determines whether the input pin is considered in the action triggering process or not. Triggering pins must have a value present in order for an activity to be created. Non-triggering pins are not. | ||
| :More info in: [[DiagramElements-Pin#Input_Pin_Trigger_Attributes | Diagram Elements-Pin]]. | |||
| ; Mailbox / Non-Mailbox (also called "''Telegram Pin''") | ; Mailbox / Non-Mailbox (also called "''Telegram Pin''") | ||
| :This option determines whether the selected pin is a telegram pin.  | :This option determines whether the selected pin is a telegram pin. Normal pins "latch" their input value when the action is triggered and provide that value to internal steps (be aware, that it might be consumed). If another value arrives at the pin while it is beeing executed, another activity will be started to process the next value. | ||
| :Mailbox pins behave differently: any value arriving there will be forwarded to inside connected steps. Mailbox pins are most useful to implement a controlled cancel operation (eg. by setting a variable inside, which stops a loop). | |||
| :For more Information see: [[DiagramElements-Pin#Telegram_and_Mailbox_Pins| Diagram Elements-Pin]]. | |||
| =====Output Pins===== | |||
| ⚫ | |||
| ;Buffered / Unbuffered | |||
| :Buffered outputs will send their value(s) when the action has finished with success. Unbuffered outputs will send any value immediately (and thus may trigger other actions while this action is still executing). | |||
| :For more Information see: [[DiagramElements-Pin/en#Output_Pin_Buffer_Attribute| Diagram Elements-Pin]]. | |||
| =====Variable Number of Pins===== | |||
| :This option sets the "''Variable Number''" attribute for the last pin. If checked, the number of pins can be changed in the step, and the last schema pin can be "replicated" an arbitrary number of times. This option is only possible for elementary actions, and the elementary code must be written to access this pin pin with a pin index. See also in [[DiagramElements-Pin/en#Variable_Number_of_Pins | Diagram Elements - Variable Number of Pins]]. | |||
| ⚫ | An input and output pin can be specified as a "variable pin". Such a pin appears in the block description (the schema) as a single pin, but it can be instantiated multiple times in one step. In other words, the number of these variable pins can be defined individually for each step. Variable pins are marked with a small plus sign. | ||
| ;Variable Number of Remaining Pins in Steps | |||
| :This is a new feature of the 2.8 version of expecco. Similar to the above "''Variable Number''" of the last pin, this defines a group of pins to be possible repeated in the step. If checked, the number of pins can be changed in multiples of the group size in the step, and the N-last schema pins can be "replicated" an arbitrary number of times. This option is only possible for elementary actions, and the elementary code must be written to access this pin pin with a pin index. See also in [[DiagramElements-Pin/en#Variable_Number_of_Pins | Diagram Elements - Variable Number of Pins]]. | |||
| Variable pins can only be the last pins, which are combined into a variable pin group. This pin group can be "replicated" in steps as often as required. Individual pins within a group can have different data types, and the replicated pins adopt the data type of their corresponding pin from the schema definition of the action. This is very useful for defining “multi-key-value” groups, e.g. for multi-setter actions of collections or user data objects. | |||
| '''This option is only possible for elementary actions and the elementary code must be written to access these pins with a pin index.''' | |||
| ;Defining the variable pin group | |||
| :In the context menu of a pin, the start of the variable pin group can be set via the sub menu <code>Special attributes</code> - <code>Start Variable Pin Group here</code>. The selected pin and the following pins become variable pins, the pins before them become or remain fixed pins.  | |||
| :This function can also be used to subsequently move the start of the pin group. | |||
| ;Remove the variable pins. | |||
| :Context menu of a variable pin via the sub menu <code>Special attributes</code> - <code>Convert all Variable Pins to Fixed Pins</code>: This converts all variable pins to fixed pins. | |||
| ;Equal Number of Variable Input and Output Pin Groups | |||
| :If a variable pin group is defined in the input and output pins, the number of pin groups can be synchronized. The number of replications of the input and output pins is the same.<br> | |||
| :<code>Special attributes</code> - <code>Equal Number of Variable Input and Output Pin Groups</code> | |||
| See also in [[DiagramElements-Pin/en#Variable_Number_of_Pins | Diagram Elements-Pin - Variable Number of Pins]]. | |||
| == Action == | == Action == | ||
| Zeile 192: | Zeile 236: | ||
| == Declaring Semantic Attributes == | == Declaring Semantic Attributes == | ||
| The block's pop up menu also allows for a number of semantic attributes to be defined for the action. | The block's pop up menu also allows for a number of semantic attributes to be defined for the action. Some of them are informal/documentation, others are used by the system to optimize excution or to help the expeccoALM/AIDYMO scheduler. In any case, they are optional, and they are not obligatory. | ||
| ⚫ | |||
| ⚫ | |||
| Currently, semantic attributes are: | Currently, semantic attributes are: | ||
| ;Blocking (Immediately Start new Activity Process) | ;Blocking (Immediately Start new Activity Process) | ||
| :Tells the executor, that this action may block for a noticeable time | :Tells the executor, that this action may block for a noticeable time; for example if it reads from an external stream (typically a socket), or by opening a user-dialog, or by waiting for some other external event.<br>By default, the executor will wait for some grace period and then start another execution thread to continue processing other action blocks. However, this grace period may be too long (a few seconds, by default) and the overall execution time may be shortened, if this is done immediately.<br>Of course, this only makes sense if it is known in advance, that this action will block the executor, and that there might be other activities to be executed in parallel. It also only makes sense if the time it takes to start another execution thread (which does involve some overhead) is shorter than the expected wait time.<br>Notice also, that this flag can also be set for individual steps - and it is usually a better place to set this flag. | ||
| ;Operator Required | ;Operator Required | ||
| :Informational flag that the action needs operator assistance. Please set this flag if a containing action opens a UI dialog, or otherwise needs an operator assistance. This will help to identify test cases which can be run without operator assistance. You can find blocks with inconsistent "''Operator required''" setting in the "''Special''" test suite search. If the "''Operator Needed''" Flag missing option is enabled all those blocks will be listed. The operator required flag can be validated against a test case's "''Operator Required''" flag, which is actually used by QM systems to effectively schedule tests which require human personal. | :Informational flag that the action needs operator assistance. Please set this flag if a containing action opens a UI dialog, or otherwise needs an operator assistance. This will help to identify test cases which can be run without operator assistance. You can find blocks with inconsistent "''Operator required''" setting in the "''Special''" test suite search. If the "''Operator Needed''" Flag missing option is enabled all those blocks will be listed. The operator required flag can be validated against a test case's "''Operator Required''" flag, which is actually used by QM systems to effectively schedule tests which require human personal. | ||
| ⚫ | |||
| ⚫ | |||
| ;Functional | ;Functional | ||
| Zeile 222: | Zeile 267: | ||
| :Hint for the code generator, that the elementary code may write any of the output pins more than once. The code generator will create data queues for the output pins. Also, the error checker makes use of this flag, when looking for input values being consumed in a loop or consumed multiple times even if only written once. | :Hint for the code generator, that the elementary code may write any of the output pins more than once. The code generator will create data queues for the output pins. Also, the error checker makes use of this flag, when looking for input values being consumed in a loop or consumed multiple times even if only written once. | ||
| Notice: these flags  | Notice: these flags should only be set if you know what you are doing and how the elementary code behaves. In a future version, a more advanced code analysis might be added, which may make these flag settings obsolete. If in doubt, leave these flags unchanged (the worst thing that happens in this case, is that any generated elementary code executes slightly slower, and that the error checker finds less errors). | ||
| == Execution Debugging Attributes == | == Execution Debugging Attributes == | ||
| The debug  | The debug submenu allows for additional debug checks to be defined for the action: | ||
| and to define additional debug checks: | |||
| ;Assert Executed | ;Assert Executed | ||
| :Adds a check to the executor, that any step of this kind must be executed if present inside a compound action's diagram. | :Adds a check to the executor, that any step of this kind must be executed if present inside a compound action's diagram.<br>If a compound action which has such a step in its activity diagram, finishes execution and that step was not executed, an error is reported.<br>Use this, to ensure that verifying actions which are placed into a diagram are certain to be executed (i.e. not skipped due to missing data) | ||
| If a compound action which has such a step in its activity diagram, finishes execution and that step was not executed, an error is reported. | |||
| ;Assert Executed within Time | |||
| Use this, to ensure that verifying actions which are placed into a diagram are certain to be executed (i.e. not skipped due to missing data) | |||
| :Adds a check to the executor, that any step of this kind must be executed within a given time limit. This has the same effect as the time limit pin at a concrete step; however, it allows for a global upper limit to be set eg. on UI actions, on protocol actions (transmission or connection times) without a need to add it to each of its steps separately. | |||
| :If a step has a time limit input, the value there takes precedence over any default value specified here. | |||
| ;Assert Any Output Written | ;Assert Any Output Written | ||
| :Adds a check to the executor, that steps of this kind must generate a datum on at least one of its output pins. | :Adds a check to the executor, that steps of this kind must generate a datum on at least one of its output pins.<br>If a compound action which has such a step in its activity diagram, finishes execution and that step did not generate at least one output value, an error is reported. | ||
| If a compound action which has such a step in its activity diagram, finishes execution and that step did not generate at least one output value, an error is reported. | |||
| ;Assert All Outputs Written | ;Assert All Outputs Written | ||
| :Adds a check to the executor, that steps of this kind must generate a datum on every of its output pins. | :Adds a check to the executor, that steps of this kind must generate a datum on every of its output pins.<br>If a compound action which has such a step in its activity diagram, finishes execution and that step did not generate output values for every output pin, an error is reported. | ||
| If a compound action which has such a step in its activity diagram, finishes execution and that step did not generate output values for every output pin, an error is reported. | |||
| Notice that these flags can also be set on a per-step basis. The settings here will be ored with the flag settings of individual steps. | Notice that these flags can also be set on a per-step basis. The settings here will be ored with the flag settings of individual steps. | ||
| Zeile 254: | Zeile 298: | ||
| The "''Interface''" field at the bottom of the editor assigns such an interface to a concrete action, and specifies that the edited action is able to play that virtual action's role. | The "''Interface''" field at the bottom of the editor assigns such an interface to a concrete action, and specifies that the edited action is able to play that virtual action's role. | ||
| [[Datei:NotBeginner.png|20px]]Note: this field is not shown if your experience setting is "''Beginner''". | [[Datei:NotBeginner.png|20px]]Note: this field is not shown if your experience setting is "''Beginner''".<br>Go to the "''Extras''" - "''Settings''" - "''Look & Feel''" - dialog to change your experience setting. | ||
| === Add / Remove / Test Action User Interface (Action-UI) === | === Add / Remove / Test the Action's User Interface (Action-UI) === | ||
| You can specify a graphical user interface ( | You can specify a graphical user interface (GUI) for an action. If defined, that user interface will be displayed as long as the action is executed during a test run. The action can communicate with the UI using environment variables. The environment variables will be created by the [[GUI Editor-GUICode Editor|UI Editor]] during creation / editing the UI. | ||
| ⚫ | |||
| [[Datei:NotBeginner.png|20px]]Note: this field is not shown unless your experience setting is "''Expert''".<br>Go to the"''Extras''" - "''Settings''" - "''Look & Feel''" - dialog to change your experience setting. | |||
| == Keyboard Shortcuts == | == Keyboard Shortcuts == | ||
| Zeile 267: | Zeile 310: | ||
| * '''<span style="box-shadow: 1px 1px 2px rgba(0,0,0,0.3);"><kbd>Ctrl-o</kbd></span>''' - "''New OutputPin''".<br>Adds a new output pin - same as clicking on the "''Add Output Pin''" button. | * '''<span style="box-shadow: 1px 1px 2px rgba(0,0,0,0.3);"><kbd>Ctrl-o</kbd></span>''' - "''New OutputPin''".<br>Adds a new output pin - same as clicking on the "''Add Output Pin''" button. | ||
| ==== If a Pin is Selected ==== | |||
| * '''<span style="box-shadow: 1px 1px 2px rgba(0,0,0,0.3);"><kbd>Ctrl-n</kbd></span>''' - "''New Pin''".<br>Adds a new input or output pin, depending on the currently selected pin's type. | * '''<span style="box-shadow: 1px 1px 2px rgba(0,0,0,0.3);"><kbd>Ctrl-n</kbd></span>''' - "''New Pin''".<br>Adds a new input or output pin, depending on the currently selected pin's type. | ||
| * '''<span style="box-shadow: 1px 1px 2px rgba(0,0,0,0.3);"><kbd>Ctrl-e</kbd></span>''' - "''Environment''".<br> | * '''<span style="box-shadow: 1px 1px 2px rgba(0,0,0,0.3);"><kbd>Ctrl-e</kbd></span>''' - "''Environment''".<br>Opens a dialog to adds an environment-freeze (the value is read from a variable, if the pin is unconnected) | ||
| * '''<span style="box-shadow: 1px 1px 2px rgba(0,0,0,0.3);"><kbd>Ctrl-p</kbd></span>''' - "''Parameter''".<br>Toggles the "''is parameter pin''" attribute of the pin | * '''<span style="box-shadow: 1px 1px 2px rgba(0,0,0,0.3);"><kbd>Ctrl-p</kbd></span>''' - "''Parameter''".<br>Toggles the "''is parameter pin''" attribute of the pin | ||
| * '''<span style="box-shadow: 1px 1px 2px rgba(0,0,0,0.3);"><kbd>Ctrl-d</kbd></span>''' - "''Datatype''".<br>Opens the datatype selection menu for the pin | |||
| == See Also == | == See Also == | ||
| Zeile 278: | Zeile 325: | ||
| [[Code_Editor/en | Code Editor]] | [[Code_Editor/en | Code Editor]] | ||
| [[ElementaryBlock_Element/en|Elementary Action]], [[CompoundBlock_Element/en|Compound Action]]  | |||
| ⚫ | |||
| ⚫ | |||
| <br> | <br> | ||
| sections of interest are the [[Expecco_API/en#Pin Functions  | Pin-API ]], [[ Expecco_API/en#Current Activity | Activity-API ]] | |||
Aktuelle Version vom 4. Juni 2025, 15:16 Uhr
The schema editor is used to define the external interface and some other attributes of an action block (both elementary and compound actions). It is found on the "Schema" tab after selecting either an elementary or a compound action in the navigation tree.
The block's interface consists of the input and output pins and its trigger behavior. The editor shows a box representation of the action, where inputs are located on the left, outputs on the right. This is the "outside view" of the action; i.e. the action's look when placed as a step in a diagram.
To the right, you see an example for the interface of a action with a single input pin (in) and a single output pin (out). In a network, a step with this action will trigger when all connected input pins have received a value ("AndConnected" trigger condition).
Schema editors can also be invoked on actions that are write protected, e.g. actions from imported libraries, such as the standard library or your own block libraries. Such components cannot be modified, but they can however be shown and inspected by the editor.
Inhaltsverzeichnis
- 1 Pins
- 2 Action
- 3 Declaring Semantic Attributes
- 4 Execution Debugging Attributes
- 5 Adding Pre- and Post Actions
- 6 Advanced and Expert Settings
- 7 Keyboard Shortcuts
- 8 See Also
Pins[Bearbeiten]
Adding & Removing Pins[Bearbeiten]
New input and output pins can be added using the icon buttons in the top corners of each side of the action's representation box ( /
 /  ). Existing inputs and outputs can be removed using the icon buttons directly beside the buttons for adding (
). Existing inputs and outputs can be removed using the icon buttons directly beside the buttons for adding ( ), but a pin has to be selected for this operation first. Please note that some builtin blocks, like shell command blocks, have a fixed set of pins which can not be removed.
), but a pin has to be selected for this operation first. Please note that some builtin blocks, like shell command blocks, have a fixed set of pins which can not be removed.
When new pins are added, they get default names attached with a sequential number, like in1, in2, out1, out2, etc.
Special Pins[Bearbeiten]
Some actions (i.e. script and bridged execution actions) support additional special pins, with a predefined (and hardcoded) functionality. For script actions, these are used to provide the execution directory, environment variables, standard input, exitCode handling and output line buffering options. For bridged actions, these provide the bridge connection handle and/or script interpreter handle on which the script is to be executed.
Special pins are added with the "Special Pins" menu, and removed by selecting the pin and deleting it (via key or menu).
These special pins are described in "Special Pins of Script Action Blocks", "Special Pins of Bridged Action Blocks" and also in "Expecco Scripting API"
 Note: these menu items are not shown if your experience setting is "Beginner". Go to the "Settings" - "Look & Feel" - dialog to change your experience setting.
Note: these menu items are not shown if your experience setting is "Beginner". Go to the "Settings" - "Look & Feel" - dialog to change your experience setting.
Renaming of Pins[Bearbeiten]
The name of a pin can be changed (*) by clicking on the name field, which then turns into an input text field. There, type in a new name for the pin. The pin will be renamed when either the Enter key is pressed, or the input field is left (i.e. clicking on any other element in the editor). The Escape key cancels the rename operation.
For a subset of the supported programming languages, the editor will rewrite the code to use the new name.
(*): except for special pins which cannot be renamed.
Restrictions on Pin Naming for Elementary Blocks[Bearbeiten]
In elementary blocks, pin names are not only used for description purpose but also to access the pin's value in the action's source code (i.e. for actions written in a textual programming language). Therefore, some naming restrictions apply to ensure that the pin name represents a valid identifier in the block's code (i.e. it must be a valid variable identifier in the programming language of the action's code, which can be JavaScript, Smalltalk, Groovy, Python, C etc.).
In practice, the identifier should be a sequence of letters, digits or the underline character (_), where the very first character should not be a digit. It may also not be a keyword of the language (i.e. "function" in Groovy, "if" in JavaScript or "self" in Smalltalk). 
Such restrictions do not apply to compound blocks; however, if you ever plan to convert or generate elementary code, it is a good idea to restrict your naming there too.
Restrictions on Pin Naming for JavaScript and Groovy Elementary Blocks[Bearbeiten]
The syntax of those two languages contains a much larger number of language keywords, which cannot be used as identifier. For example, "if", "while", "for" and "in" are all reserved words in those languages and cannot be used. Otherwise, a syntax error will be reported when code is entered.
It is a good practice to name pins as "inPin1" or "textPin" or "xxxPin" in general, to avoid such conflicts right from the beginning. Such naming convention also make the code more readable, as it reduces chances for confusing the name of a pin with a name of a variable used for a pin's data value (remember: in the code, the pin-name refers to the pin - not the pin's value).
Restrictions on Pin Naming for Other Languages[Bearbeiten]
Similar restrictions apply to the other supported languages (Python, C, etc.).
Edit Functions for Existing Pins[Bearbeiten]
For all other pin operations, the pin to be modified has to be selected first.
To select a pin, click on it with the left mouse button.
You can select multiple pins: keep the Ctrl key down while clicking, to toggle the pin into or out of the selection. Press the Shift-key while clicking to select all pins in between the previously selected pin and the clicked-on pin. You can also select multiple pins with a rectangle-drag operation (click outside, keep holding the mouse button, and drag to the other corner, to select all pins inside the rectangle).
The selected pin(s) will appear highlighted in a red color.
To open the context menu for a pin or group of pins, first select the pin(s), then press the right mouse button. The context menu provides additional pin related functions. Since input and output pins have slightly different properties, their context menus are different and described below.
Setup / Change Datatype[Bearbeiten]
Each pin has a data type attribute that determines which kind of data is expected or generated by the pin. Every new pin initially gets the data type that was last used; initially the data type "Any" is assigned by default. This type is also used as default, whenever no other reasonable data type can be predicted. The pin's data type is displayed beside the pin, outside of the representation box. The data type for a pin can be changed in the context menu, through its "datatype" sub-menu, which brings up a list of available types.
Note that when you have already placed step instances of the modified action block in any activity diagram, a change in the data type of a pin may affect existing connections in which the pin is involved. If the new type is incompatible with a connection, it is drawn as dotted line in the diagram, or when a preset value becomes incompatible, the value is displayed in a red color.
Default Values for Pins[Bearbeiten]
Default values for unconnected step-pins can be defined here, by "freezing" a pin in this schema editor. Both constant-value and environment-freeze values are possible.
Pin Specific Options (Context Menu)[Bearbeiten]
- Undo
- Undo last change(s). The text shown after the word "Undo" (in parentheses) is the name of operation that will be undone.
- Copy Pin
- Copy all attributes from selected pin.
- Remove Pin
- This option simply removes the selected pin.
- Datatype
- This option is used to specify the data type of the selected pin. This brings up a list of the available data types.
- Default Value Editor
- This option allows you to specify the editor type for the freeze value, e.g. strings can be entered single line, multi-line or as a password string.
- Show Datatype
- This option opens a view which shows the pins data type. Note that you can not change the datatype in this view.
- Default Value As
- This option 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. The identifier of the data type in the menu entry differs depending on the data type of the pin. A freeze value defined in this schema defines the input value of unconnected step-pins. It will only be in effect, if the action is placed as a step and the corresponding step-pin is not connected or frozen.
- Default Value from Clipboard
- Freeze pin with the data stored in the clipboard.
- Default Value from Environment Variable
- 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. This freeze value is only effective for unconnected step pins (read description above).
- Delete Default Value
- This option 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.
- Parameter (Non Consuming; Non Triggering)
- This option determines whether the select input pin is a parameter pin. For more information see: Diagram Elements - Input Pin.
- Telegram (Non Consuming; Non Triggering; Deliver While Executing)
- This option determines whether the selected input pin is a telegram pin. For more Information see: Telegram Pin.
- Buffered
- This option sets the buffering mode of the selected output pin to on or off. For more information see: Diagram Elements - Output Pin
- Special Attributs
- A submenu offering additional functions (see below)
- Comment
- This option causes a text editor to open on the pin's comment. That comment will be displayed as a tooltip of the selected pin.
- Move Up/Down
- With those options you can change the sequence of the pins.
Special Attributes[Bearbeiten]
Input Pins[Bearbeiten]
The input pin behavior can be controlled in more detail here. Individual control of the triggering/non-triggering, consuming/non-consuming and buffered/passed-through attributes is offered here.
- Consuming / Non-Consuming
- This option determines whether the input pin consumes its input value from the input basket or leaves it. Non-consuming pins are sometimes required, when the step is executed in a loop, and the input value should be reused for each iteration. Also, frozen parameter pins should be defined as non-consuming, as otherwise, the freeze value is only available once (in the first loop iteration).
- More info in: Diagram Elements-Pin.
- Triggering / Non Triggering
- This option determines whether the input pin is considered in the action triggering process or not. Triggering pins must have a value present in order for an activity to be created. Non-triggering pins are not.
- More info in: Diagram Elements-Pin.
- Mailbox / Non-Mailbox (also called "Telegram Pin")
- This option determines whether the selected pin is a telegram pin. Normal pins "latch" their input value when the action is triggered and provide that value to internal steps (be aware, that it might be consumed). If another value arrives at the pin while it is beeing executed, another activity will be started to process the next value.
- Mailbox pins behave differently: any value arriving there will be forwarded to inside connected steps. Mailbox pins are most useful to implement a controlled cancel operation (eg. by setting a variable inside, which stops a loop).
- For more Information see: Diagram Elements-Pin.
Output Pins[Bearbeiten]
- Buffered / Unbuffered
- Buffered outputs will send their value(s) when the action has finished with success. Unbuffered outputs will send any value immediately (and thus may trigger other actions while this action is still executing).
- For more Information see: Diagram Elements-Pin.
Variable Number of Pins[Bearbeiten]
An input and output pin can be specified as a "variable pin". Such a pin appears in the block description (the schema) as a single pin, but it can be instantiated multiple times in one step. In other words, the number of these variable pins can be defined individually for each step. Variable pins are marked with a small plus sign.
Variable pins can only be the last pins, which are combined into a variable pin group. This pin group can be "replicated" in steps as often as required. Individual pins within a group can have different data types, and the replicated pins adopt the data type of their corresponding pin from the schema definition of the action. This is very useful for defining “multi-key-value” groups, e.g. for multi-setter actions of collections or user data objects.
This option is only possible for elementary actions and the elementary code must be written to access these pins with a pin index.
- Defining the variable pin group
- In the context menu of a pin, the start of the variable pin group can be set via the sub menu Special attributes-Start Variable Pin Group here. The selected pin and the following pins become variable pins, the pins before them become or remain fixed pins.
- This function can also be used to subsequently move the start of the pin group.
- Remove the variable pins.
- Context menu of a variable pin via the sub menu Special attributes-Convert all Variable Pins to Fixed Pins: This converts all variable pins to fixed pins.
- Equal Number of Variable Input and Output Pin Groups
- If a variable pin group is defined in the input and output pins, the number of pin groups can be synchronized. The number of replications of the input and output pins is the same.
- Special attributes-- Equal Number of Variable Input and Output Pin Groups
See also in Diagram Elements-Pin - Variable Number of Pins.
Action[Bearbeiten]
To open the context menu for an action, select the box representation of the action, then press the right mouse button. The context menu supports the following functions.
Changing Triggering Conditions[Bearbeiten]
The triggering condition of an action block defines which input pins must have received data on order for a new activity to be triggered and started. The so called "triggering condition" can be:
- ANDConnected (Default)
- All connected input pins which are "triggering" must have received data - unconnected pins are ignored.
- AND
- All triggering input pins must have received data.
- OR
- At least one triggering input pin must have received data.
Previous versions of expecco showed a (discussable wrong) behavior when a step had the autostart flag set AND an enable input pin with no value provided. This behavior will be set when an old (pre 19.2) suite is loaded to remain backward compatible, but it will be displayed as:
- AND (old behavior)
- Same as AND, but will start with autoStart and enablePin present.
- OR (old behavior)
- Same as OR, but will start with autoStart and enablePin present.
The most common trigger condition is 'AndConnected'. The 'Or' condition allows for a step to be activated whenever any input arrives on any of its pins. It is especially useful to handle events or input data coming from different sources (i.e. a demultiplexer action).
You can also change the triggering conditions by a left click on the trigger-condition field (located at the top left of the block) and select one of the conditions.
New in the 2.8 version of expecco: The default triggering condition for new compound action blocks is "And", and "AndConnected" for all other (elementary) actions. It used to be "AndConnected" for all action blocks in previous versions.
Renaming of Actions[Bearbeiten]
An action can be renamed either using the context menu option or rename the action in the project menu. The name of the action in project tree and the Scheme editor are identical.
The rename of an action will also rename all already placed step instances of this action containing the previous (original) action name. If a step was renamed itself, the step will keep its name.
Action Specific Options (Context Menu)[Bearbeiten]
- Undo
- Undo last change(s).
- Rename
- Open an inplace editor within the headline of the representing box for the action. Initially the current name of the action is selected and the editor will replace the current name with the new name. On lost focus (enter, cursor down, mouse click) the changes will be saved. Cancel editing without saving the changes can be done by pressing the "ESC" key.
- Copy Pin Interface
- Copy all pins (input/output) with all attributes
- Paste Pin Interface
- Paste a previous copied pin interface
- Paste Pin
- Paste a previous copied single pin (see pin context menu)
- Trigger Condition
- see Changing Triggering Conditions
- Role in Load and Performance Tests
- These settings are also not yet used. They are only effective for load and performance tests, which are not yet officially released.
- Semantic Attributes
- see Declaring Semantic Attributes below
- Execution Debugging Attributes
- see Execution Debugging Attributes below
- Attributes
- Open an editor to define the background and frame color besides the tag and name settings for this action.
Declaring Semantic Attributes[Bearbeiten]
The block's pop up menu also allows for a number of semantic attributes to be defined for the action. Some of them are informal/documentation, others are used by the system to optimize excution or to help the expeccoALM/AIDYMO scheduler. In any case, they are optional, and they are not obligatory.
Currently, semantic attributes are:
- Blocking (Immediately Start new Activity Process)
- Tells the executor, that this action may block for a noticeable time; for example if it reads from an external stream (typically a socket), or by opening a user-dialog, or by waiting for some other external event.
 By default, the executor will wait for some grace period and then start another execution thread to continue processing other action blocks. However, this grace period may be too long (a few seconds, by default) and the overall execution time may be shortened, if this is done immediately.
 Of course, this only makes sense if it is known in advance, that this action will block the executor, and that there might be other activities to be executed in parallel. It also only makes sense if the time it takes to start another execution thread (which does involve some overhead) is shorter than the expected wait time.
 Notice also, that this flag can also be set for individual steps - and it is usually a better place to set this flag.
- Operator Required
- Informational flag that the action needs operator assistance. Please set this flag if a containing action opens a UI dialog, or otherwise needs an operator assistance. This will help to identify test cases which can be run without operator assistance. You can find blocks with inconsistent "Operator required" setting in the "Special" test suite search. If the "Operator Needed" Flag missing option is enabled all those blocks will be listed. The operator required flag can be validated against a test case's "Operator Required" flag, which is actually used by QM systems to effectively schedule tests which require human personal.
Except for the previous "Blocking" and "Operator Required" attributes, the following are only relevant for the error checker and the code generator (which is not yet officially released). When set, these flags allow for the error checker to make more specific tests and the code generator / executor to optimize the execution speed of the action.
- Functional
- Hint for the code generator, and the execution engine, that the action's code is purely functional. This means, that the output value(s) only depend(s) on the input value(s), and that neither the input values themselves nor any other global data is modified by any side effect. Purely functional blocks can be executed in parallel without a need for synchronization.
- Modifies an Input Object (Side Effect)
- Hint for the code generator and executor, that the action's code is modifying any of its input values. This means basically, that probably no other step which possibly uses this value should execute concurrently.
- Modifies an Object or External State (Side Effect)
- Hint for the code generator and executor, that the action's code is modifying any object. This means basically, that probably no other step at all should execute concurrently.
- Writes all Output(s) exactly Once
- Hint for the code generator, that the elementary code writes all of the output pins, but only once. This allows for the code generator to eliminate any data queues along the output connections, and pass these values to follow up action code as a function call; effectively allowing for faster execution.
- Writes any Output exactly Once
- Hint for the code generator, that the elementary code writes any of the output pins, but only once. This also allows for the code generator to generate shorter, more efficient code.
- May write an Output more than Once
- Hint for the code generator, that the elementary code may write any of the output pins more than once. The code generator will create data queues for the output pins. Also, the error checker makes use of this flag, when looking for input values being consumed in a loop or consumed multiple times even if only written once.
Notice: these flags should only be set if you know what you are doing and how the elementary code behaves. In a future version, a more advanced code analysis might be added, which may make these flag settings obsolete. If in doubt, leave these flags unchanged (the worst thing that happens in this case, is that any generated elementary code executes slightly slower, and that the error checker finds less errors).
Execution Debugging Attributes[Bearbeiten]
The debug submenu allows for additional debug checks to be defined for the action:
- Assert Executed
- Adds a check to the executor, that any step of this kind must be executed if present inside a compound action's diagram.
 If a compound action which has such a step in its activity diagram, finishes execution and that step was not executed, an error is reported.
 Use this, to ensure that verifying actions which are placed into a diagram are certain to be executed (i.e. not skipped due to missing data)
- Assert Executed within Time
- Adds a check to the executor, that any step of this kind must be executed within a given time limit. This has the same effect as the time limit pin at a concrete step; however, it allows for a global upper limit to be set eg. on UI actions, on protocol actions (transmission or connection times) without a need to add it to each of its steps separately.
- If a step has a time limit input, the value there takes precedence over any default value specified here.
- Assert Any Output Written
- Adds a check to the executor, that steps of this kind must generate a datum on at least one of its output pins.
 If a compound action which has such a step in its activity diagram, finishes execution and that step did not generate at least one output value, an error is reported.
- Assert All Outputs Written
- Adds a check to the executor, that steps of this kind must generate a datum on every of its output pins.
 If a compound action which has such a step in its activity diagram, finishes execution and that step did not generate output values for every output pin, an error is reported.
Notice that these flags can also be set on a per-step basis. The settings here will be ored with the flag settings of individual steps. (i.e. the check will be done if either the block, OR the individual step has the flag set.
Adding Pre- and Post Actions[Bearbeiten]
Compound blocks can have pre- and post-actions. The pre-action block will be executed each time the owning block is triggered; the post execution block is executed after the owning block is finished, but not if a pre-action was present and that pre-action failed. This can be useful e.g. to allocate and/or release resources. To add a pre- or post-action, drag and drop any action from the navigation tree into the corresponding field at the bottom. Please note that these blocks cannot not have input pins.
Advanced and Expert Settings[Bearbeiten]
Defining the Implemented Interface[Bearbeiten]
A virtual action defines the interface (number of pins and their datatypes) of an action, but not its implementation. They can be placed into a network like any other action.
At execution time, a real (concrete) action must be provided for it, either explicitly, via a performer input pin, or implicit, via an imported library which contains a concrete action which implements that virtual action.
The "Interface" field at the bottom of the editor assigns such an interface to a concrete action, and specifies that the edited action is able to play that virtual action's role.
 Note: this field is not shown if your experience setting is "Beginner".
Note: this field is not shown if your experience setting is "Beginner".
Go to the "Extras" - "Settings" - "Look & Feel" - dialog to change your experience setting.
Add / Remove / Test the Action's User Interface (Action-UI)[Bearbeiten]
You can specify a graphical user interface (GUI) for an action. If defined, that user interface will be displayed as long as the action is executed during a test run. The action can communicate with the UI using environment variables. The environment variables will be created by the UI Editor during creation / editing the UI.
 Note: this field is not shown unless your experience setting is "Expert".
Note: this field is not shown unless your experience setting is "Expert".
Go to the"Extras" - "Settings" - "Look & Feel" - dialog to change your experience setting.
Keyboard Shortcuts[Bearbeiten]
- Ctrl-i - "New InputPin".
 Adds a new input pin - same as clicking on the "Add Input Pin" button.
- Ctrl-o - "New OutputPin".
 Adds a new output pin - same as clicking on the "Add Output Pin" button.
If a Pin is Selected[Bearbeiten]
- Ctrl-n - "New Pin".
 Adds a new input or output pin, depending on the currently selected pin's type.
- Ctrl-e - "Environment".
 Opens a dialog to adds an environment-freeze (the value is read from a variable, if the pin is unconnected)
- Ctrl-p - "Parameter".
 Toggles the "is parameter pin" attribute of the pin
- Ctrl-d - "Datatype".
 Opens the datatype selection menu for the pin
See Also[Bearbeiten]
Elementary Action, Compound Action
For the programmer API for the builtin languages see: Expecco API;
sections of interest are the  Pin-API ,  Activity-API 



