ETSI ES 203 022 V1.1.1 (2017-07)
Methods for Testing and Specification (MTS); The Testing and Test Control Notation version 3; TTCN-3 Language Extensions: Advanced Matching
Methods for Testing and Specification (MTS); The Testing and Test Control Notation version 3; TTCN-3 Language Extensions: Advanced Matching
DES/MTS-203022AdvMatch ed111
Metode za preskušanje in specificiranje (MTS) - 3. različica zapisa preskušanja in krmiljenja preskusov - Razširitev nabora jezikov TTCN-3: Napredno ujemanje
Ta dokument določa podporo za napredno ujemanje jezika TTCN-3. TTCN-3 je mogoče uporabiti za specificiranje vseh vrst reaktivnih sistemskih preskusov v okviru različnih komunikacijskih vrat. Običajna področja uporabe so preskušanje protokolov (vključno z mobilnimi in internetnimi protokoli), preskušanje storitev (vključno z dodatnimi storitvami), preskušanje modulov,
preskušanje platform na osnovi OMG CORBA, programskih vmesnikov (API) itd. TTCN-3 ni omejen na preskušanje skladnosti in se lahko uporablja za številne druge vrste preskušanja, vključno s preskušanjem interoperabilnosti, robustnosti, regresije, sistema in integracije. Specificiranje preskuševalnih nizov za protokole fizične plasti ne spada na področje uporabe tega dokumenta.
Paketi TTCN-3 so namenjeni določitvi dodatnih pojmov TTCN-3, ki niso obvezni kot pojmi v jedrnem jeziku TTCN-3, ampak so izbirni kot del paketa, ki je primeren za namenske aplikacije in/ali načine uporabe jezika TTCN-3.
Zasnova paketa TTCN-3 upošteva skladnost kombinirane uporabe jedrnega jezika z več paketi, vendar pa dejanske uporabe tega paketa in smernice zanj v kombinaciji z drugimi paketi ne spadajo na področje uporabe tega dokumenta.
General Information
Buy Standard
Standards Content (Sample)
ETSI ES 203 022 V1.1.1 (2017-07)
ETSI STANDARD
Methods for Testing and Specification (MTS);
The Testing and Test Control Notation version 3;
TTCN-3 Language Extensions: Advanced Matching
---------------------- Page: 1 ----------------------
2 ETSI ES 203 022 V1.1.1 (2017-07)
Reference
DES/MTS-203022AdvMatch ed111
Keywords
conformance, testing, TTCN-3
ETSI
650 Route des Lucioles
F-06921 Sophia Antipolis Cedex - FRANCE
Tel.: +33 4 92 94 42 00 Fax: +33 4 93 65 47 16
Siret N° 348 623 562 00017 - NAF 742 C
Association à but non lucratif enregistrée à la
Sous-Préfecture de Grasse (06) N° 7803/88
Important notice
The present document can be downloaded from:
http://www.etsi.org/standards-search
The present document may be made available in electronic versions and/or in print. The content of any electronic and/or
print versions of the present document shall not be modified without the prior written authorization of ETSI. In case of any
existing or perceived difference in contents between such versions and/or in print, the only prevailing document is the
print of the Portable Document Format (PDF) version kept on a specific network drive within ETSI Secretariat.
Users of the present document should be aware that the document may be subject to revision or change of status.
Information on the current status of this and other ETSI documents is available at
https://portal.etsi.org/TB/ETSIDeliverableStatus.aspx
If you find errors in the present document, please send your comment to one of the following services:
https://portal.etsi.org/People/CommiteeSupportStaff.aspx
Copyright Notification
No part may be reproduced or utilized in any form or by any means, electronic or mechanical, including photocopying
and microfilm except as authorized by written permission of ETSI.
The content of the PDF version shall not be modified without the written authorization of ETSI.
The copyright and the foregoing restriction extend to reproduction in all media.
© ETSI 2017.
All rights reserved.
TM TM TM
DECT , PLUGTESTS , UMTS and the ETSI logo are Trade Marks of ETSI registered for the benefit of its Members.
TM
3GPP and LTE™ are Trade Marks of ETSI registered for the benefit of its Members and
of the 3GPP Organizational Partners.
oneM2M logo is protected for the benefit of its Members
GSM® and the GSM logo are Trade Marks registered and owned by the GSM Association.
ETSI
---------------------- Page: 2 ----------------------
3 ETSI ES 203 022 V1.1.1 (2017-07)
Contents
Intellectual Property Rights . 4
Foreword . 4
Modal verbs terminology . 4
1 Scope . 5
2 References . 5
2.1 Normative references . 5
2.2 Informative references . 5
3 Definitions and abbreviations . 6
3.1 Definitions . 6
3.2 Abbreviations . 6
4 Package conformance and compatibility . 6
5 Package Concepts for the Core Language . 7
5.0 General . 7
5.1 Dynamic Matching . 7
5.2 Templates with variable bindings . 8
5.2.0 General . 8
5.2.1 Value retrieval from matching . 8
5.2.2 Declaring out parameters for template definitions . 9
5.3 Additional logical operators for combining matching mechanisms . 11
5.3.0 General . 11
5.3.1 Conjunction. 11
5.3.2 Implication . 12
5.3.3 Exclusion . 13
5.3.4 Disjunction . 13
5.4 Repetition . 14
5.5 Equality operator for the omit symbol and templates with restriction omit . 16
5.5.0 General . 16
5.5.1 Modifications to ETSI ES 201 873-1, clause 7 (Expressions) . 16
6 TCI Extensions for the Package . 17
6.1 Extensions to clause 7.2.2.2.0 of ETSI ES 201 873-6 Basic rules . 17
6.2 Extensions to clause 7.2.2.3.1 of ETSI ES 201 873-6 The abstract data type MatchingMechanism . 19
6.3 Extensions to clause 7.2.2.3.2 of ETSI ES 201 873-6 The abstract data type MatchingList . 19
6.4 Extensions to clause 7.2.2.3 of ETSI ES 201 873-6 The abstract data type MatchingMechanism . 19
TM
6.5 Extensions to clause 8 of ETSI ES 201 873-6 Java language mapping . 20
6.6 Extensions to clause 9 of ETSI ES 201 873-6 ANSI C language mapping . 22
6.7 Extensions to clause 10 of ETSI ES 201 873-6 C++ language mapping . 23
6.8 Extensions to clause 12 of ETSI ES 201 873-6 C# language mapping . 25
Annex A (normative): BNF and static semantics . 27
A.1 Modified TTCN-3 syntax BNF productions . 27
A.2 Deleted TTCN-3 syntax BNF productions . 27
A.3 Additional TTCN-3 syntax BNF productions . 27
History . 29
ETSI
---------------------- Page: 3 ----------------------
4 ETSI ES 203 022 V1.1.1 (2017-07)
Intellectual Property Rights
IPRs essential or potentially essential to the present document may have been declared to ETSI. The information
pertaining to these essential IPRs, if any, is publicly available for ETSI members and non-members, and can be found
in ETSI SR 000 314: "Intellectual Property Rights (IPRs); Essential, or potentially Essential, IPRs notified to ETSI in
respect of ETSI standards", which is available from the ETSI Secretariat. Latest updates are available on the ETSI Web
server (https://ipr.etsi.org/).
Pursuant to the ETSI IPR Policy, no investigation, including IPR searches, has been carried out by ETSI. No guarantee
can be given as to the existence of other IPRs not referenced in ETSI SR 000 314 (or the updates on the ETSI Web
server) which are, or may be, or may become, essential to the present document.
Foreword
This ETSI Standard (ES) has been produced by ETSI Technical Committee Methods for Testing and Specification
(MTS).
The present document relates to the multi-part standard ETSI ES 201 873 covering the Testing and Test Control
Notation version 3, as identified below:
Part 1: "TTCN-3 Core Language";
Part 4: "TTCN-3 Operational Semantics";
Part 5: "TTCN-3 Runtime Interface (TRI)";
Part 6: "TTCN-3 Control Interface (TCI)";
Part 7: "Using ASN.1 with TTCN-3";
Part 8: "The IDL to TTCN-3 Mapping";
Part 9: "Using XML schema with TTCN-3";
Part 10: "TTCN-3 Documentation Comment Specification";
Part 11: "Using JSON with TTCN-3".
NOTE: Part 2 is in status "historical" and part 3 is no longer maintained.
Modal verbs terminology
In the present document "shall", "shall not", "should", "should not", "may", "need not", "will", "will not", "can" and
"cannot" are to be interpreted as described in clause 3.2 of the ETSI Drafting Rules (Verbal forms for the expression of
provisions).
"must" and "must not" are NOT allowed in ETSI deliverables except when used in direct citation.
ETSI
---------------------- Page: 4 ----------------------
5 ETSI ES 203 022 V1.1.1 (2017-07)
1 Scope
The present document defines the support of advance matching of TTCN-3. TTCN-3 can be used for the specification
of all types of reactive system tests over a variety of communication ports. Typical areas of application are protocol
testing (including mobile and Internet protocols), service testing (including supplementary services), module testing,
testing of OMG CORBA based platforms, APIs, etc. TTCN-3 is not restricted to conformance testing and can be used
for many other kinds of testing including interoperability, robustness, regression, system and integration testing. The
specification of test suites for physical layer protocols is outside the scope of the present document.
TTCN-3 packages are intended to define additional TTCN-3 concepts, which are not mandatory as concepts in the
TTCN-3 core language, but which are optional as part of a package which is suited for dedicated applications and/or
usages of TTCN-3.
While the design of TTCN-3 package has taken into account the consistency of a combined usage of the core language
with a number of packages, the concrete usages of and guidelines for this package in combination with other packages
is outside the scope of the present document.
2 References
2.1 Normative references
References are either specific (identified by date of publication and/or edition number or version number) or
non-specific. For specific references,only the cited version applies. For non-specific references, the latest version of the
referenced document (including any amendments) applies.
Referenced documents which are not found to be publicly available in the expected location might be found at
https://docbox.etsi.org/Reference/.
NOTE: While any hyperlinks included in this clause were valid at the time of publication, ETSI cannot guarantee
their long term validity.
The following referenced documents are necessary for the application of the present document.
[1] ETSI ES 201 873-1: "Methods for Testing and Specification (MTS); The Testing and Test Control
Notation version 3; Part 1: TTCN-3 Core Language".
[2] ETSI ES 201 873-4: "Methods for Testing and Specification (MTS); The Testing and Test Control
Notation version 3; Part 4: TTCN-3 Operational Semantics".
[3] ETSI ES 201 873-5: "Methods for Testing and Specification (MTS); The Testing and Test Control
Notation version 3; Part 5: TTCN-3 Runtime Interface (TRI)".
[4] ETSI ES 201 873-6: "Methods for Testing and Specification (MTS); The Testing and Test Control
Notation version 3; Part 6: TTCN-3 Control Interface (TCI)".
2.2 Informative references
References are either specific (identified by date of publication and/or edition number or version number) or
non-specific. For specific references,only the cited version applies. For non-specific references, the latest version of the
referenced document (including any amendments) applies.
NOTE: While any hyperlinks included in this clause were valid at the time of publication, ETSI cannot guarantee
their long term validity.
The following referenced documents are not necessary for the application of the present document but they assist the
user with regard to a particular subject area.
[i.1] ETSI ES 201 873-7: "Methods for Testing and Specification (MTS); The Testing and Test Control
Notation version 3; Part 7: Using ASN.1 with TTCN-3".
ETSI
---------------------- Page: 5 ----------------------
6 ETSI ES 203 022 V1.1.1 (2017-07)
[i.2] ETSI ES 201 873-8: "Methods for Testing and Specification (MTS); The Testing and Test Control
Notation version 3; Part 8: The IDL to TTCN-3 Mapping".
[i.3] ETSI ES 201 873-9: "Methods for Testing and Specification (MTS); The Testing and Test Control
Notation version 3; Part 9: Using XML schema with TTCN-3".
[i.4] ETSI ES 201 873-10: "Methods for Testing and Specification (MTS); The Testing and Test
Control Notation version 3; Part 10: TTCN-3 Documentation Comment Specification".
3 Definitions and abbreviations
3.1 Definitions
For the purposes of the present document, the terms and definitions given in ETSI ES 201 873-1 [1], ETSI
ES 201 873-4 [2], ETSI ES 201 873-5 [3] and ETSI ES 201 873-6 [4] apply.
3.2 Abbreviations
For the purposes of the present document, the abbreviations given in ETSI ES 201 873-1 [1], ETSI ES 201 873-4 [2],
ETSI ES 201 873-5 [3] and ETSI ES 201 873-6 [4] apply.
4 Package conformance and compatibility
The package presented in the present document is identified by the package tag:
"TTCN-3:2017 Advanced Matching" - to be used with modules complying with the present document.
For an implementation claiming to conform to this package version, all features specified in the present document shall
be implemented consistently with the requirements given in the present document and in ETSI ES 201 873-1 [1] and
ETSI ES 201 873-4 [2].
The package presented in the present document is compatible to:
• ETSI ES 201 873-1 [1], version 4.9.1;
• ETSI ES 201 873-4 [2], version 4.6.1;
• ETSI ES 201 873-5 [3], version 4.8.1;
• ETSI ES 201 873-6 [4], version 4.9.1;
• ETSI ES 201 873-7 [i.1];
• ETSI ES 201 873-8 [i.2];
• ETSI ES 201 873-9 [i.3];
• ETSI ES 201 873-10 [i.4].
If later versions of those parts are available and should be used instead, the compatibility to the package presented in the
present document has to be checked individually.
ETSI
---------------------- Page: 6 ----------------------
7 ETSI ES 203 022 V1.1.1 (2017-07)
5 Package Concepts for the Core Language
5.0 General
This package defines advanced matching mechanisms for TTCN-3, i.e. new matching mechanisms which go beyond the
matching mechanisms defined in ETSI ES 201 873-1 [1]. This package realizes the following concepts:
• Dynamic matching allows to specify matching in a function-like fashion, i.e. statement blocks and functions
can be used to define matching.
• Templates with variable bindings ease the retrieval field values of received messages and signatures. For this
the "->" symbol is used to denote a value assignment to a variable or an out parameter in the scope of a
template definition in case of a successful template matching.
• The additional logical operators conjunction, implication, exclusion and disjunction allow the combination
matching mechanisms for advanced matching.
• Repetition allows to match repetitions of a sub-sequence templates inside values of a certain type.
• Restrictions for the omit symbol and templates with restriction omit are relieved allowing omit symbols and
templates with restriction omit as operands for the equality operator.
5.1 Dynamic Matching
A dynamic matching is a special matching mechanism. Similar to other matching mechanisms, it can be considered as a
Boolean function that indicates successful matching for the value to be matched by returning the value true and
unsuccessful matching by returning the value false.
Syntactical Structure
@dynamic (StatementBlock | FunctionRef)
Semantic Description
The StatementBlock shall return a value of type boolean. The value to be matched is referenced by the special
keyword value. When applying this matching mechanism to a value, the StatementBlock is executed and if and only if
the execution returns true, the dynamic matching function matches. Unsuccessful matching shall return false.
A dynamic matching function can only be used in the context of a template, the value expression inside the
StatementBlock shall have the same type as the whole template.
The notation @dynamic FunctionRef denotes a shorthand for the special case @dynamic { return
FunctionRef(value) } where FunctionRef is a reference to a Boolean function with a single parameter compatible
with the template's type. Here, the type of the parameter of the referenced function determines the type context, if this
template's place of usage does not provide a type context.
Restrictions
a) The dynamic matching syntax shall only be used in a typed context.
b) The StatementBlock shall compute a value of type boolean.
c) The StatementBlock shall be deterministic and side-effect free and follow the restrictions of clause 16.1.4 of
ETSI ES 201 873-1 [1].
d) The StatementBlock shall not use variables that are declared outside of the StatementBlock.
e) The StatementBlock shall not use inout or out parameters.
ETSI
---------------------- Page: 7 ----------------------
8 ETSI ES 203 022 V1.1.1 (2017-07)
f) Only if the dynamic matching syntax appears on the right-hand-side of a parameterized template definition, the
formal in parameters of that definition may be referenced inside the StatementBlock. All other formal in
parameters shall not be used by the StatementBlock.
EXAMPLE:
type record of integer Numbers;
template Numbers mw_sorted := @dynamic { // value is of type Numbers
for (var integer v_i := 1; v_i < lengthof(value); v_i := v_i + 1) {
if (value[v_i-1] > value[v_i]) { return false }
}
return true;
} // mw_sorted(v_recInt) matches all values of type Numbers
// if elements of v_recInt do not break an ascending order
type record Coordinate { float x, float y };
external function fx_distance(Coordinate p_a, Coordinate p_b) return float;
template float mw_closeTo(Coordinate p_origin := { 0.0, 0.0 }, float p_maxDistance := 1.0) :=
// access to in parameters is allowed
@dynamic { return fx_distance(p_origin, value) <= p_maxDistance; };
// mw_closeTo(c,d) matches all values of type Coordinate
// which have maximum distance of d from Coordinate c
external function fx_isPrime(integer p_x) return boolean;
:
p.receive(@dynamic fx_isPrime)
// is the same as p.receive(integer:@dynamic { return fx_isPrime(value) })
5.2 Templates with variable bindings
5.2.0 General
The possibilities to retrieve field values of received messages and signatures in ETSI ES 201 873-1 [1] are restricted
and cumbersome. To overcome this situation, this clause implements the definition of templates with variable bindings
that store the actual value matched by a template instance if the matching of all containing templates is successful. This
feature is implemented by using the "->" symbol for denoting a value assignment to a variable or an out parameter in the
scope of a template definition in case of a successful template matching. Such a value assignment can syntactically be
specified at all places where a template matching mechanism or a template reference is used in a template definition or
an inline template.
5.2.1 Value retrieval from matching
In case of a successful template match, the value which matches the template can be assigned to a variable. This can be
specified by using the "->" symbol.
Syntactical Structure
TemplateInstance "->" VariableRef
Semantic Description
If a template successfully matches a value and contains a value retrieval assignment for a TemplateInstance, then, if
during the matching process that TemplateInstance and all its containing TemplateInstances contribute to the successful
template match, the part of the value the TemplateInstance was matching is assigned to the VariableRef referenced in
the value retrieval assignment.
EXAMPLE:
template integer mw_t1 := (?, (1.3) -> v); // mw_t1 always matches, but if the (1.3) does not
// contribute to the successful match
// then v is not assigned a value
template integer mw_t2 := ((1.3) -> v_small, (3.5) -> v_big)
// matching mw_t2 to number in (1.3) will cause only v_small to be assigned,
// matching it to number in (4.5) will cause only v_big to be assigned (preference of (1.3))
ETSI
---------------------- Page: 8 ----------------------
9 ETSI ES 203 022 V1.1.1 (2017-07)
Restrictions
a) If TempateInstance describes the matching of a mandatory element in a template definition, VariableRef shall
refer to a variable of the same type as the mandatory element.
b) If TempateInstance describes the matching of an optional element in a template definition, VariableRef shall
refer to a template variable of the same type as the optional element. In case of a successful matching, the
matching value or omit shall be assigned to the template variable denoted by VariableRef.
c) Value retrieval shall not be used in special places as described in clause 16.1.4 of ETSI ES 201 873-1 [1] with
the exception of the matching parts of receiving operations. If value retrieval is used in the matching part of a
receiving operation, the assignment to the variables of all the templates is done once the whole matching part
matches and all other conditions for the selection of the alternative are met.
d) Value retrieval shall not be applied to templates of set of types or any of their direct or indirect elements,
elements of a permutation matching mechanism or any of their direct or indirect elements.
NOTE: TTCN-3 makes no assumptions about the value of the variable or template variable denoted by
VariableRef My in case of an unsuccessful match.
5.2.2 Declaring out parameters for template definitions
The retrieval of field values in case of successful matching from a structured value can be specified by means of out
parameters of template definitions.
Syntactical Structure
The syntactical structure for global and local template definitions does not change:
template [ restriction ] [ @fuzzy ] Type TemplateIdentifier ["(" TemplateFormalParList ")"]
[ modifies TemplateRef ] ":=" TemplateBody
Only the static semantics restriction for formal template parameters change in such a way that formal template
parameters shall evaluate to in or out parameters.
Semantic Description
The semantics of the value retrieval using templates with out parameters can be described by means of the match
operation:
// Given the record type definition
type record MyRecordType {
integer field1,
boolean field2
}
// the constant definition
const MyRecordType c_myRecord := {
field1 := 7,
field2 := true
}
// the template definition
template MyRecordType mw_myTemplate1 := {
field1 := 7,
field2 := ?
}
// the same template definition with an out parameter matchinstring
template MyRecordType mw_myTemplate2 (out boolean p_matchingBool):= {
field1 := 7,
field2 := ? -> p_matchingBool
}
// and the variable declarations
var boolean v_a, v_b;
// then the effect of
v_a := match (c_myRecord, mw_myTemplate2(v_b));
ETSI
---------------------- Page: 9 ----------------------
10 ETSI ES 203 022 V1.1.1 (2017-07)
// is identical to
if (match (c_myRecord, mw_myTemplate1) {
v_a := true;
v_b := c_myRecord.field2 // i.e., true
}
else {
v_a:= false;
}
Restrictions
a) TempateInstance with out parameters shall not be used as templates of set of types or any of their direct or
indirect elements.
b) TempateInstance with out parameters shall not be used as elements of a permutation matching mechanism or
any of their direct or indirect elements. TempateInstance with out parameters shall not used in special places
as described in clause 16.1.4 of ETSI ES 201 873-1 [1] with the exception of the matching parts of receiving
operations. If TempateInstance with out parameters are used in the matching part of a receiving operation, the
assignment to the actual out parameter variables of all the templates is done only once the whole matching
part matches and all other conditions for the selection of the alternative are met.
c) Every formal out parameter of a template with out parameters shall be referenced at most once inside the
template body.
NOTE: In certain cases a template may match without assigning a value to a declared out parameter. In such
cases, the boundness of the actual out parameter has to be checked even after a successful match before
using it.
EXAMPLE 1:
type union Tree {
integer leaf,
Branch branch
}
type record Branch {
Tree left optional,
Tree right optional
}
template Branch mw_branch(out omit Tree p_left, out omit Tree p_right) := {
left := * -> p_left,
right := * -> p_right
}
template Tree mw_treebranch(out omit Tree p_left, out omit Tree p_right) :=
{ branch := mw_branch(p_left, p_right) }
template Tree mw_leaf(out integer p_value, in template integer p_expected := ?) :=
{ leaf := p_expected -> p_value }
// compute the sum of absolute values of all leafs in the given tree
function f_absSum(omit Tree p_tree) return integer {
var omit Tree v_left, v_right;
var integer v_value;
if (ispresent(p_tree)) {
select (p_tree) {
case (mw_treebranch(v_left, v_right)) {
return f_absSum(v_left) + f_absSum(v_right);
}
case (mw_leaf(v_value, (0 . infinity)) { return v_value; }
case (mw_leaf(v_value) { return -v_value; }
}
}
else {
return 0; }
}
ETSI
---------------------- Page: 10 ----------------------
11 ETSI ES 203 022 V1.1.1 (2017-07)
EXAMPLE 2:
var Tree v_tree;
…
template Tree mw_anyTree(out integer p_value,
out omit Tree p_left, out omit Tree p_right) :=
(mw_leaf(p_value), mw_treebranch(p_left, p_right));
// extraction of leaf or branch from v_tree (any value, if present)
if (match(v_tree, mw_anyTree(v_value, v_left, v_right)) {
if (isbound(v_value)) {
// v_value might not have been assigned => needs check
}
else if (isbound(v_left)) {
// v_left and v_right might not have been assigned
// => needs check
}
}
EXAMPLE 3: Receiving with multiple out parameter templates
signature S(out Tree p_tree) return Tree;
alt {
[match(v_tree, mw_leaf(v_value)] p.receive { }
// NOT allowed to use template with out parameter in alt guard
[] p.getreply(S:{ mw_leaf(v_value) } value mw_treebranch(v_left, v_right)) {
// if either mw_leaf or mw_treebranch does not match, v_value, v_left and v_right
// all remain unchanged
// it is equivalent with the following:
// [] p.getreply(S:{mw_leaf(v_value1)} value mw_treebranch(v_left1, v_right1)) {
// v_left := v_left1;
// v_right := v_right1;
// v_value := v_value1;
// }
// where v_value1, v_left1 and v_right1 are all internal unbound variables of the
// appropriate ty
5.3 Additional logical operators for combining matching
mechanisms
5.3.0 General
This clause defines the additional logical operators conjunction, implication, exclusion and disjunction for matching
mechanisms. Their usage allows the combination matching mechanisms for advanced matching.
5.3.1 Conjunction
The conjunction matching mechanism is used when a value shall fulfil several distinct conditions.
Syntactical Structure
conjunct "(" { (TemplateInstance | all from TemplateInstance) [","] } ")"
Semantic Description
The conjunction matching mechanism can be used for matching values of all types.
A template specified by the co
...
Final draft ETSI ES 203 022 V1.1.1 (2017-04)
ETSI STANDARD
Methods for Testing and Specification (MTS);
The Testing and Test Control Notation version 3;
TTCN-3 Language Extensions: Advanced Matching
---------------------- Page: 1 ----------------------
2 Final draft ETSI ES 203 022 V1.1.1 (2017-04)
Reference
DES/MTS-203022AdvMatch ed111
Keywords
conformance, testing, TTCN-3
ETSI
650 Route des Lucioles
F-06921 Sophia Antipolis Cedex - FRANCE
Tel.: +33 4 92 94 42 00 Fax: +33 4 93 65 47 16
Siret N° 348 623 562 00017 - NAF 742 C
Association à but non lucratif enregistrée à la
Sous-Préfecture de Grasse (06) N° 7803/88
Important notice
The present document can be downloaded from:
http://www.etsi.org/standards-search
The present document may be made available in electronic versions and/or in print. The content of any electronic and/or
print versions of the present document shall not be modified without the prior written authorization of ETSI. In case of any
existing or perceived difference in contents between such versions and/or in print, the only prevailing document is the
print of the Portable Document Format (PDF) version kept on a specific network drive within ETSI Secretariat.
Users of the present document should be aware that the document may be subject to revision or change of status.
Information on the current status of this and other ETSI documents is available at
https://portal.etsi.org/TB/ETSIDeliverableStatus.aspx
If you find errors in the present document, please send your comment to one of the following services:
https://portal.etsi.org/People/CommiteeSupportStaff.aspx
Copyright Notification
No part may be reproduced or utilized in any form or by any means, electronic or mechanical, including photocopying
and microfilm except as authorized by written permission of ETSI.
The content of the PDF version shall not be modified without the written authorization of ETSI.
The copyright and the foregoing restriction extend to reproduction in all media.
© European Telecommunications Standards Institute 2017.
All rights reserved.
TM TM TM
DECT , PLUGTESTS , UMTS and the ETSI logo are Trade Marks of ETSI registered for the benefit of its Members.
TM
3GPP and LTE™ are Trade Marks of ETSI registered for the benefit of its Members and
of the 3GPP Organizational Partners.
oneM2M logo is protected for the benefit of its Members
GSM® and the GSM logo are Trade Marks registered and owned by the GSM Association.
ETSI
---------------------- Page: 2 ----------------------
3 Final draft ETSI ES 203 022 V1.1.1 (2017-04)
Contents
Intellectual Property Rights . 4
Foreword . 4
Modal verbs terminology . 4
1 Scope . 5
2 References . 5
2.1 Normative references . 5
2.2 Informative references . 5
3 Definitions and abbreviations . 6
3.1 Definitions . 6
3.2 Abbreviations . 6
4 Package conformance and compatibility . 6
5 Package Concepts for the Core Language . 7
5.0 General . 7
5.1 Dynamic Matching . 7
5.2 Templates with variable bindings . 8
5.2.0 General . 8
5.2.1 Value retrieval from matching . 8
5.2.2 Declaring out parameters for template definitions . 9
5.3 Additional logical operators for combining matching mechanisms . 11
5.3.0 General . 11
5.3.1 Conjunction. 11
5.3.2 Implication . 12
5.3.3 Exclusion . 13
5.3.4 Disjunction . 13
5.4 Repetition . 14
5.5 Equality operator for the omit symbol and templates with restriction omit . 16
5.5.0 General . 16
5.5.1 Modifications to ETSI ES 201 873-1, clause 7 (Expressions) . 16
6 TCI Extensions for the Package . 17
6.1 Extensions to clause 7.2.2.2.0 of ETSI ES 201 873-6 Basic rules . 17
6.2 Extensions to clause 7.2.2.3.1 of ETSI ES 201 873-6 The abstract data type MatchingMechanism . 19
6.3 Extensions to clause 7.2.2.3.2 of ETSI ES 201 873-6 The abstract data type MatchingList . 19
6.4 Extensions to clause 7.2.2.3 of ETSI ES 201 873-6 The abstract data type MatchingMechanism . 19
TM
6.5 Extensions to clause 8 of ETSI ES 201 873-6 Java language mapping . 20
6.6 Extensions to clause 9 of ETSI ES 201 873-6 ANSI C language mapping . 22
6.7 Extensions to clause 10 of ETSI ES 201 873-6 C++ language mapping . 23
6.8 Extensions to clause 12 of ETSI ES 201 873-6 C# language mapping . 25
Annex A (normative): BNF and static semantics . 27
A.1 Modified TTCN-3 syntax BNF productions . 27
A.2 Deleted TTCN-3 syntax BNF productions . 27
A.3 Additional TTCN-3 syntax BNF productions . 27
History . 29
ETSI
---------------------- Page: 3 ----------------------
4 Final draft ETSI ES 203 022 V1.1.1 (2017-04)
Intellectual Property Rights
IPRs essential or potentially essential to the present document may have been declared to ETSI. The information
pertaining to these essential IPRs, if any, is publicly available for ETSI members and non-members, and can be found
in ETSI SR 000 314: "Intellectual Property Rights (IPRs); Essential, or potentially Essential, IPRs notified to ETSI in
respect of ETSI standards", which is available from the ETSI Secretariat. Latest updates are available on the ETSI Web
server (https://ipr.etsi.org/).
Pursuant to the ETSI IPR Policy, no investigation, including IPR searches, has been carried out by ETSI. No guarantee
can be given as to the existence of other IPRs not referenced in ETSI SR 000 314 (or the updates on the ETSI Web
server) which are, or may be, or may become, essential to the present document.
Foreword
This final draft ETSI Standard (ES) has been produced by ETSI Technical Committee Methods for Testing and
Specification (MTS), and is now submitted for the ETSI standards Membership Approval Procedure.
The present document relates to the multi-part standard ETSI ES 201 873 covering the Testing and Test Control
Notation version 3, as identified below:
Part 1: "TTCN-3 Core Language";
Part 4: "TTCN-3 Operational Semantics";
Part 5: "TTCN-3 Runtime Interface (TRI)";
Part 6: "TTCN-3 Control Interface (TCI)";
Part 7: "Using ASN.1 with TTCN-3";
Part 8: "The IDL to TTCN-3 Mapping";
Part 9: "Using XML schema with TTCN-3";
Part 10: "TTCN-3 Documentation Comment Specification";
Part 11: "Using JSON with TTCN-3".
NOTE: Part 2 is in status "historical" and part 3 is no longer maintained.
Modal verbs terminology
In the present document "shall", "shall not", "should", "should not", "may", "need not", "will", "will not", "can" and
"cannot" are to be interpreted as described in clause 3.2 of the ETSI Drafting Rules (Verbal forms for the expression of
provisions).
"must" and "must not" are NOT allowed in ETSI deliverables except when used in direct citation.
ETSI
---------------------- Page: 4 ----------------------
5 Final draft ETSI ES 203 022 V1.1.1 (2017-04)
1 Scope
The present document defines the support of advance matching of TTCN-3. TTCN-3 can be used for the specification
of all types of reactive system tests over a variety of communication ports. Typical areas of application are protocol
testing (including mobile and Internet protocols), service testing (including supplementary services), module testing,
testing of OMG CORBA based platforms, APIs, etc. TTCN-3 is not restricted to conformance testing and can be used
for many other kinds of testing including interoperability, robustness, regression, system and integration testing. The
specification of test suites for physical layer protocols is outside the scope of the present document.
TTCN-3 packages are intended to define additional TTCN-3 concepts, which are not mandatory as concepts in the
TTCN-3 core language, but which are optional as part of a package which is suited for dedicated applications and/or
usages of TTCN-3.
While the design of TTCN-3 package has taken into account the consistency of a combined usage of the core language
with a number of packages, the concrete usages of and guidelines for this package in combination with other packages
is outside the scope of the present document.
2 References
2.1 Normative references
References are either specific (identified by date of publication and/or edition number or version number) or
non-specific. For specific references,only the cited version applies. For non-specific references, the latest version of the
referenced document (including any amendments) applies.
Referenced documents which are not found to be publicly available in the expected location might be found at
https://docbox.etsi.org/Reference/.
NOTE: While any hyperlinks included in this clause were valid at the time of publication, ETSI cannot guarantee
their long term validity.
The following referenced documents are necessary for the application of the present document.
[1] ETSI ES 201 873-1: "Methods for Testing and Specification (MTS); The Testing and Test Control
Notation version 3; Part 1: TTCN-3 Core Language".
[2] ETSI ES 201 873-4: "Methods for Testing and Specification (MTS); The Testing and Test Control
Notation version 3; Part 4: TTCN-3 Operational Semantics".
[3] ETSI ES 201 873-5: "Methods for Testing and Specification (MTS); The Testing and Test Control
Notation version 3; Part 5: TTCN-3 Runtime Interface (TRI)".
[4] ETSI ES 201 873-6: "Methods for Testing and Specification (MTS); The Testing and Test Control
Notation version 3; Part 6: TTCN-3 Control Interface (TCI)".
2.2 Informative references
References are either specific (identified by date of publication and/or edition number or version number) or
non-specific. For specific references,only the cited version applies. For non-specific references, the latest version of the
referenced document (including any amendments) applies.
NOTE: While any hyperlinks included in this clause were valid at the time of publication, ETSI cannot guarantee
their long term validity.
The following referenced documents are not necessary for the application of the present document but they assist the
user with regard to a particular subject area.
[i.1] ETSI ES 201 873-7: "Methods for Testing and Specification (MTS); The Testing and Test Control
Notation version 3; Part 7: Using ASN.1 with TTCN-3".
ETSI
---------------------- Page: 5 ----------------------
6 Final draft ETSI ES 203 022 V1.1.1 (2017-04)
[i.2] ETSI ES 201 873-8: "Methods for Testing and Specification (MTS); The Testing and Test Control
Notation version 3; Part 8: The IDL to TTCN-3 Mapping".
[i.3] ETSI ES 201 873-9: "Methods for Testing and Specification (MTS); The Testing and Test Control
Notation version 3; Part 9: Using XML schema with TTCN-3".
[i.4] ETSI ES 201 873-10: "Methods for Testing and Specification (MTS); The Testing and Test
Control Notation version 3; Part 10: TTCN-3 Documentation Comment Specification".
3 Definitions and abbreviations
3.1 Definitions
For the purposes of the present document, the terms and definitions given in ETSI ES 201 873-1 [1], ETSI
ES 201 873-4 [2], ETSI ES 201 873-5 [3] and ETSI ES 201 873-6 [4] apply.
3.2 Abbreviations
For the purposes of the present document, the abbreviations given in ETSI ES 201 873-1 [1], ETSI ES 201 873-4 [2],
ETSI ES 201 873-5 [3] and ETSI ES 201 873-6 [4] apply.
4 Package conformance and compatibility
The package presented in the present document is identified by the package tag:
"TTCN-3:2017 Advanced Matching" - to be used with modules complying with the present document.
For an implementation claiming to conform to this package version, all features specified in the present document shall
be implemented consistently with the requirements given in the present document and in ETSI ES 201 873-1 [1] and
ETSI ES 201 873-4 [2].
The package presented in the present document is compatible to:
• ETSI ES 201 873-1 [1], version 4.9.1;
• ETSI ES 201 873-4 [2], version 4.6.1;
• ETSI ES 201 873-5 [3], version 4.8.1;
• ETSI ES 201 873-6 [4], version 4.9.1;
• ETSI ES 201 873-7 [i.1];
• ETSI ES 201 873-8 [i.2];
• ETSI ES 201 873-9 [i.3];
• ETSI ES 201 873-10 [i.4].
If later versions of those parts are available and should be used instead, the compatibility to the package presented in the
present document has to be checked individually.
ETSI
---------------------- Page: 6 ----------------------
7 Final draft ETSI ES 203 022 V1.1.1 (2017-04)
5 Package Concepts for the Core Language
5.0 General
This package defines advanced matching mechanisms for TTCN-3, i.e. new matching mechanisms which go beyond the
matching mechanisms defined in ETSI ES 201 873-1 [1]. This package realizes the following concepts:
• Dynamic matching allows to specify matching in a function-like fashion, i.e. statement blocks and functions
can be used to define matching.
• Templates with variable bindings ease the retrieval field values of received messages and signatures. For this
the "->" symbol is used to denote a value assignment to a variable or an out parameter in the scope of a
template definition in case of a successful template matching.
• The additional logical operators conjunction, implication, exclusion and disjunction allow the combination
matching mechanisms for advanced matching.
• Repetition allows to match repetitions of a sub-sequence templates inside values of a certain type.
• Restrictions for the omit symbol and templates with restriction omit are relieved allowing omit symbols and
templates with restriction omit as operands for the equality operator.
5.1 Dynamic Matching
A dynamic matching is a special matching mechanism. Similar to other matching mechanisms, it can be considered as a
Boolean function that indicates successful matching for the value to be matched by returning the value true and
unsuccessful matching by returning the value false.
Syntactical Structure
@dynamic (StatementBlock | FunctionRef)
Semantic Description
The StatementBlock shall return a value of type boolean. The value to be matched is referenced by the special
keyword value. When applying this matching mechanism to a value, the StatementBlock is executed and if and only if
the execution returns true, the dynamic matching function matches. Unsuccessful matching shall return false.
A dynamic matching function can only be used in the context of a template, the value expression inside the
StatementBlock shall have the same type as the whole template.
The notation @dynamic FunctionRef denotes a shorthand for the special case @dynamic { return
FunctionRef(value) } where FunctionRef is a reference to a Boolean function with a single parameter compatible
with the template's type. Here, the type of the parameter of the referenced function determines the type context, if this
template's place of usage does not provide a type context.
Restrictions
a) The dynamic matching syntax shall only be used in a typed context.
b) The StatementBlock shall compute a value of type boolean.
c) The StatementBlock shall be deterministic and side-effect free and follow the restrictions of clause 16.1.4 of
ETSI ES 201 873-1 [1].
d) The StatementBlock shall not use variables that are declared outside of the StatementBlock.
e) The StatementBlock shall not use inout or out parameters.
ETSI
---------------------- Page: 7 ----------------------
8 Final draft ETSI ES 203 022 V1.1.1 (2017-04)
f) Only if the dynamic matching syntax appears on the right-hand-side of a parameterized template definition, the
formal in parameters of that definition may be referenced inside the StatementBlock. All other formal in
parameters shall not be used by the StatementBlock.
EXAMPLE:
type record of integer Numbers;
template Numbers mw_sorted := @dynamic { // value is of type Numbers
for (var integer v_i := 1; v_i < lengthof(value); v_i := v_i + 1) {
if (value[v_i-1] > value[v_i]) { return false }
}
return true;
} // mw_sorted(v_recInt) matches all values of type Numbers
// if elements of v_recInt do not break an ascending order
type record Coordinate { float x, float y };
external function fx_distance(Coordinate p_a, Coordinate p_b) return float;
template float mw_closeTo(Coordinate p_origin := { 0.0, 0.0 }, float p_maxDistance := 1.0) :=
// access to in parameters is allowed
@dynamic { return fx_distance(p_origin, value) <= p_maxDistance; };
// mw_closeTo(c,d) matches all values of type Coordinate
// which have maximum distance of d from Coordinate c
external function fx_isPrime(integer p_x) return boolean;
:
p.receive(@dynamic fx_isPrime)
// is the same as p.receive(integer:@dynamic { return fx_isPrime(value) })
5.2 Templates with variable bindings
5.2.0 General
The possibilities to retrieve field values of received messages and signatures in ETSI ES 201 873-1 [1] are restricted
and cumbersome. To overcome this situation, this clause implements the definition of templates with variable bindings
that store the actual value matched by a template instance if the matching of all containing templates is successful. This
feature is implemented by using the "->" symbol for denoting a value assignment to a variable or an out parameter in the
scope of a template definition in case of a successful template matching. Such a value assignment can syntactically be
specified at all places where a template matching mechanism or a template reference is used in a template definition or
an inline template.
5.2.1 Value retrieval from matching
In case of a successful template match, the value which matches the template can be assigned to a variable. This can be
specified by using the "->" symbol.
Syntactical Structure
TemplateInstance "->" VariableRef
Semantic Description
If a template successfully matches a value and contains a value retrieval assignment for a TemplateInstance, then, if
during the matching process that TemplateInstance and all its containing TemplateInstances contribute to the successful
template match, the part of the value the TemplateInstance was matching is assigned to the VariableRef referenced in
the value retrieval assignment.
EXAMPLE:
template integer mw_t1 := (?, (1.3) -> v); // mw_t1 always matches, but if the (1.3) does not
// contribute to the successful match
// then v is not assigned a value
template integer mw_t2 := ((1.3) -> v_small, (3.5) -> v_big)
// matching mw_t2 to number in (1.3) will cause only v_small to be assigned,
// matching it to number in (4.5) will cause only v_big to be assigned (preference of (1.3))
ETSI
---------------------- Page: 8 ----------------------
9 Final draft ETSI ES 203 022 V1.1.1 (2017-04)
Restrictions
a) If TempateInstance describes the matching of a mandatory element in a template definition, VariableRef shall
refer to a variable of the same type as the mandatory element.
b) If TempateInstance describes the matching of an optional element in a template definition, VariableRef shall
refer to a template variable of the same type as the optional element. In case of a successful matching, the
matching value or omit shall be assigned to the template variable denoted by VariableRef.
c) Value retrieval shall not be used in special places as described in clause 16.1.4 of ETSI ES 201 873-1 [1] with
the exception of the matching parts of receiving operations. If value retrieval is used in the matching part of a
receiving operation, the assignment to the variables of all the templates is done once the whole matching part
matches and all other conditions for the selection of the alternative are met.
d) Value retrieval shall not be applied to templates of set of types or any of their direct or indirect elements,
elements of a permutation matching mechanism or any of their direct or indirect elements.
NOTE: TTCN-3 makes no assumptions about the value of the variable or template variable denoted by
VariableRef My in case of an unsuccessful match.
5.2.2 Declaring out parameters for template definitions
The retrieval of field values in case of successful matching from a structured value can be specified by means of out
parameters of template definitions.
Syntactical Structure
The syntactical structure for global and local template definitions does not change:
template [ restriction ] [ @fuzzy ] Type TemplateIdentifier ["(" TemplateFormalParList ")"]
[ modifies TemplateRef ] ":=" TemplateBody
Only the static semantics restriction for formal template parameters change in such a way that formal template
parameters shall evaluate to in or out parameters.
Semantic Description
The semantics of the value retrieval using templates with out parameters can be described by means of the match
operation:
// Given the record type definition
type record MyRecordType {
integer field1,
boolean field2
}
// the constant definition
const MyRecordType c_myRecord := {
field1 := 7,
field2 := true
}
// the template definition
template MyRecordType mw_myTemplate1 := {
field1 := 7,
field2 := ?
}
// the same template definition with an out parameter matchinstring
template MyRecordType mw_myTemplate2 (out boolean p_matchingBool):= {
field1 := 7,
field2 := ? -> p_matchingBool
}
// and the variable declarations
var boolean v_a, v_b;
// then the effect of
v_a := match (c_myRecord, mw_myTemplate2(v_b));
ETSI
---------------------- Page: 9 ----------------------
10 Final draft ETSI ES 203 022 V1.1.1 (2017-04)
// is identical to
if (match (c_myRecord, mw_myTemplate1) {
v_a := true;
v_b := c_myRecord.field2 // i.e., true
}
else {
v_a:= false;
}
Restrictions
a) TempateInstance with out parameters shall not be used as templates of set of types or any of their direct or
indirect elements.
b) TempateInstance with out parameters shall not be used as elements of a permutation matching mechanism or
any of their direct or indirect elements. TempateInstance with out parameters shall not used in special places
as described in clause 16.1.4 of ETSI ES 201 873-1 [1] with the exception of the matching parts of receiving
operations. If TempateInstance with out parameters are used in the matching part of a receiving operation, the
assignment to the actual out parameter variables of all the templates is done only once the whole matching
part matches and all other conditions for the selection of the alternative are met.
c) Every formal out parameter of a template with out parameters shall be referenced at most once inside the
template body.
NOTE: In certain cases a template may match without assigning a value to a declared out parameter. In such
cases, the boundness of the actual out parameter has to be checked even after a successful match before
using it.
EXAMPLE 1:
type union Tree {
integer leaf,
Branch branch
}
type record Branch {
Tree left optional,
Tree right optional
}
template Branch mw_branch(out omit Tree p_left, out omit Tree p_right) := {
left := * -> p_left,
right := * -> p_right
}
template Tree mw_treebranch(out omit Tree p_left, out omit Tree p_right) :=
{ branch := mw_branch(p_left, p_right) }
template Tree mw_leaf(out integer p_value, in template integer p_expected := ?) :=
{ leaf := p_expected -> p_value }
// compute the sum of absolute values of all leafs in the given tree
function f_absSum(omit Tree p_tree) return integer {
var omit Tree v_left, v_right;
var integer v_value;
if (ispresent(p_tree)) {
select (p_tree) {
case (mw_treebranch(v_left, v_right)) {
return f_absSum(v_left) + f_absSum(v_right);
}
case (mw_leaf(v_value, (0 . infinity)) { return v_value; }
case (mw_leaf(v_value) { return -v_value; }
}
}
else {
return 0; }
}
ETSI
---------------------- Page: 10 ----------------------
11 Final draft ETSI ES 203 022 V1.1.1 (2017-04)
EXAMPLE 2:
var Tree v_tree;
…
template Tree mw_anyTree(out integer p_value,
out omit Tree p_left, out omit Tree p_right) :=
(mw_leaf(p_value), mw_treebranch(p_left, p_right));
// extraction of leaf or branch from v_tree (any value, if present)
if (match(v_tree, mw_anyTree(v_value, v_left, v_right)) {
if (isbound(v_value)) {
// v_value might not have been assigned => needs check
}
else if (isbound(v_left)) {
// v_left and v_right might not have been assigned
// => needs check
}
}
EXAMPLE 3: Receiving with multiple out parameter templates
signature S(out Tree p_tree) return Tree;
alt {
[match(v_tree, mw_leaf(v_value)] p.receive { }
// NOT allowed to use template with out parameter in alt guard
[] p.getreply(S:{ mw_leaf(v_value) } value mw_treebranch(v_left, v_right)) {
// if either mw_leaf or mw_treebranch does not match, v_value, v_left and v_right
// all remain unchanged
// it is equivalent with the following:
// [] p.getreply(S:{mw_leaf(v_value1)} value mw_treebranch(v_left1, v_right1)) {
// v_left := v_left1;
// v_right := v_right1;
// v_value := v_value1;
// }
// where v_value1, v_left1 and v_right1 are all internal unbound variables of the
// appropriate ty
5.3 Additional logical operators for combining matching
mechanisms
5.3.0 General
This clause defines the additional logical operators conjunction, implication, exclusion and disjunction for matching
mechanisms. Their usage allows the combination matching mechanisms for advanced matching.
5.3.1 Conjunction
The conjunction matching mechanism is used when a value shall fulfil s
...
SLOVENSKI STANDARD
SIST ES 203 022 V1.1.1:2017
01-september-2017
0HWRGH]DSUHVNXãDQMHLQVSHFLILFLUDQMH076UD]OLþLFD]DSLVDSUHVNXãDQMDLQ
NUPLOMHQMDSUHVNXVRY5D]ãLULWHYQDERUDMH]LNRY77&11DSUHGQRXMHPDQMH
Methods for Testing and Specification (MTS) - The Testing and Test Control Notation
version 3 - TTCN-3 Language Extensions: Advanced Matching
Ta slovenski standard je istoveten z: ETSI ES 203 022 V1.1.1 (2017-07)
ICS:
35.060 Jeziki, ki se uporabljajo v Languages used in
informacijski tehniki in information technology
tehnologiji
SIST ES 203 022 V1.1.1:2017 en
2003-01.Slovenski inštitut za standardizacijo. Razmnoževanje celote ali delov tega standarda ni dovoljeno.
---------------------- Page: 1 ----------------------
SIST ES 203 022 V1.1.1:2017
---------------------- Page: 2 ----------------------
SIST ES 203 022 V1.1.1:2017
ETSI ES 203 022 V1.1.1 (2017-07)
ETSI STANDARD
Methods for Testing and Specification (MTS);
The Testing and Test Control Notation version 3;
TTCN-3 Language Extensions: Advanced Matching
---------------------- Page: 3 ----------------------
SIST ES 203 022 V1.1.1:2017
2 ETSI ES 203 022 V1.1.1 (2017-07)
Reference
DES/MTS-203022AdvMatch ed111
Keywords
conformance, testing, TTCN-3
ETSI
650 Route des Lucioles
F-06921 Sophia Antipolis Cedex - FRANCE
Tel.: +33 4 92 94 42 00 Fax: +33 4 93 65 47 16
Siret N° 348 623 562 00017 - NAF 742 C
Association à but non lucratif enregistrée à la
Sous-Préfecture de Grasse (06) N° 7803/88
Important notice
The present document can be downloaded from:
http://www.etsi.org/standards-search
The present document may be made available in electronic versions and/or in print. The content of any electronic and/or
print versions of the present document shall not be modified without the prior written authorization of ETSI. In case of any
existing or perceived difference in contents between such versions and/or in print, the only prevailing document is the
print of the Portable Document Format (PDF) version kept on a specific network drive within ETSI Secretariat.
Users of the present document should be aware that the document may be subject to revision or change of status.
Information on the current status of this and other ETSI documents is available at
https://portal.etsi.org/TB/ETSIDeliverableStatus.aspx
If you find errors in the present document, please send your comment to one of the following services:
https://portal.etsi.org/People/CommiteeSupportStaff.aspx
Copyright Notification
No part may be reproduced or utilized in any form or by any means, electronic or mechanical, including photocopying
and microfilm except as authorized by written permission of ETSI.
The content of the PDF version shall not be modified without the written authorization of ETSI.
The copyright and the foregoing restriction extend to reproduction in all media.
© ETSI 2017.
All rights reserved.
TM TM TM
DECT , PLUGTESTS , UMTS and the ETSI logo are Trade Marks of ETSI registered for the benefit of its Members.
TM
3GPP and LTE™ are Trade Marks of ETSI registered for the benefit of its Members and
of the 3GPP Organizational Partners.
oneM2M logo is protected for the benefit of its Members
GSM® and the GSM logo are Trade Marks registered and owned by the GSM Association.
ETSI
---------------------- Page: 4 ----------------------
SIST ES 203 022 V1.1.1:2017
3 ETSI ES 203 022 V1.1.1 (2017-07)
Contents
Intellectual Property Rights . 4
Foreword . 4
Modal verbs terminology . 4
1 Scope . 5
2 References . 5
2.1 Normative references . 5
2.2 Informative references . 5
3 Definitions and abbreviations . 6
3.1 Definitions . 6
3.2 Abbreviations . 6
4 Package conformance and compatibility . 6
5 Package Concepts for the Core Language . 7
5.0 General . 7
5.1 Dynamic Matching . 7
5.2 Templates with variable bindings . 8
5.2.0 General . 8
5.2.1 Value retrieval from matching . 8
5.2.2 Declaring out parameters for template definitions . 9
5.3 Additional logical operators for combining matching mechanisms . 11
5.3.0 General . 11
5.3.1 Conjunction. 11
5.3.2 Implication . 12
5.3.3 Exclusion . 13
5.3.4 Disjunction . 13
5.4 Repetition . 14
5.5 Equality operator for the omit symbol and templates with restriction omit . 16
5.5.0 General . 16
5.5.1 Modifications to ETSI ES 201 873-1, clause 7 (Expressions) . 16
6 TCI Extensions for the Package . 17
6.1 Extensions to clause 7.2.2.2.0 of ETSI ES 201 873-6 Basic rules . 17
6.2 Extensions to clause 7.2.2.3.1 of ETSI ES 201 873-6 The abstract data type MatchingMechanism . 19
6.3 Extensions to clause 7.2.2.3.2 of ETSI ES 201 873-6 The abstract data type MatchingList . 19
6.4 Extensions to clause 7.2.2.3 of ETSI ES 201 873-6 The abstract data type MatchingMechanism . 19
TM
6.5 Extensions to clause 8 of ETSI ES 201 873-6 Java language mapping . 20
6.6 Extensions to clause 9 of ETSI ES 201 873-6 ANSI C language mapping . 22
6.7 Extensions to clause 10 of ETSI ES 201 873-6 C++ language mapping . 23
6.8 Extensions to clause 12 of ETSI ES 201 873-6 C# language mapping . 25
Annex A (normative): BNF and static semantics . 27
A.1 Modified TTCN-3 syntax BNF productions . 27
A.2 Deleted TTCN-3 syntax BNF productions . 27
A.3 Additional TTCN-3 syntax BNF productions . 27
History . 29
ETSI
---------------------- Page: 5 ----------------------
SIST ES 203 022 V1.1.1:2017
4 ETSI ES 203 022 V1.1.1 (2017-07)
Intellectual Property Rights
IPRs essential or potentially essential to the present document may have been declared to ETSI. The information
pertaining to these essential IPRs, if any, is publicly available for ETSI members and non-members, and can be found
in ETSI SR 000 314: "Intellectual Property Rights (IPRs); Essential, or potentially Essential, IPRs notified to ETSI in
respect of ETSI standards", which is available from the ETSI Secretariat. Latest updates are available on the ETSI Web
server (https://ipr.etsi.org/).
Pursuant to the ETSI IPR Policy, no investigation, including IPR searches, has been carried out by ETSI. No guarantee
can be given as to the existence of other IPRs not referenced in ETSI SR 000 314 (or the updates on the ETSI Web
server) which are, or may be, or may become, essential to the present document.
Foreword
This ETSI Standard (ES) has been produced by ETSI Technical Committee Methods for Testing and Specification
(MTS).
The present document relates to the multi-part standard ETSI ES 201 873 covering the Testing and Test Control
Notation version 3, as identified below:
Part 1: "TTCN-3 Core Language";
Part 4: "TTCN-3 Operational Semantics";
Part 5: "TTCN-3 Runtime Interface (TRI)";
Part 6: "TTCN-3 Control Interface (TCI)";
Part 7: "Using ASN.1 with TTCN-3";
Part 8: "The IDL to TTCN-3 Mapping";
Part 9: "Using XML schema with TTCN-3";
Part 10: "TTCN-3 Documentation Comment Specification";
Part 11: "Using JSON with TTCN-3".
NOTE: Part 2 is in status "historical" and part 3 is no longer maintained.
Modal verbs terminology
In the present document "shall", "shall not", "should", "should not", "may", "need not", "will", "will not", "can" and
"cannot" are to be interpreted as described in clause 3.2 of the ETSI Drafting Rules (Verbal forms for the expression of
provisions).
"must" and "must not" are NOT allowed in ETSI deliverables except when used in direct citation.
ETSI
---------------------- Page: 6 ----------------------
SIST ES 203 022 V1.1.1:2017
5 ETSI ES 203 022 V1.1.1 (2017-07)
1 Scope
The present document defines the support of advance matching of TTCN-3. TTCN-3 can be used for the specification
of all types of reactive system tests over a variety of communication ports. Typical areas of application are protocol
testing (including mobile and Internet protocols), service testing (including supplementary services), module testing,
testing of OMG CORBA based platforms, APIs, etc. TTCN-3 is not restricted to conformance testing and can be used
for many other kinds of testing including interoperability, robustness, regression, system and integration testing. The
specification of test suites for physical layer protocols is outside the scope of the present document.
TTCN-3 packages are intended to define additional TTCN-3 concepts, which are not mandatory as concepts in the
TTCN-3 core language, but which are optional as part of a package which is suited for dedicated applications and/or
usages of TTCN-3.
While the design of TTCN-3 package has taken into account the consistency of a combined usage of the core language
with a number of packages, the concrete usages of and guidelines for this package in combination with other packages
is outside the scope of the present document.
2 References
2.1 Normative references
References are either specific (identified by date of publication and/or edition number or version number) or
non-specific. For specific references,only the cited version applies. For non-specific references, the latest version of the
referenced document (including any amendments) applies.
Referenced documents which are not found to be publicly available in the expected location might be found at
https://docbox.etsi.org/Reference/.
NOTE: While any hyperlinks included in this clause were valid at the time of publication, ETSI cannot guarantee
their long term validity.
The following referenced documents are necessary for the application of the present document.
[1] ETSI ES 201 873-1: "Methods for Testing and Specification (MTS); The Testing and Test Control
Notation version 3; Part 1: TTCN-3 Core Language".
[2] ETSI ES 201 873-4: "Methods for Testing and Specification (MTS); The Testing and Test Control
Notation version 3; Part 4: TTCN-3 Operational Semantics".
[3] ETSI ES 201 873-5: "Methods for Testing and Specification (MTS); The Testing and Test Control
Notation version 3; Part 5: TTCN-3 Runtime Interface (TRI)".
[4] ETSI ES 201 873-6: "Methods for Testing and Specification (MTS); The Testing and Test Control
Notation version 3; Part 6: TTCN-3 Control Interface (TCI)".
2.2 Informative references
References are either specific (identified by date of publication and/or edition number or version number) or
non-specific. For specific references,only the cited version applies. For non-specific references, the latest version of the
referenced document (including any amendments) applies.
NOTE: While any hyperlinks included in this clause were valid at the time of publication, ETSI cannot guarantee
their long term validity.
The following referenced documents are not necessary for the application of the present document but they assist the
user with regard to a particular subject area.
[i.1] ETSI ES 201 873-7: "Methods for Testing and Specification (MTS); The Testing and Test Control
Notation version 3; Part 7: Using ASN.1 with TTCN-3".
ETSI
---------------------- Page: 7 ----------------------
SIST ES 203 022 V1.1.1:2017
6 ETSI ES 203 022 V1.1.1 (2017-07)
[i.2] ETSI ES 201 873-8: "Methods for Testing and Specification (MTS); The Testing and Test Control
Notation version 3; Part 8: The IDL to TTCN-3 Mapping".
[i.3] ETSI ES 201 873-9: "Methods for Testing and Specification (MTS); The Testing and Test Control
Notation version 3; Part 9: Using XML schema with TTCN-3".
[i.4] ETSI ES 201 873-10: "Methods for Testing and Specification (MTS); The Testing and Test
Control Notation version 3; Part 10: TTCN-3 Documentation Comment Specification".
3 Definitions and abbreviations
3.1 Definitions
For the purposes of the present document, the terms and definitions given in ETSI ES 201 873-1 [1], ETSI
ES 201 873-4 [2], ETSI ES 201 873-5 [3] and ETSI ES 201 873-6 [4] apply.
3.2 Abbreviations
For the purposes of the present document, the abbreviations given in ETSI ES 201 873-1 [1], ETSI ES 201 873-4 [2],
ETSI ES 201 873-5 [3] and ETSI ES 201 873-6 [4] apply.
4 Package conformance and compatibility
The package presented in the present document is identified by the package tag:
"TTCN-3:2017 Advanced Matching" - to be used with modules complying with the present document.
For an implementation claiming to conform to this package version, all features specified in the present document shall
be implemented consistently with the requirements given in the present document and in ETSI ES 201 873-1 [1] and
ETSI ES 201 873-4 [2].
The package presented in the present document is compatible to:
• ETSI ES 201 873-1 [1], version 4.9.1;
• ETSI ES 201 873-4 [2], version 4.6.1;
• ETSI ES 201 873-5 [3], version 4.8.1;
• ETSI ES 201 873-6 [4], version 4.9.1;
• ETSI ES 201 873-7 [i.1];
• ETSI ES 201 873-8 [i.2];
• ETSI ES 201 873-9 [i.3];
• ETSI ES 201 873-10 [i.4].
If later versions of those parts are available and should be used instead, the compatibility to the package presented in the
present document has to be checked individually.
ETSI
---------------------- Page: 8 ----------------------
SIST ES 203 022 V1.1.1:2017
7 ETSI ES 203 022 V1.1.1 (2017-07)
5 Package Concepts for the Core Language
5.0 General
This package defines advanced matching mechanisms for TTCN-3, i.e. new matching mechanisms which go beyond the
matching mechanisms defined in ETSI ES 201 873-1 [1]. This package realizes the following concepts:
• Dynamic matching allows to specify matching in a function-like fashion, i.e. statement blocks and functions
can be used to define matching.
• Templates with variable bindings ease the retrieval field values of received messages and signatures. For this
the "->" symbol is used to denote a value assignment to a variable or an out parameter in the scope of a
template definition in case of a successful template matching.
• The additional logical operators conjunction, implication, exclusion and disjunction allow the combination
matching mechanisms for advanced matching.
• Repetition allows to match repetitions of a sub-sequence templates inside values of a certain type.
• Restrictions for the omit symbol and templates with restriction omit are relieved allowing omit symbols and
templates with restriction omit as operands for the equality operator.
5.1 Dynamic Matching
A dynamic matching is a special matching mechanism. Similar to other matching mechanisms, it can be considered as a
Boolean function that indicates successful matching for the value to be matched by returning the value true and
unsuccessful matching by returning the value false.
Syntactical Structure
@dynamic (StatementBlock | FunctionRef)
Semantic Description
The StatementBlock shall return a value of type boolean. The value to be matched is referenced by the special
keyword value. When applying this matching mechanism to a value, the StatementBlock is executed and if and only if
the execution returns true, the dynamic matching function matches. Unsuccessful matching shall return false.
A dynamic matching function can only be used in the context of a template, the value expression inside the
StatementBlock shall have the same type as the whole template.
The notation @dynamic FunctionRef denotes a shorthand for the special case @dynamic { return
FunctionRef(value) } where FunctionRef is a reference to a Boolean function with a single parameter compatible
with the template's type. Here, the type of the parameter of the referenced function determines the type context, if this
template's place of usage does not provide a type context.
Restrictions
a) The dynamic matching syntax shall only be used in a typed context.
b) The StatementBlock shall compute a value of type boolean.
c) The StatementBlock shall be deterministic and side-effect free and follow the restrictions of clause 16.1.4 of
ETSI ES 201 873-1 [1].
d) The StatementBlock shall not use variables that are declared outside of the StatementBlock.
e) The StatementBlock shall not use inout or out parameters.
ETSI
---------------------- Page: 9 ----------------------
SIST ES 203 022 V1.1.1:2017
8 ETSI ES 203 022 V1.1.1 (2017-07)
f) Only if the dynamic matching syntax appears on the right-hand-side of a parameterized template definition, the
formal in parameters of that definition may be referenced inside the StatementBlock. All other formal in
parameters shall not be used by the StatementBlock.
EXAMPLE:
type record of integer Numbers;
template Numbers mw_sorted := @dynamic { // value is of type Numbers
for (var integer v_i := 1; v_i < lengthof(value); v_i := v_i + 1) {
if (value[v_i-1] > value[v_i]) { return false }
}
return true;
} // mw_sorted(v_recInt) matches all values of type Numbers
// if elements of v_recInt do not break an ascending order
type record Coordinate { float x, float y };
external function fx_distance(Coordinate p_a, Coordinate p_b) return float;
template float mw_closeTo(Coordinate p_origin := { 0.0, 0.0 }, float p_maxDistance := 1.0) :=
// access to in parameters is allowed
@dynamic { return fx_distance(p_origin, value) <= p_maxDistance; };
// mw_closeTo(c,d) matches all values of type Coordinate
// which have maximum distance of d from Coordinate c
external function fx_isPrime(integer p_x) return boolean;
:
p.receive(@dynamic fx_isPrime)
// is the same as p.receive(integer:@dynamic { return fx_isPrime(value) })
5.2 Templates with variable bindings
5.2.0 General
The possibilities to retrieve field values of received messages and signatures in ETSI ES 201 873-1 [1] are restricted
and cumbersome. To overcome this situation, this clause implements the definition of templates with variable bindings
that store the actual value matched by a template instance if the matching of all containing templates is successful. This
feature is implemented by using the "->" symbol for denoting a value assignment to a variable or an out parameter in the
scope of a template definition in case of a successful template matching. Such a value assignment can syntactically be
specified at all places where a template matching mechanism or a template reference is used in a template definition or
an inline template.
5.2.1 Value retrieval from matching
In case of a successful template match, the value which matches the template can be assigned to a variable. This can be
specified by using the "->" symbol.
Syntactical Structure
TemplateInstance "->" VariableRef
Semantic Description
If a template successfully matches a value and contains a value retrieval assignment for a TemplateInstance, then, if
during the matching process that TemplateInstance and all its containing TemplateInstances contribute to the successful
template match, the part of the value the TemplateInstance was matching is assigned to the VariableRef referenced in
the value retrieval assignment.
EXAMPLE:
template integer mw_t1 := (?, (1.3) -> v); // mw_t1 always matches, but if the (1.3) does not
// contribute to the successful match
// then v is not assigned a value
template integer mw_t2 := ((1.3) -> v_small, (3.5) -> v_big)
// matching mw_t2 to number in (1.3) will cause only v_small to be assigned,
// matching it to number in (4.5) will cause only v_big to be assigned (preference of (1.3))
ETSI
---------------------- Page: 10 ----------------------
SIST ES 203 022 V1.1.1:2017
9 ETSI ES 203 022 V1.1.1 (2017-07)
Restrictions
a) If TempateInstance describes the matching of a mandatory element in a template definition, VariableRef shall
refer to a variable of the same type as the mandatory element.
b) If TempateInstance describes the matching of an optional element in a template definition, VariableRef shall
refer to a template variable of the same type as the optional element. In case of a successful matching, the
matching value or omit shall be assigned to the template variable denoted by VariableRef.
c) Value retrieval shall not be used in special places as described in clause 16.1.4 of ETSI ES 201 873-1 [1] with
the exception of the matching parts of receiving operations. If value retrieval is used in the matching part of a
receiving operation, the assignment to the variables of all the templates is done once the whole matching part
matches and all other conditions for the selection of the alternative are met.
d) Value retrieval shall not be applied to templates of set of types or any of their direct or indirect elements,
elements of a permutation matching mechanism or any of their direct or indirect elements.
NOTE: TTCN-3 makes no assumptions about the value of the variable or template variable denoted by
VariableRef My in case of an unsuccessful match.
5.2.2 Declaring out parameters for template definitions
The retrieval of field values in case of successful matching from a structured value can be specified by means of out
parameters of template definitions.
Syntactical Structure
The syntactical structure for global and local template definitions does not change:
template [ restriction ] [ @fuzzy ] Type TemplateIdentifier ["(" TemplateFormalParList ")"]
[ modifies TemplateRef ] ":=" TemplateBody
Only the static semantics restriction for formal template parameters change in such a way that formal template
parameters shall evaluate to in or out parameters.
Semantic Description
The semantics of the value retrieval using templates with out parameters can be described by means of the match
operation:
// Given the record type definition
type record MyRecordType {
integer field1,
boolean field2
}
// the constant definition
const MyRecordType c_myRecord := {
field1 := 7,
field2 := true
}
// the template definition
template MyRecordType mw_myTemplate1 := {
field1 := 7,
field2 := ?
}
// the same template definition with an out parameter matchinstring
template MyRecordType mw_myTemplate2 (out boolean p_matchingBool):= {
field1 := 7,
field2 := ? -> p_matchingBool
}
// and the variable declarations
var boolean v_a, v_b;
// then the effect of
v_a := match (c_myRecord, mw_myTemplate2(v_b));
ETSI
---------------------- Page: 11 ----------------------
SIST ES 203 022 V1.1.1:2017
10 ETSI ES 203 022 V1.1.1 (2017-07)
// is identical to
if (match (c_myRecord, mw_myTemplate1) {
v_a := true;
v_b := c_myRecord.field2 // i.e., true
}
else {
v_a:= false;
}
Restrictions
a) TempateInstance with out parameters shall not be used as templates of set of types or any of their direct or
indirect elements.
b) TempateInstance with out parameters shall not be used as elements of a permutation matching mechanism or
any of their direct or indirect elements. TempateInstance with out parameters shall not used in special places
as described in clause 16.1.4 of ETSI ES 201 873-1 [1] with the exception of the matching parts of receiving
operations. If TempateInstance with out parameters are used in the matching part of a receiving operation, the
assignment to the actual out parameter variables of all the templates is done only once the whole matching
part matches and all other conditions for the selection of the alternative are met.
c) Every formal out parameter of a template with out parameters shall be referenced at most once inside the
template body.
NOTE: In certain cases a template may match without assigning a value to a declared out parameter. In such
cases, the boundness of the actual out parameter has to be checked even after a successful match before
using it.
EXAMPLE 1:
type union Tree {
integer leaf,
Branch branch
}
type record Branch {
Tree left optional,
Tree right optional
}
template Branch mw_branch(out omit Tree p_left, out omit Tree p_right) := {
left := * -> p_left,
right := * -> p_right
}
template Tree mw_treebranch(out omit Tree p_left, out omit Tree p_right) :=
{ branch := mw_branch(p_left, p_right) }
template Tree mw_leaf(out integer p_value, in template integer p_expected := ?) :=
{ leaf := p_expected -> p_value }
// compute the sum of absolute values of all leafs in the given tree
function f_absSum(omit Tree p_tree) return integer {
var omit Tree v_left, v_right;
var integer v_value;
if (ispresent(p_tree)) {
select (p_tree) {
case (mw_treebranch(v_left, v_right)) {
return f_absSum(v_left) + f_absSum(v_right);
}
case (mw_leaf(v_value, (0 . infinity)) { return v_value; }
case (mw_leaf(v_value) { return -v_value; }
}
}
else {
return 0; }
}
ETSI
---------------------- Page: 12 ----------------------
SIST ES 203 022 V1.1.1:2017
11 ETSI ES 203 022 V1.1.1 (2017-07)
EXAMPLE 2:
var Tree v_tree;
…
template Tree mw_anyTree(out integer p_value,
out omit Tree p_left, out omit Tree p_right) :=
(mw_leaf(p_value), mw_treebranch(p_left, p_right));
// extraction of leaf or branch from v_tree (any value, if present)
if (match(v_tree, mw_anyTree(v_value, v_left, v_right)) {
if (isbound(v_value)) {
// v_value might not have been assigned => needs check
}
else if (isbound(v_left)) {
// v_left and v_right might not have been assigned
// => needs check
}
}
EXAMPLE 3: Receiving with multiple out parameter templates
signature S(out Tree p_tree) return Tree;
alt {
[match(v_tree, mw_leaf(v_value)] p.receive { }
// NOT allowed to use template wit
...
Questions, Comments and Discussion
Ask us and Technical Secretary will try to provide an answer. You can facilitate discussion about the standard in here.