Concepts/en
Inhaltsverzeichnis
- 1 Introduction
- 2 Overview and Structure of this Document
- 3 Architecture and User Roles
- 3.1 The expecco Role Model
- 3.2 The User Roles
- 3.3 Testsuites and Testsuite Components
- 3.4 Component Categories and Types
- 3.5 Including Libraries
- 3.6 Arranging Components
- 3.7 Component Properties
- 3.7.1 Documentation Property
- 3.7.2 Variable Environment Property
- 3.7.3 Schema Definition Property
- 3.7.4 Internal Network Property
- 3.7.5 Code Content Property
- 3.7.6 Script Content Property
- 3.7.7 Console Command Property
- 3.7.8 Generic Values List Property
- 3.7.9 Local Test Network Property
- 3.7.10 Skill Requirements Property
- 3.7.11 Skill Attributes Property
- 3.7.12 Skill Assignments Property
- 3.7.13 Resources List Property
- 3.7.14 Test Items List Property
- 3.7.15 Class Definition Property
- 3.7.16 Type Definition Property
 
 
- 4 Workflows and Activity Diagrams
- 5 Test Plans and Test Results
- 6 Resource Management
- 7 Variable Environments
- 8 Further Documentation
Introduction[Bearbeiten]
expecco Wiki[Bearbeiten]
We are currently summarizing our complete documentation in our expecco Wiki: [ "http://doc.expecco.de/wiki2.6" ]
The Situation[Bearbeiten]
Since graphical and interactive modeling came up in computer science, a remarkable number of tools have been developed to faciliate the generative creation of products, especially high-technology products. For a long period of time, big attention has been turned to the automated generation of products, but less attention was spent towards the automation of product testing, especially in the development phase (less so in manufacturing).
Classic testing was - and still is - more than often the unstructured sum of multiple individual, partial tests, in most cases performed by the developers themselves, and often inconsequently conducted due to the lack of time. This usually leads to using proprietary testing systems, which in addition are incompletely and sometimes erroneously implemented, and for all aspects of the testing, the collaboration or support of an expert is required.
Today, the steadily increasing complexity of high technology products, together with the continuous shortage of development cycle times, but also the expectations of the customers regarding quality and reliability, let testing become one of the major issues of modern product development. Also the markets for which products are generated are changing - Increasing concurrence and economical challenge raise the need for reusable work. Internationalization and outsourcing bring up new requirements for logistics and communication. Accordingly, also decentralized tests have to be well organized, and a division of the testing process into distinct testing roles becomes indispensable.
The Solution[Bearbeiten]
The German-based eXept AG was one of the first and earliest software companies to take this topic serious, and as a result of many years of development, the expecco System is a professional approach to this issue. Utilizing the newest technologies of the current UML 2.0 standard, and extending them by a set of powerful special features, expecco is the state-of-the-art solution for modeling, executing and evaluating tests efficiently. Using the available interfaces, existing tests and testing systems can easily be embedded into the expecco Workflow management. This allows a seamless integration of expecco into almost any existing infrastructure.
eXpecco is a modern, component based, modular test and quality ensurance platform, which aims at the consolidation of tests and partial test systems into an automated, interactive test center, and making them accessible to wider person subgroups dependent on their particular role in the test events.
The concept of test modeling introduced by expecco decisively eases the development, execution and evaluation of even most complex test scenarios. This leads to a significant productivity improvement at the creation and maintenance of test scenarios. The integrated versioning of test sequences and test results, the concise library concept, the generally intelligible representation of test scenarios, the wide debug features, and flexible enterprise integration, are additional considerable features.
By introducing different roles for the people involved, it also - and especially - suits complex and distributed test scenarios. The usage of built-in as well as self-defined libraries is the basis for the exchangeability and extensive reuse of your work. Sophisticated standard libraries supply you with the typical components that are frequently used.
Overview and Structure of this Document[Bearbeiten]
This chapter will give a brief overview on the topical categories of the expecco system, and on the most important terms which apply to them. In the subsequent chapters, each of the mentioned categories will be discussed, explaining each of the according components individually, as well as the way they are used in cooperation in the expecco System.
User Roles[Bearbeiten]
Users of expecco may take different roles during the testing operation. Depending on the project size and other factors, it is both possible that a single person takes any of these roles, or that a group of persons is splitted and assigned the distinct roles:
- The Coder is responsible for the generation of building blocks for the test scenario. These building blocks are typically elementary blocks, which are either programmed explicitly, or which invoke existing procedures of the system under test via some communication mechanism like Shell commands, RPC, SOAP etc. Typically, the Coder is a programmer.
- The Composer is creating test scenarios by arranging elementary building blocks into higher level networks of activity diagrams. There is no need for the composer to be a programmer. Typically, the composer has broad domain knowledge of the system under test.
- The Tester is executing tests. Typically, he has to stage the hardware environment of the test, like posing and connecting measurement units an probes, and care for configuration details, such as hostnames, ip addresses, measurement device specifics etc.
- The Auditor is interpreting test results. He evaluates the test results and generates reports for these results. Typically, the analyzer is the interface to the project-, quality- and product-management.
These User Roles are described in detail in the chapter [[Concepts#Architecture and User Roles|"Architecture and User Roles"].
Dataflow Modeling and Activity Diagrams[Bearbeiten]
The expecco System makes use of Activity Diagrams as they are known from the UML 2.0 standard. Although there are many other possible kinds for process modeling in the UML specification, Activity Diagrams offer the best approach to model dataflow driven processes. This is a fundamental difference to the other diagram types in the UML specification, which are all more or less controlflow driven.
However, dataflow modeling is the easiest modeling technique for humans to understand, because it resembles most to the way humans use to think and act. The process pattern is divided into distinct partial Blocks, which represent associated subject parts of the process to be modeled. Instances of these Blocks are supplied with data, which causes them to execute, and produce resulting data, which can be passed to other Block instances or otherwise evaluated. To illustrate this, think of a person that works somewhere in a bureau: An information is coming in, the person acts due to this information, and supplies the resulting information when the job is done.
Another important issue in this context is parallelism: Launching activities in a dataflow model is not achieved by explicit calls, instead the presence of the required information is initiating the activity. From a controlflow style diagram, if at all parallelism can be created with it, it is not easy for humans to anticipate the parallelism behaviour of the model, especially when the diagram gets more complex. In a dataflow diagram on the other hand, parallel behaviour is directly visible and almost always obvious.
Workflows, Blocks, Steps, Activities[Bearbeiten]
The major task to create test scenarios in expecco is the creation of Workflows. Using the expecco GUI, these Workflows are modeled in the form of Activity Diagrams, as mentioned before. Activity Diagrams are not the only way to create Workflows, neither are they the same thing. While a Workflow is an abstract executable network, an Activity Diagram is a graphical, possibly editable representation of a Workflow. The usual terminology would tell that Workflows are made up of so-called Blocks, but to be more precise, the following distinction has to be made:
- An '"'Action Block" (also hereafter often referred to as "block" or "action") is the representation and definition of an operation (or part of it) to be modeled. Inside an expecco project, Blocks are organized as so-called Block Components. Blocks are abstract generalisations of Activities, i.e. they are never executed directly, instead they provide a blueprint for the behaviour of Activities that are spawned from them. Thus an action describes a possible activity. It becomes a real activity, once it is performed.
- A "Step" is a modeling instance of an Action Block. In a Workflow, Steps are placed and interconnected to model the desired behaviour. While Blocks are unique objects within a project, any number of according Steps can be embedded in any Workflow, each representing an individual instance of the Block's blueprint. The Steps inside a Workflow mark the spawning points for the Activities which are created from the according Blocks when the Workflow is executed.
- An "Activity" is a concrete executing instance of a Step, and exists only as long as it is being executed. Multiple Activities can be spawned concurrently from the same Step or different steps which are associated with the same Action Block. Activities are created when a Step inside a Workflow is being invoked (i.e. activated or triggered).
Since Workflows can, in their entireness, also be regarded as assembled Blocks, there is a special type of Block in expecco which contains such a Workflow. These so-called "Compound Blocks" can then in turn be integrated into other Workflows. Compound Blocks are the key to the great flexibility and reusability of the expecco Workflow system. They allow not only to organize, but also to easily re-organize activity patterns, divide existing patterns into partial ones, and even to automatically generate new patterns out of arbitrary subsets of existing ones. This helps to create intuitively associable structures, and to rearrange them with ease whenever needed.
In contrast, the so-called "Elementary Blocks" do not combine other Blocks, but instead are used for basic data processing, and to provide access to the operating system and to the interfaces of the real world. They are needed to exchange information with the testing environment outside the system, e.g. to exchange signals, obtain measurement values, display dialogs, etc. This is achieved either by programmatic, scripting or console call access, or by remote invocation methods like RPC, SOAP, DCOM, DCE, or Corba.
Workflows and Activity Diagrams are described in detail in the chapter "Workflows and Activity Diagrams".
Tests, Test Plans, Test Runs, and Test Results[Bearbeiten]
A "Test", in terms of the expecco System, is a Block which can either fail or succeed. A "Test Plan" is a set of individual Tests which are sequentially processed when the Test Plan is processed. A "Test Run" designates the execution of a Test Plan or a single Test, providing tracing and logging information on each step of the execution. A "Test Result", finally, is the collection of elementary results of a Test Run.
Test Results can be stored either in a database (Oracle, SQL, Access, etc.), or as a standardized XML file. This information can be further processed, and be used to generate reports, statistics, etc., which can finally be stored as PDF or HTML viewable files.
Because the desired appearance of a report usually depends on company-specific style guides, these reports are generated via a set of customizable XSLT- rules. A standard default set of rules is included in the expecco release, either to work with immediately, or as a starting point for your own, personalized reports.
Tests, Test Plans, Test Runs, and Test Results are described in detail in the chapter "Using Elementary Blocks".
Resources, Skills, Requirements and Inventories[Bearbeiten]
In addition to its input data values, a Block may also require a set of "Resources" for its Activity to be started. Possible resources could be human operators, machinery, measurement devices, hardware resources or database locks.
To honor the fact that some resources (especially humans) can take different roles, a Resource is defined by a set of "Skills". A Skill is a pattern for a particular kind of ability or feature. A Block may define a set of "Requirements" which are necessary for its processing, and an Activity can only be spawned from it if enough Resources can be allocated to meet the needs hereby defined.
Besides the obvious use of Resources to model skills and availability of humans or devices, they can also be very useful for process synchronization. Semaphores, database locks, mutual exclusion and limiting parallel execution can all be easily modeled using Resources.
Resources are managed and held by "Inventories". Whenever an Activity is started, the fitting Resources are allocated (fetched) from the assigned Inventory and moved into a temporary Inventory, which is held by the Activity. When the Activity is finished, all allocated Resources are returned to the Inventory they were taken from.
Resources, Skills, Requirements and Inventories are described in detail in the chapter "Resource Management".
Testsuites and Testsuite Components[Bearbeiten]
In expecco, test cases are organized in Testsuites, which are composed of Testsuite Components. You can think of the Testsuite Components as the basical units of association when working with expecco: editing the Testsuite means editing one or more of its Components. In the expecco GUI, Testsuite Components are kept and arranged in the Component Navigation Tree. There are four categories of Testsuite Components:
- For workflow creation, arrangement and execution, the Block and Testplan Components are used.
- For resource management, the Skill, Resource and Inventory Components are used.
- For project organization, the Group, Package, Library and Documentation Components are used.
- For individual adaptation and extension, the Datatype and Class Components are used.
There are no further types of Testsuite Components that you need to know. However, some of the listed Component types include different specialized subtypes.
Testsuite management concepts are described in detail in the chapter "Testsuites and Testsuite Components".
Architecture and User Roles[Bearbeiten]
Like for all automated processes, it applies accordingly to testing, that the mapping of processes is ideally characterized by generalization and modularization. The development of software products is a good example for this: while low-level components are tested with the built-in means of the language, the high-level components are tested with accumulating scripts and artificial stimulations (triggerings, parameterizations, value passes).
It is this basical level on which the expecco architecture is based. It's about the dissociation of elementary and compound actions, as the prerequisite for intuitive abstraction and modularization. The system under test is not longer understood just as a surrounding subject, but instead comprehended as a discrete unit, which can be communicated with from inside the integrated testing system.
This view also directly clarifies the question for which types of tests expecco is applicable: for all test scenarios whose parameters relevant for the evaluation can be retrieved by use of computers, and whose stimulations required for the operation can be created by use of computers. In the last consequence, this can also simply be done by using dialogs, so that in principle, any test scenario that is evaluatable by use of computers,
can be engaged with expecco.
The modelling architecture of expecco is made up of four consecutive levels..
The first level is the one that connects the system under test to the testing
system. At this point, elementary building blocks
come into use, which primarily serve for creating the communicative interfaces
between expecco and the testing environment. From them, in the second level,
abstract compound building blocks are composed,
which in turn can contain both types of building blocks. In the third level,
test plans are generated that combine one or more
building blocks for sequential execution, and which can also be nested (test
plan in test plan). When executing, the test results
are generated, which in the fourth layer are logged into result files or documents,
or can be made available in a database. 
With expecco, a top-down- as well as a bottom-up-creation of tests is possible. With the bottom-up approach, the basic functionalities for communication with the system under test and the measurement devices are created first. From these basical building blocks, more complex building blocks are then composed. With the top-down approach, in contrast, the test scenarios are created very early and on high level. This is even possible when the system under test or the interfaces to it do not yet exist. Though such a test scenario can not yet execute, it however documents the system behaviour already in an early project phase, and can serve concurrently as requirement and as documentation.
The expecco Role Model[Bearbeiten]
The persons involved in the integrated testing environment take different
roles. Essential for the reasonable division of
the roles is the black-box concept, which permits
every subject of one of these roles to act independent of the others. Black-box
means, that for the usage of building blocks, not their internal structure,
but only the interface to the outside, has to be known. 
Depending on the extent and complexity of the conceptual formulation, the roles can also overlap, one person can cover multiple roles, or one role can be covered by multiple distinct persons. However, the pivotal thing is that the division of the roles allows a well defined limitation of the required
skills, as well as the competencies of the people involved.
The User Roles[Bearbeiten]
The following paragraphs describe the four distinct user roles introduced by the expecco system:
- The Coder Role:
 The Coder provides the basic functionalities and interfaces for tests by creating basical building blocks ("Elementary Blocks", EB). The Coder implements them in programming languages like Smalltalk, Java, C, JavaScript, Perl, Shell, etc. Also direct invocations of existing programs are possible in the form of EBs, on the local platform as well as remotely via RPC, SOAP, DCOM, DCE or Corba. Preparatively for the Composer, the Coder can also combine EBs into composite building blocks ("Compound Blocks", CB).
- The Composer Role:
 The Composer makes use of existing building blocks (like those supplied by the Coder or a library), and generates assembled composite building blocks ("Compound Blocks", CB) by interconnection of those existing EBs and CBs. They can in turn be combined into more complex CBs or test lists. In a CB, required resources like e.g. measuring devices or personnel can be declared. With top-down development, the Composer will usually define the demands for the Coder by modularization. The Composer solely needs domain knowledge, but usually no special programming proficiency.
- The Tester Role:
 The conducts test preparations and executes concrete Test Runs. The preparations typically include the setup of the testing environment, as well as configuration details like IP addresses, measuring unit parameters, etc. The Tester either starts the tests manually, or he enrols them for time guided execution. Before execution of the test, the system assists the Tester to make available all required resources. Test Results are displayed to the Tester and in addition stored in a database. The Tester needs domain knowledge only as far as it is necessary for the setup of the testing environment.
- The Auditor Role:
 The Auditor evaluates the Test Results, creates statistics and trend analyses, and supplies the evidence of quality. All test data are at the Auditor's disposal in a database, which he can evaluate by means of database tools. He generates Test Reports out of the collected data, which he typically forwards to the quality-insurance-, project- or product-management. He needs domain knowledge only as far as it is necessary for the understanding of the evaluation.
Testsuites and Testsuite Components[Bearbeiten]
In expecco, test cases are organized in Testsuites. An expecco Testsuite consists of its so-called Testsuite Components, or often also shortly called Components, and of nothing more or less than these. Note that the Components are depicted as free, unbound units, that are not structured in their appearance. Although the GUI provides a hierarchical view on Testsuite Components, they are not bound to a hierarchical arrangement. Instead, a Component's Properties may refer to other Components, as explained later.
Each expecco Testsuite contains exactly one Root Component <img SRC="./pictures/PIC_GUI_IconSymbol_ProjectComponent_PackageClosed"> for itself, which serves as the base node for all subsequent structures. The Root Component also contains the global Variable Environment for the Testsuite, which can be accessed by any of the other Components.
Component Categories and Types[Bearbeiten]
Testsuite Components are of different types. The different types serve different needs, which can be grouped into distinct topical categories. These categories are the Workflow Management, the Resource Management, the Testsuite Organization and the Programmatic Modeling.
The following list gives an overview on the Component type categories, briefly explaining the role of each Component type, and introducing the icon which is used for it in the expecco GUI:
- Workflow Management: The Components in this category serve for  creation, arrangement and execution of Workflows. The category includes the following Component types:
 The Block Component  is the Component type used to contain and to model  Workflows and elementary functionalities. There are several different subtypes of this Component type, each having a different icon, but all of those have the same frame  as the empty one depicted here (the different subtypes are listed separately below). The Block Component  is the Component type used to contain and to model  Workflows and elementary functionalities. There are several different subtypes of this Component type, each having a different icon, but all of those have the same frame  as the empty one depicted here (the different subtypes are listed separately below).
 The Test Plan Component  is the Component type used to  model and execute test sequences. A Test Plan can contain references to Block Components, as well as to other Test Plan Components to be processed as nested sub sequences of the superordinate Test Plan. The Test Plan Component  is the Component type used to  model and execute test sequences. A Test Plan can contain references to Block Components, as well as to other Test Plan Components to be processed as nested sub sequences of the superordinate Test Plan.
 
- Resource Management<: The Components in this category serve for definition, assignment / requirement, and housekeeping of Resources. The category includes the following Component types:
 The Skill Component  is the Component type used to  define and represent a particular type of ability (regarding a resource). Skill Components consist of an attribute list, while the attributes are not assigned any values yet. The Skill Component  is the Component type used to  define and represent a particular type of ability (regarding a resource). Skill Components consist of an attribute list, while the attributes are not assigned any values yet.
 The Resource Component  is the Component type used to  model and represent a particular real or formal resource. A Resource is defined by a set of Skills, to each of which are given concrete values for the Skill's attributes. The Resource Component itself does not yet represent  a concrete instance of a resource, but instead serves as a pattern for those instances. The Resource Component  is the Component type used to  model and represent a particular real or formal resource. A Resource is defined by a set of Skills, to each of which are given concrete values for the Skill's attributes. The Resource Component itself does not yet represent  a concrete instance of a resource, but instead serves as a pattern for those instances.
 The Inventory Component  is the Component type used to  instantiate and govern concrete instances of Resources. Arbitrary numbers of instances of the according Resource Components can be registered in an Inventory. The Inventory can then be assigned to a Test Plan or other Workflow execution, serving as the pool for the Resources available to the Activities in this execution. The Inventory Component  is the Component type used to  instantiate and govern concrete instances of Resources. Arbitrary numbers of instances of the according Resource Components can be registered in an Inventory. The Inventory can then be assigned to a Test Plan or other Workflow execution, serving as the pool for the Resources available to the Activities in this execution.
 
- Testsuite Organization: The Components in this category serve for  organization and overall documentation of Testsuite Components. The category includes the following Component types:
 The Group Component  is the Component type used to  accumulate Components that are belonging together associatively. The Group Component has no other functionality or use other than this. It is the only Component that has no Component Properties assigned. The Group Component  is the Component type used to  accumulate Components that are belonging together associatively. The Group Component has no other functionality or use other than this. It is the only Component that has no Component Properties assigned.
 The Package Component  is the Component type used to  accumulate Testsuites or Libraries. The Package Component is usually created automatically, not by hand. For example, if you include one or more Libraries in your Testsuite, those Libraries will be nested into a self-generated Package named "imports". The Package Component  is the Component type used to  accumulate Testsuites or Libraries. The Package Component is usually created automatically, not by hand. For example, if you include one or more Libraries in your Testsuite, those Libraries will be nested into a self-generated Package named "imports".
 The Library Component  is the Root Component of an imported Library (or Testsuite). It does not only serve as a hierarchical root node, but also provides the sub-global Variable Environment for the subject Components in its scope, in the same way as the Root Component does it for the Testsuite. Components below this type cannot be modified or moved, but however can be copied and pasted. The Library Component  is the Root Component of an imported Library (or Testsuite). It does not only serve as a hierarchical root node, but also provides the sub-global Variable Environment for the subject Components in its scope, in the same way as the Root Component does it for the Testsuite. Components below this type cannot be modified or moved, but however can be copied and pasted.
 The Documentation Component  is the Component type used to  write down documentation contents that are not bound to a particular Testsuite Component. Every Component type in expecco already has a Documentation Property (except for the Group Component), but each of those Properties is bound to its owning Component. The Documentation Component is free of this restriction, supplying the Documentation Property as the only one for its type. The Documentation Component  is the Component type used to  write down documentation contents that are not bound to a particular Testsuite Component. Every Component type in expecco already has a Documentation Property (except for the Group Component), but each of those Properties is bound to its owning Component. The Documentation Component is free of this restriction, supplying the Documentation Property as the only one for its type.
 
- Programmatic Modeling: The Components in this category serve for  adaption and creation of proprietary extensions. The category includes the following Component types:
 The Class Component  is the Component type used to  create and represent own or imported programmatical classes. These classes can then be used to introduce according Datatypes, in the same manner as a Datatype can be assigned an existing standard class. The Class Component  is the Component type used to  create and represent own or imported programmatical classes. These classes can then be used to introduce according Datatypes, in the same manner as a Datatype can be assigned an existing standard class.
 The Datatype Component  is the Component type used to  select additional data types which are not available  in the standard default set of provided data types. Datatype Components are referencing to existing, build-in or self-created classes. When a new Datatype is specified, it will from then on be available in all dropdown choosers concerning data types. The Datatype Component  is the Component type used to  select additional data types which are not available  in the standard default set of provided data types. Datatype Components are referencing to existing, build-in or self-created classes. When a new Datatype is specified, it will from then on be available in all dropdown choosers concerning data types.
 
- The Block Component Subtypes
The Block Component type is the only expecco Component type that has specialized subtypes. In the list above, only the abstract Block Component type was introduced. The following list shows the concrete subtypes of the Block Component type, again briefly explaining the role of each, and introducing the icon which is used for it in the expecco GUI:
 The Compound Block Component  is the Component type used to contain and model Workflows. Each Component of this type contains exactly one so-called Internal Workflow, also often called the Internal Network of the Block. There are no further subtypes of the Compound Block Component type. All other Block Component types are called Elementary Blocks, because in contrast they have no Internal Network, instead implementing elementary functionality blocks. The Compound Block Component  is the Component type used to contain and model Workflows. Each Component of this type contains exactly one so-called Internal Workflow, also often called the Internal Network of the Block. There are no further subtypes of the Compound Block Component type. All other Block Component types are called Elementary Blocks, because in contrast they have no Internal Network, instead implementing elementary functionality blocks.
 The Smalltalk Code Block Component  is the Component type used to implement an elementary functionality block in form of Smalltalk style source code. Each Component of this type contains exactly one so-called Code Content, which is interpreted according to the SmalltalkX syntax at runtime. The Smalltalk Code Block Component  is the Component type used to implement an elementary functionality block in form of Smalltalk style source code. Each Component of this type contains exactly one so-called Code Content, which is interpreted according to the SmalltalkX syntax at runtime.
 The JavaScript Code Block Component  is the Component type used to implement an elementary functionality block in form of JavaScript style source code. Each Component of this type contains exactly one so-called Code Content, which is interpreted according to the JavaScript syntax at runtime. The JavaScript Code Block Component  is the Component type used to implement an elementary functionality block in form of JavaScript style source code. Each Component of this type contains exactly one so-called Code Content, which is interpreted according to the JavaScript syntax at runtime.
 The Shell Script Block Component  is the Component type used to implement an elementary functionality block in form of Shell Script code. Each Component of this type contains exactly one so-called Script Content, which is interpreted according to a shell or batch script syntax at runtime. Since the content is directly piped to the underlying OS, and is not interpreted by the expecco engine, the executability of the contents depends on the local platform at execution time. The Component type also supplies the typical streams from and to the OS process, like stdin,  stdout, and  stderr. The Shell Script Block Component  is the Component type used to implement an elementary functionality block in form of Shell Script code. Each Component of this type contains exactly one so-called Script Content, which is interpreted according to a shell or batch script syntax at runtime. Since the content is directly piped to the underlying OS, and is not interpreted by the expecco engine, the executability of the contents depends on the local platform at execution time. The Component type also supplies the typical streams from and to the OS process, like stdin,  stdout, and  stderr.
 The Console Shell Command Block Component  is the Component type used to implement an elementary functionality block in form of a console command. Each Component of this type contains exactly one so-called Console Command setup, which is executed directly by the underlying OS, as if it had been typed into an OS console window. The executability of the command depends on the local platform at execution time. The Component type also supplies the typical streams from and to the OS process, like stdin,  stdout, and  stderr. The Console Shell Command Block Component  is the Component type used to implement an elementary functionality block in form of a console command. Each Component of this type contains exactly one so-called Console Command setup, which is executed directly by the underlying OS, as if it had been typed into an OS console window. The executability of the command depends on the local platform at execution time. The Component type also supplies the typical streams from and to the OS process, like stdin,  stdout, and  stderr.
 The Test Data Generator Block Component  is the Component type used to supply artificially generated data values during runtime. Its purpose is to substitute data inputs which are not yet, or temporarily not available, to enable the user to however run his tests for trial. Each Component of this type contains exactly one so-called Generic Values List, which takes time-value-pairs that are used at runtime to generate each value at its particular generation time and supply it to the output interface. The Test Data Generator Block Component  is the Component type used to supply artificially generated data values during runtime. Its purpose is to substitute data inputs which are not yet, or temporarily not available, to enable the user to however run his tests for trial. Each Component of this type contains exactly one so-called Generic Values List, which takes time-value-pairs that are used at runtime to generate each value at its particular generation time and supply it to the output interface.
 
Including Libraries[Bearbeiten]
Besides the possibility to create Testsuite Components on your own, it is also possible to integrate existing Components from other Testsuites, simply by importing them as the contents of a Library. These Components can then be used inside your own project in the same manner as those that you created on your own, but it is not possible to modify those in-lib Components. The reason for this is to keep the Librarys version consistent, so changing one of the libs Components is only possible when working directly inside its project. However, if desired, you can still make a copy of an in-lib Component, and modify
that copy to fit your needs.
Note that the included Libraries each contain an own Root Component, which is distinct from the current projects Root Component. Each of those carries an own Variable Environment, which is thus valid for all - and only - the Components inside the Librarys scope.
By their nature, Libraries are nothing else than Testsuites: a collection of Testsuite Components. The differences to a practical Testsuite are as regards content: While the regular Testsuite aims on provision of concretely executable items, a Library aims on provision of frequently used standard Components. On the file system, expecco Libraries usually have the ".xlib" suffix, while Testsuites have the ".xprj" suffix. Technically seen, this is the only difference between them, and you can use both for import, also your own projects. A Testsuite will be named .xlib
only if the author intended it to be a Library.
Arranging Components[Bearbeiten]
Usually, you work with the Testsuite and with its Components using the expecco GUI Browser, which displays the Components inside the Component Navigation Tree View. This view displays a tree containing all the Components in an arbitrary hierarchical structure. Arbitrary means that the hierarchical arrangement inside the Tree View does not influence the functionalities of the Testsuite or any of its Components in any way. The only reason to supply a hierarchically arrangeable view for the Components, is to allow the user to group and arrange Components according to his subjective associations.
Although the arrangement of the Components is technically arbitrary, some restrictions have been made to the arrangements possible in the Tree View. The base node of the tree always is the Root Component of the Testsuite. Furthermore, Components can only be nested directly below one of the following Component types: Compound Blocks, Test Plans, Packages, Libraries, or Groups (which will all be explained later). Below a Compound Block, for example, usually other Blocks are placed that are used only or mainly inside that Compound Block, while below a Test Plan there might be placed other partial Test Plans or Inventories. A Group, for example, could serve to embrace a group of Skills and Resources, or Datatypes and Classes. Apart from these restrictions, you can arrange your Components by free will.
Testsuite Components
have names, which serve to make
them distinguishable for the user. The names are a purely
associative feature for the user. The expecco system
does not need them for operation, neither for distinguishing
the Components from each other. Internally, the expecco system
uses other information to do this: Every Testsuite Component
has a unique internal ID, which
is not only unique inside the project, but also world
wide. A special algorithm ensures that two Components
that are not identical will never
have the same internal ID. 
The user usually doesn't get in touch with the internal ID, and it is neither wanted nor possible by normal means of usage in the expecco system. Thus, the user must use the associative names to distinguish the Components. Although it is possible to give the same name to several distinct Components, this doesnt make much sense, because it will only lead to confusion for the user: When a Component is referenced in another Component's Property Editor, it will be labeled with the associative name rather than with its ID.
Component Properties[Bearbeiten]
The characteristic contents that make up a Component are called the Component Properties. There are about 20 different types of Component Properties, but every Component type owns only some of them, according to the purpose of the Component type. The maximum of 6 different Properties is within the Compound Block Component. All other Component types have a lower number of Properties.
It is important at this point to understand the correct meaning of what is called "Property" here. A Property in the current context does not mean things like the name, id, or other internal detail. Property here means a topical unit of information that is characteristic for the Component's purpose, and which is editable
or at least displayable to the user.
A Component never has two Properties of the same type, and Properties are never shared between Components, i.e. a Component Property always belongs to exactly one Component only. When duplicating Testsuite Components by copying and pasting, the duplicate's Properties will initially have the same contents like the copied one, but however, each of the duplicates will hold its own, individual set of Properties. The Properties of the pasted Components are deep copies of the copied one's, so modifying a Property of a pasted Component will never affect the Properties of the source Component or other pasted Components.
For each Component, one or more Component Pages can be opened in the expecco GUI Browser. A Component Page contains the Editors appropriate for the Component to which the Page refers, as depicted in Figure 4.4-2. The GUI Editors are used to access and modify the Component Properties, and for each Property type, there is one specialized Editor. Only one of the Editors is visible at a time in one Page, but Editors can be switched by using the rider tags on top of the Component Page. Changes on a Components Properties are accepted or rejected as a whole, so changes in several Editors can be made before storing its new state. You get detailed information on the GUI Browser's Page and Editor management in <a HREF="./DOC_eXpeccoUserGuide_GUI.html#b1f2aa20-f609-11da-9610-0040c7999506">expecco
GUI Documentation/Chapter 3: The GUI Browser Window</a>.
Below, you find a list giving a brief
description of each individual Property type, each containing a link to the
explanation of the according GUI Editor that is used to modify the Property.
Documentation Property[Bearbeiten]
applies to all
Component types, except the Group
Component. It serves to assign each Component an individual documentation
text. Accessing this Property through the GUI is described in
the chapter "The Documentation Editor" of the expecco GUI Documentation.
Variable Environment Property[Bearbeiten]
applies
to the Package and Compound
Block Component types. It serves to create and preset a
scoped variable environment which is then accessible by all subordinated
Block Components. Accessing this Property through the GUI is described
in
<a HREF="./DOC_eXpeccoUserGuide_GUI.html#172bfc50-f60c-11da-9610-0040c7999506">expecco
GUI Documentation/Chapter 6.3: The Testsuite Environment Editor</a>
and
<a HREF="./DOC_eXpeccoUserGuide_GUI.html#1767a5c0-f60c-11da-9610-0040c7999506">expecco GUI Documentation/Chapter 6.4: The Block Environment Editor</a>.
Schema Definition Property[Bearbeiten]
applies
to all Block
Component types. It serves to define the data inputs and outputs
of a Block Component. Accessing this Property through the GUI
is described in
<a HREF="./DOC_eXpeccoUserGuide_GUI.html#179d0da0-f60c-11da-9610-0040c7999506">expecco
GUI Documentation/Chapter 6.5: The Schema Editor</a>. 
Internal Network Property[Bearbeiten]
applies to
the Compound Block Component type only.
It serves to model the internal Workflow of a Compound Block by
arranging and interconnecting building blocks called the Steps.
Accessing this Property through the GUI is described in
<a HREF="./DOC_eXpeccoUserGuide_GUI.html#190a5940-f60c-11da-9610-0040c7999506">expecco
GUI Documentation/Chapter 6.11: The Internal Network Editor</a>.
Code Content Property[Bearbeiten]
applies to the
Code Block Component types only. It
serves to contain executable code in a particular programming
language. Accessing this Property through the GUI is described
in
<a HREF="./DOC_eXpeccoUserGuide_GUI.html#17d73070-f60c-11da-9610-0040c7999506">expecco
GUI Documentation/Chapter 6.6: The Program Code Editor </a>. 
Script Content Property[Bearbeiten]
applies to
the Shell Script Block Component type only.
It serves to contain script code in an OS dependent scripting
language. Accessing this Property through the GUI is described
in
<a HREF="./DOC_eXpeccoUserGuide_GUI.html#181f0ee0-f60c-11da-9610-0040c7999506">expecco
GUI Documentation/Chapter 6.7: The Script Code Editor </a>. 
Console Command Property[Bearbeiten]
applies to
the Shell Command Block Component type only.
It serves to contain an OS dependent console command. Accessing
this Property through the GUI is described in
<a HREF="./DOC_eXpeccoUserGuide_GUI.html#185a9140-f60c-11da-9610-0040c7999506">expecco
GUI Documentation/Chapter 6.8: The Console Command Editor</a>.
Generic Values List Property[Bearbeiten]
applies
to the Test Data Generator Component
Type only. It serves to set up a list of typed values, and time
offsets on which those values should be yielded. Accessing this
Property through the GUI is described in
<a HREF="./DOC_eXpeccoUserGuide_GUI.html#189947f0-f60c-11da-9610-0040c7999506">expecco
GUI Documentation/Chapter 6.9: The Generic Values Editor</a>.
Local Test Network Property[Bearbeiten]
applies
to all Block
Component types, except the Test
Data Generator Component type. It serves to model and execute
a trial Workflow which is held local with the Component. Accessing
this Property through the GUI is described in
<a HREF="./DOC_eXpeccoUserGuide_GUI.html#19476240-f60c-11da-9610-0040c7999506">expecco
GUI Documentation/Chapter 6.12: The Block Test Editor</a>. 
Skill Requirements Property[Bearbeiten]
applies
to all Block
Component types. It serves to assign a set of required skills
to the Block which will be used to reserve applicable Resources
for its execution. Accessing this Property through the GUI is
described in
<a HREF="./DOC_eXpeccoUserGuide_GUI.html#1a5f13d0-f60c-11da-9610-0040c7999506">expecco
GUI Documentation/Chapter 6.16: The Resource Requirement Editor</a>.
Skill Attributes Property[Bearbeiten]
applies to
the Skill Component Type only. It serves to define the typed attributes that characterize a Skill object. Accessing this Property through the GUI is described in
<a HREF="./DOC_eXpeccoUserGuide_GUI.html#19a19030-f60c-11da-9610-0040c7999506">expecco GUI Documentation/Chapter 6.13: The Skill Definition Editor</a>.
Skill Assignments Property[Bearbeiten]
applies
to the Resource Component type only.
It serves to assign one or more Skills to the Resource Component
and concretizing them with typed values. Accessing this Property
through the GUI is described in
<a HREF="./DOC_eXpeccoUserGuide_GUI.html#19e1cd80-f60c-11da-9610-0040c7999506">expecco
GUI Documentation/Chapter 6.14: The Resource Definition Editor</a>.
Resources List Property[Bearbeiten]
applies to
the Inventory Component type only.
It serves to define the set of Resources that the Inventory Component
shall contain for disposition on Skill requirement requests. Accessing
this Property through the GUI is described in
<a HREF="./DOC_eXpeccoUserGuide_GUI.html#1a205d20-f60c-11da-9610-0040c7999506">expecco
GUI Documentation/Chapter 6.15: The Inventory Definition Editor</a>.
Test Items List Property[Bearbeiten]
applies to
the Test Plan Component type only.
It serves to set up and arrange a sequence of test items, and
provides the execution wrapper to process that sequence. Accessing
this Property through the GUI is described in
<a HREF="./DOC_eXpeccoUserGuide_GUI.html#1abf5c40-f60c-11da-9610-0040c7999506">expecco
GUI Documentation/Chapter 6.17: The Testplan Editor</a>. 
Class Definition Property[Bearbeiten]
applies to
the Class Component type only. It serves
to define the programmatic structure of a Class Component. Accessing
this Property through the GUI is described in
expecco
User Guides (Full Version)/expecco GUI Documentation/Chapter 1:
The Class Definition Editor (not included). 
Type Definition Property[Bearbeiten]
applies to
the Datatype Component type only. It
serves to select a data type which is not included by default
to be represented by the Datatype Component. Accessing this Property
through the GUI is described in
expecco
User Guides (Full Version)/expecco GUI Documentation/Chapter 2:
The Datatype Definition Editor (not included). 
Workflows and Activity Diagrams[Bearbeiten]
The peculiarity of expecco is the Workflow Management, which allows the combination of elementary programmatical elements (working steps) into a composite Workflow. This is done in form of UML-2.0 compliant, so-called Activity Diagrams. Activity Diagrams consist of building blocks called the Steps, and of Connections which interconnect those Steps with each other. Activity Diagrams are data flow driven, which corresponds most to the way in which humans use to think and act: an input is coming in, causing us to perform some particular activity, which in turn yields a resulting output.
| 
 | 
 | 
| <A NAME="15846120-1237-11db-a24a-0040c7999506"></A> 
 | 
 | 
<A NAME="89bc6ba0-117e-11db-a24a-0040c7999506"></A>
| 5.1. Data Flow Driven Execution |        <A HREF="#96fbaff0-f604-11da-b4b4-0040c7999506">
       <IMG SRC="./pictures/__ICON_CHPNAV_ROOT"></IMG>
       </A>
       <A HREF="#1b23ba30-0761-11db-bbaf-0040c7999506">
       <IMG SRC="./pictures/__ICON_CHPNAV_MASTER"></IMG>
       </A>
       <A HREF="#36885720-0812-11db-bbaf-0040c7999506">
       <IMG SRC="./pictures/__ICON_CHPNAV_PREV"></IMG>
       </A>
       <A HREF="#f7b87fb0-10aa-11db-a24a-0040c7999506">
       <IMG SRC="./pictures/__ICON_CHPNAV_NEXT"></IMG>
</A> | 
Data flow driven execution means that the invocation of a Step takes place in the moment when the data that is required for execution is present. When invoked, the Step takes the required portion of data from the inputs and launches an Activity instance that uses those data. Input data can be buffered on the Step's inputs, and on invocation, the Step only fetches the first value from each input, leaving the rest of the queue in the buffer for subsequent invocations.
One of the big advantages of this approach is that you never have to directly implement the creation of Activity instances; this is done implicitly at runtime by passing the input values to the Step. Please keep in mind that invoking a Step does not mean that the Step itself is running. The Step inside the Activity Diagram only serves as a value collector and buffer, and as a spawning point for its Activities.
| 
 | <A NAME="47e3a0e0-10ca-11db-a24a-0040c7999506"></A> 
 | 
| <A NAME="cc9ce4a0-117d-11db-a24a-0040c7999506"></A> 
 | 
 | 
| 
 | 
 | 
<A NAME="f7b87fb0-10aa-11db-a24a-0040c7999506"></A>
| 5.2. The Schema Definition |        <A HREF="#96fbaff0-f604-11da-b4b4-0040c7999506">
       <IMG SRC="./pictures/__ICON_CHPNAV_ROOT"></IMG>
       </A>
       <A HREF="#1b23ba30-0761-11db-bbaf-0040c7999506">
       <IMG SRC="./pictures/__ICON_CHPNAV_MASTER"></IMG>
       </A>
       <A HREF="#89bc6ba0-117e-11db-a24a-0040c7999506">
       <IMG SRC="./pictures/__ICON_CHPNAV_PREV"></IMG>
       </A>
       <A HREF="#43261fd0-155f-11db-9ca4-0040c7999506">
       <IMG SRC="./pictures/__ICON_CHPNAV_NEXT"></IMG>
</A> | 
Every building block inside an expecco Activity Diagram is characterized by its input and output interface, which is specified in its associated Block Component's Schema Definition Property. The Schema Definition consists of an ordered set of Input and Output Pin Definitions. Note that it does not consist of Pins directly, because Pins occur on a Step instance only. The Block Component, meanwhile, just holds the Pins' definitions.
               According to the black-box concept,  the internal implementation of the Block  is irrelevant for the integration into a Workflow. You can even embed Steps of a Block which internally is not implemented at all, and make up for the implementation at a later point of time (top-down creation). Meanwhile, you can already use the Block to instantiate Steps in a Workflow, because the data flow interface is already specified. <a HREF="#cfbea310-0b53-11db-a24a-0040c7999506">Figure 5.2-1</a> shows two exemplary Schema Definition depictions as they appear  in the according Editor in the expecco GUI Browser:
               
                | 
 | <A NAME="cfbea310-0b53-11db-a24a-0040c7999506"></A> 
 | 
In addition, with the small grey box to the left, an Triggering Condition Type can be selected. The gating type determines in which way the presence of input values should be evaluated to decide when a Step spawns an Activity: AND gating requires all consuming inputs to have a value, OR gating requires one or more consuming inputs to have a value, and ANDConnected gating requires all connected consuming inputs to have a value.
| <A NAME="fdfe3c90-0b53-11db-a24a-0040c7999506"></A> 
 | 
 | 
| 
 | 
 | 
               Every Step uses the Default Pin Configuration of its Block, which, however, can be locally overwritten inside an Activity Diagram. The Pin Confiiguration settings affect only the behaviour of Steps to the outside, it does not affect the internal functionality of a Block or any of its Steps. The below list gives an overview on the adjustable features:
               
                | 
 | 
The Editor used by the expecco GUI Browser to edit Schema Definitions is described in detail in
<a HREF="./DOC_eXpeccoUserGuide_GUI.html#179d0da0-f60c-11da-9610-0040c7999506">expecco GUI Documentation/Chapter 6.5: The Schema Editor</a>.
<A NAME="43261fd0-155f-11db-9ca4-0040c7999506"></A>
| Using Activity Diagrams[Bearbeiten]A Workflow consists of three basical elements: Steps which have Pins, and Connections that interconnect the Pins. The Activity Diagram displays these elements, and allows the user to arrange and modify them. Steps are displayed as building blocks with the according set of graphical endpoints for the Pins, and Connections are displayed as lines between the Pins endpoints. This chapter describes how Activity Diagrams are structured, and which features apply to the distinct modeling elements. Because the features are numerous, each topical issue is discussed in an individual subchapter. A description of the Editor used to handle Activity Diagrams is available under <A NAME="9b22a120-1570-11db-9ca4-0040c7999506"></A> 
 There are two types of Workflow Editors in the expecco system, which are almost the same. The only difference between these two variants is that the one type supplies Interface Pins to the Activity Diagram, while the other one does not. The reason for this is the different purpose of the two variants: The first variant, called the Local Test Editor, applies to all Block Components, to Elementary Blocks as well as to Compound Blocks. Its purpose is to allow the user to model one trial network for each Block Component, which is kept individually by that Component. It supplies a Test Wrapper object, which embeds the Workflow defined in this editor. Since the Test Wrapper object has no input or output interface, no External Pins are needed. The second variant, called the Internal Network Editor, is the one that supplies External Pins to the diagram, which represent the Interface Pins of the Block. It is only available for Compound Blocks, which hold an Internal Workflow Property. These Pins are the Interface Pins of the according Schema Definition of the Block. The Blocks Input Pins are displayed on the left side of the Activity Diagram, and act like Output Pins inside of it. Vice versa, the Blocks Output Pins are displayed to the right, and act like Input Pins inside the Diagram. <a HREF="#e8a5c2b0-1561-11db-9ca4-0040c7999506">Figure 5.3.1-1</a> shows a Compound Block's Interface Pins, as defined in the Schema Definition, appearing as External Pins in the Internal Workflow's Activity Diagram. <A NAME="e8a5c2b0-1561-11db-9ca4-0040c7999506"></A> 
 Note that inside the Activity Diagram, the Interface Pins have the opposite behaviour as when used from the outside: The Input Interface Pins behave as Output Pins (because they pass the incoming values from the outside to the Workflow), and the Interface Output Pins behave as Input Pins (because they pass the outgoing values from the Workflow to the outside). Also note that Interface Pins can also be added and deleted directly inside
    this Editor, without first having to switch to the Schema Editor. The Interface
    Pins' settings can also be edited directly from within the Internal Network
    Editor, the context menu for the Interface Pins supplies the identical functionality
    as it does in the Schema Definition Editor. However, frozen values are not
    displayed here, and the Triggering Condition Type can't be modified from here
    either.  
 <A NAME="c9e09030-1561-11db-9ca4-0040c7999506"></A> 
 
 Another possibility to create Step instances is first to copy an existing Step instance, and then paste it into the same or into another Activity Diagram. Multiple Steps can also be copied at once, and can be pasted as a whole. It is not possible to copy and paste single Connections, but when copying multiple Steps at a time, the Connections which are between them are also copied. This allows to copy and paste complete sub structures of existing Workflows, including all Connections comprised. 
 To create a Connection between two Pins, you simply click on one of the Pins, and drag the mouse pointer to the other one. This creates a Connection object in the Workflow which is then displayed as an angled line between the Pins in the Activity Diagram. 
                        A more sophisticated way to create new Steps is the possibility to either create new Compound Blocks out of existing Step structures of a Workflow, or to expand the Step structure inside a Compound Block from an existing Step of that Block. In both cases, the selected Steps are removed, and replaced with the according substitute:
                       When combining Steps, a new Compound Block is created which obtains the selected sub structure as its Internal Workflow, providing a masking Interface Pin for each Pin of the former sub structure that was connected to Pins not comprised in that sub structure. The structure is substituted with a new Step instance of the new Block, and the semi-internal Connections are replaced with Connections to or from the masking Interface Pins. This keeps the connective functionality unchanged, so no further corrections are necessary. When expanding a Step, no new Block Components are generated. Only Steps that refer to Compound Blocks can be expanded. The Step is removed and replaced by a copy of the according Compound Block's Internal Workflow. The complete Workflow is copied, including all internal Connections between the Steps. Connections to the Interface Pins of the expanded Block are replaced by Connections to those Pins of the target Workflow that previously were connected to the substituted Step. <A NAME="69b376b0-162d-11db-9ca4-0040c7999506"></A> 
 Inside a Workflow, every Step has an individual Step Configuration. This comprises the Local Step Configuration for the parameters directly related to the Step instance object, and a set of Local Pin Configurations, which hold overdubbing parameters for each of the Data Pins. The Step Configuration can be edited inside the Activity Diagram, using the functions provided by the appropriate context menus. Every Step inside a Workflow holds its individual set of Local Pin Configurations, which comprise a set of parameters for each of the Pins. In the Schema Definition of a Block, the Default Pin Configurations for those parameters are specified, which are initially applied to every new Step instance. The Steps local Pin Configuration starts as an empty Pin Configuration, which can then be filled individually. When local settings are applied to a Data Pin, they overdub the Blocks according Default Pin Configuration settings, without affecting any of the other Steps in any Workflow. When changes are made to the Block's Schema Definition, those are immediately affecting all according Step instances, but however the individual local Pin Configuration remains in effect.  The Schema Editor allows editing of
 the Triggering Condition Type, the Data Pin Definitions, and the Default Pin Configurations (left column). The Workflow Editor allows, for each Step, editing of the Local Step Configuration and the Local Pin Configurations (center column). The effective Step Configuration is then assembled like this:                        The Effective Step Configuration determines how input and output values are handled, and under wchich conditions Activities are spawned. The following two paragraphs give an overview on the settings comprised int the Local Step Configuration and the Local Pin Configuration; all of the mentioned Step specific options are accessible through the Step's Context Menu,  as described in <a HREF="./DOC_eXpeccoUserGuide_GUI.html#f46d3890-f60c-11da-9610-0040c7999506">expecco GUI Documentation/Chapter 6.10.4: Step Specific Options (Context Menu)</a>.
                       Local Step Configuration The Local Step Configuration comprises parameters that are directly related to the Step object. Because a Step is a Workflow Component, the only possibility to edit these settings in the GUI is through the Workflow Editor for the Workflow object that contains the Step. The following list gives an overview on the adjustable settings: 
 Local Pin Configuration The functionality of a Local Pin Configuration is exactly the same as for the Default Pin Configuration, which is accessible in the Schema Editor. The overdubbing mechanism works on a per-parameter level: When a parameter is set to a value in the Local Pin Configuration, then this value is taken into account for the Effective Pin Configuration. Parameters for which no value is specified in the Local Pin Configuration will be assigned the value that is given in the Default Pin Configuration. The Pin Configuration affects only the Step's behaviour towards the comprising Workflow, but does not affect the internal functionality. There are four settings for Input Pins, and one setting for Output Pins: 
 <A NAME="95fcddf0-187c-11db-9ca4-0040c7999506"></A> 
 Triggering Condition denotes the rule that determines when to invoke a Step. Invoking a Step means spawning an Activity, and comprises creating it, supplying it with the appropriate input values, and putting it to the Activity execution queue. According to the dataflow driven concept of Activity Diagrams, the decision when this is done is usually made referring to the Input Pins' value occupancies. Depending on the Gating Type, which can be adjusted in the Schema Editor, and on the effective Input Pin Configurations, the presence of input values on certain Input Pins decides about the readiness of the Step for being invoked. However, one more input plays a role in this decision: The Enable Trigger Input Pin, if activated, also has to obtain a value before the Activity instance can be initialized. In an executing Workflow, the system cyclically performs an occupancy evaluation on each of the Workflow's Step instances, which analyzes the value occupancies of the Data Input Pins according to the adjusted Triggering Condition Type. When the relevant occupancies meet the Gating Type's demands, and the Enable Trigger - if activated - also holds a value, the Step will initialize a new Activity instance. There is one parameter inside the effective Input Pin Configuration that plays a role in the evaluation of value occupancies: The non-consuming/non-triggering mode of the Pin, which can be adjusted in the Schema Editor, and overdubbed for each Step in the Workflow Editor. When this option is off, the occupancy of the according Pin is relevant for the evaluation. If not, the occupancy of that Pin is not taken into account. Non-consuming inputs are intended to have parametric behaviour. In the terms of Activity Diagrams, this means that the value is not taken from the input queue of the Pin, instead each Activity obtains an individual copy of the value. Like this, the parametric value has to be supplied only once (e.g. by another Step that yields the value on an Output Pin), instead of having to supply it for each invocation. Also, no queue is present for the input values, instead the current value is replaced by a new one as soon as the new value is received by the Pin. There are three Gating Types available, of which one can be selected at a time, and which is valid for all Steps of the according Block. The most simple one is the Or function, which requires only one of the consuming Pins to have a value. The second one, the And function, requires all of the consuming Pins to have a value. The third one, the AndConnected function, requires all of the connected consuming Pins to have a value; Pins that are not connected are not taken into account. With this function, Pins can remain unconnected, while the And function in contrast would cause the Step never to be invoked if one consuming Pin was unconnected. Since the AndConnected function is most typically used, it is initially selected in new Block's Schema Definitions. <A NAME="f406d5a0-f60c-11da-9610-0040c7999506"></A> 
 Triggers are a means for synchronisation of Steps in a Workflow Chart. They allow execution gating and intentional serialization, as well as conditional and timelimit dependent canceling. Although regarded theoretically, everything of these could also be done by using only the Data Input/Output Pins, the use of Triggers faciliates handling and structuring of the Workflow, and improves associative overview of the Workflow Chart. Trigger Pin Connections are handled in a very similar manner as the Data Pin Connections, and all that is said about the wiring options and display properties of those Connections also applies to the Trigger Pin Connections. Trigger Pins can be selected in the same way as Data Pins are selected, and they use the same Context Menu, although differing in the availability of some entries. 
 On top of the representation box, you see three possible Trigger Input Pins, which are (from left to right) the Enable-Input, the Cancel-Input, and the Timelimit-Input trigger pin. At its bottom, you see the two possible Trigger Output Pins, called (from left to right) the Enable-Output, and the Exception-Output trigger pin. Most often used is the Enable-Input/-Output pin pair. Its major use is to determine the activation sequence of (in regard to synchronisation) equitable Steps, or to trigger execution of trailing activities when a superposed activity has finished. The other pins usually serve for exception handling and conditional branching.                        Here are some abstract examples for the typical use of the different triggers:
                       
 
                        Trigger Inputs can not only be connected to Trigger Outputs,  but also to Data Outputs in some cases,  and Trigger Outputs can be connected to Trigger Inputs as well as to Data Inputs in some cases.  The following lineup will discuss the possibilities of each trigger type in detail:
                       
                        All Trigger Pins can be activated and deactivated through the Step's Context Menu,  as described in  <a HREF="./DOC_eXpeccoUserGuide_GUI.html#f46d3890-f60c-11da-9610-0040c7999506">expecco GUI Documentation/Chapter 6.10.4: Step Specific Options (Context Menu)</a>.
                       <A NAME="80b77080-164d-11db-9ca4-0040c7999506"></A> 
 Although the Internal Workflow of a Compound Block is modeled inside the Internal Network Editor, this Editor does not supply any direct execution mechanisms for that Workflow. Instead, the Local Test Editor is used for modeling trial situations for a particular Block. In the Local Test Editor, Steps of arbitrary Blocks can be combined to a separate Workflow, which can then be executed directly from within that editor. The reason for this extra editor is obvious: While the Internal Network Editor is only intended for the definition of the Internal Workflow Property of a Compound Block, the Local Test Editor allows to model independent trial Workflows, which dont affect the Blocks own behaviour, and which in addition are also available to Elementary Blocks. In the expecco GUI, there are only two possibilities to execute Workflows: One is through the Local Test Editor, the other is through the Test Plan Editor. What both execution models have in common is the Test Wrapper object. It encapsulates the Workflow to be executed, and serves as the starting point which receives the users control signals. During execution, Activity Logs are created and kept for later evaluation. In the case of Test Plan executions, the Test Wrapper contains the implicitly generated Workflow as its Internal Workflow Property. The difference between these two possibilities is, that the Local Test Editors Test Wrapper directly wraps the trial Workflow which has been modeled in its Activity Diagram, while the Test Plan Editors Test Wrapper wraps a sequence of implicit Steps. The Test Plan Editor does not supply an Activity Diagram. Instead, when a Test Plan is executed in this editor, the according Steps are implicitly created, and automatically sequenced by Enable Triggers. This causes the sequence to stop when one of the spawned Activities fails on execution. There are two different events that can cause a Step to initialize an Activity: The first is the Autostart option, which can be set as a Step Configuration parameter inside the according Activity Diagram. When the Autostart option is set for a Step, the Step will initialize exactly one Activity instance each time the comprising Workflow is beginning an execution. The second is the Input Pin Evaluation, which analyzes the value occupancies of the Data Input Pins according to the adjusted Triggering Condition Type. The Gating Type can be adjusted in the Schema Editor. When the relevant input values meet the Gating Type's demands, and the Enable Trigger - if activated - also holds a value, the Step will initialize a new Activity instance. It is important to know that initializing an Activity is not the same as executing an Activity. When an Activity is initialized, only the internal object is prepared, and the according set of input values is attached to that object. Execution can however start at a later point of time, depending on parallelity limitation of the Step, and on the Activity's position in the execution queue. This means that the values that the internal functionality of the Activity will work on are the first values present at the Step's Input Pins in the moment of the invocation (= Activity initialization), and changes in the value constitution (especially on the parametric Input Pins) are not recognized by the Activity when its execution starts. Another important issue when executing Workflows is the so-called Execution Context, which denotes the executing environment of an Activity. Activities, meanwhile, can only be spawned from Steps, and Steps can only exist inside of Workflows. Executing a Workflow means executing Activities of the Steps inside. This especially affects Compound Block Steps, because these have own Workflows as their internal functionalities. When a Compound Block Step's Activity is executed, it constitutes the Execution Context for all Activities spawned from its internal Steps. The special thing about it is that the Activity not only creates its individual Execution Context, but also inherits the properties of its own encapsulating Execution Context. There are several items which are concerned in the Execution Context inheritance. First is the Variable Environment: Each Compound Block defines an own Variable Environment, possibly overdubbing parts or all of the Variable Environment inherited from its encapsulating Execution Context. Second is the Inventory: Also, each Compound Block defines an own Local Inventory, that may pass Resource Acquirement Requests to the Inventory of its encapsulating Execution Context. Third, but not of great interest to the user, is the internal logging mechanism: Activity Logs are always attached to the superordinate Activity Log instance in their Execution Context after the Activity has finished execution. <A NAME="36885720-0812-11db-bbaf-0040c7999506"></A> 
 | 





