1 /******************************************************************************
2 * Copyright (c) 2000-2016 Ericsson Telecom AB
3 * All rights reserved. This program and the accompanying materials
4 * are made available under the terms of the Eclipse Public License v1.0
5 * which accompanies this distribution, and is available at
6 * http://www.eclipse.org/legal/epl-v10.html
9 * Adrien Kirjak – initial implementation
12 ** @purpose 1:22.3.4, applying @decoded to a forbidden parameter field
13 ** @verdict pass reject
14 *****************************************************************/
16 // The following requirements are tested:
17 // When assigning individual fields of a reply, encoded parameters can be decoded
18 // prior to assignment using the @decoded modifier. In this case, the referenced
19 // parameter on the right hand sided of the assignment shall be one of the
20 // bitstring, hexstring, octetstring, charstring or universal charstring types. It
21 // shall be decoded into a value of the same type as the variable on the left hand
22 // side of the assignment.
24 module NegSem_220304_getreply_operation_015 {
27 record of integer payload(0..255)
30 signature S() return R;
32 type port P procedure {
34 } with {extension "internal"}
36 type component GeneralComp {
40 function f_server() runs on GeneralComp {
41 var R v_rec := { id := 6, payload := { 0, 0, 0, 0 }}
43 p.reply(S:{} value v_rec);
46 testcase TC_NegSem_220304_getreply_operation_015() runs on GeneralComp system GeneralComp {
47 var integer v_res with { encode "32bit" };
48 var GeneralComp v_ptc := GeneralComp.create("PTC");
49 connect(self:p, v_ptc:p);
50 v_ptc.start(f_server());
52 [] p.getreply(S:?) -> value (v_res := @decoded payload) {
55 [] p.getreply { setverdict(fail); }
61 execute(TC_NegSem_220304_getreply_operation_015(), 5.0);