blob: 22ed40587901b821ed08a57ff2ba6a0a9f0aa99d [file] [log] [blame]
Harald Welte03c0e562017-12-09 02:55:12 +01001module Osmocom_CTRL_Functions {
Harald Welte35bb7162018-01-03 21:07:52 +01002
3/* Definition of helper functions for the Osmocom CTRL interface.
4 *
5 * As opposed to many other parts of the Osmocom TTCN-3 code base, this module
6 * implements blocking functions, instead of asynchronous functions. The
7 * rationale for this is simple: One normally wants to inquire a value or set
8 * a value and not continue the main program until that operation is complete.
Pau Espin Pedrol76ba5412019-06-10 11:00:33 +02009 *
Harald Welte35bb7162018-01-03 21:07:52 +010010 * CTRL is a machine-type protocol on how external programs can interact with
11 * an Osmocom program in a structured way. It is intended for programmatic
12 * access (by other software), as opposed to the VTY interface intended for
13 * human consumption.
14 *
15 * (C) 2017 by Harald Welte <laforge@gnumonks.org>
16 * All rights reserved.
17 *
18 * Released under the terms of GNU General Public License, Version 2 or
19 * (at your option) any later version.
20 */
21
22
Harald Welte03c0e562017-12-09 02:55:12 +010023 import from Osmocom_CTRL_Types all;
24 import from IPA_Emulation all;
25
26 private function f_gen_rand_id() return CtrlId {
27 return int2str(float2int(rnd()*999999999.0));
28 }
29
30 /* perform a given GET Operation */
31 function f_ctrl_get(IPA_CTRL_PT pt, CtrlVariable variable) return CtrlValue {
32 timer T := 2.0;
33 var CtrlMessage rx;
34 var CtrlId id := f_gen_rand_id();
35 pt.send(ts_CtrlMsgGet(id, variable));
36 T.start;
37 alt {
Harald Weltefdfa0462017-12-10 18:09:40 +010038 [] pt.receive(tr_CtrlMsgGetRepl(id, variable)) -> value rx {
39 }
Harald Welte95a47812017-12-09 14:19:03 +010040 [] pt.receive(tr_CtrlMsgTrap) { repeat; }
Harald Welte03c0e562017-12-09 02:55:12 +010041 [] pt.receive(tr_CtrlMsgError) -> value rx {
42 setverdict(fail, "Error in CTRL GET ", variable, ": ", rx.err.reason);
Daniel Willmanne4ff5372018-07-05 17:35:03 +020043 mtc.stop;
Harald Welte03c0e562017-12-09 02:55:12 +010044 }
45 [] T.timeout {
46 setverdict(fail, "Timeout waiting for CTRL GET REPLY ", variable);
Daniel Willmanne4ff5372018-07-05 17:35:03 +020047 mtc.stop;
Harald Welte03c0e562017-12-09 02:55:12 +010048 }
49 }
50 return rx.resp.val;
51 }
52
53 /* perform a given SET Operation */
54 function f_ctrl_set(IPA_CTRL_PT pt, CtrlVariable variable, CtrlValue val) {
55 timer T := 2.0;
56 var CtrlMessage rx;
57 var CtrlId id := f_gen_rand_id();
58 pt.send(ts_CtrlMsgSet(id, variable, val));
59 T.start;
60 alt {
61 [] pt.receive(tr_CtrlMsgSetRepl(id, variable, val)) { }
Harald Welte95a47812017-12-09 14:19:03 +010062 [] pt.receive(tr_CtrlMsgTrap) { repeat; }
Harald Welte03c0e562017-12-09 02:55:12 +010063 [] pt.receive(tr_CtrlMsgError) -> value rx {
64 setverdict(fail, "Error in CTRL GET ", variable, ": ", rx.err.reason);
Daniel Willmanne4ff5372018-07-05 17:35:03 +020065 mtc.stop;
Harald Welte03c0e562017-12-09 02:55:12 +010066 }
67 [] T.timeout {
68 setverdict(fail, "Timeout waiting for CTRL SET REPLY ", variable);
Daniel Willmanne4ff5372018-07-05 17:35:03 +020069 mtc.stop;
Harald Welte03c0e562017-12-09 02:55:12 +010070 }
71 }
72 }
73
Pau Espin Pedrol579cd7a2019-06-10 21:01:30 +020074 /* send a TRAP */
75 function f_ctrl_trap(IPA_CTRL_PT pt, CtrlVariable variable, CtrlValue val) {
76 pt.send(ts_CtrlMsgTrap(variable, val));
77 }
78
Harald Welte03c0e562017-12-09 02:55:12 +010079 /* Expect a matching TRAP */
80 function f_ctrl_exp_trap(IPA_CTRL_PT pt, template CtrlVariable variable,
Pau Espin Pedrol579cd7a2019-06-10 21:01:30 +020081 template CtrlValue val := ?, float timeout_val := 2.0)
82 return CtrlValue {
83 timer T := timeout_val;
Harald Welte03c0e562017-12-09 02:55:12 +010084 var CtrlMessage rx;
85 T.start;
86 alt {
Harald Weltefdfa0462017-12-10 18:09:40 +010087 [] pt.receive(tr_CtrlMsgTrap(variable, val)) -> value rx {
88 }
Harald Welte03c0e562017-12-09 02:55:12 +010089 [] T.timeout {
90 setverdict(fail, "Timeout waiting for TRAP ", variable);
Daniel Willmanne4ff5372018-07-05 17:35:03 +020091 mtc.stop;
Harald Welte03c0e562017-12-09 02:55:12 +010092 }
93 }
94 return rx.trap.val;
95 }
Harald Welte852a3842017-12-09 14:19:36 +010096
Pau Espin Pedrol579cd7a2019-06-10 21:01:30 +020097 /* Expect a matching SET, optionally answer */
98 function f_ctrl_exp_set(IPA_CTRL_PT pt, template CtrlVariable variable,
99 template CtrlValue val := ?,
100 template (omit) CtrlValue rsp := omit,
101 float timeout_val := 2.0)
102 return CtrlValue {
103 timer T := timeout_val;
104 var CtrlMessage rx;
105 T.start;
106 alt {
107 [] pt.receive(tr_CtrlMsgSet(?, variable, val)) -> value rx {
108 if (ispresent(rsp)) {
109 pt.send(ts_CtrlMsgSetRepl(rx.cmd.id, valueof(variable), valueof(rsp)));
110 }
111 }
112 [] T.timeout {
113 setverdict(fail, "Timeout waiting for SET ", variable);
114 mtc.stop;
115 }
116 }
117 return rx.cmd.val;
118 }
119
Harald Welte852a3842017-12-09 14:19:36 +0100120 /* Expect a matching GET result */
121 function f_ctrl_get_exp(IPA_CTRL_PT pt, CtrlVariable variable, template CtrlValue exp) {
122 var charstring ctrl_resp;
123 ctrl_resp := f_ctrl_get(pt, variable);
124 if (not match(ctrl_resp, exp)) {
125 setverdict(fail, "Unexpected " & variable & ":" & ctrl_resp);
Daniel Willmanne4ff5372018-07-05 17:35:03 +0200126 mtc.stop;
Harald Welte852a3842017-12-09 14:19:36 +0100127 }
128 }
129
Harald Welte3ec493f2017-12-09 16:25:29 +0100130 template charstring ts_ctrl_ratectr(CtrlVariable grp, integer instance, CtrlVariable name,
131 CtrlVariable kind := "abs") :=
132 "rate_ctr." & kind & "." & grp & "." & int2str(instance) & "." & name;
133
134 function f_ctrl_get_ratectr_abs(IPA_CTRL_PT pt, CtrlVariable grp, integer instance,
135 CtrlVariable name) return integer {
136 return str2int(f_ctrl_get(pt, valueof(ts_ctrl_ratectr(grp, instance, name))));
137 }
138
139 function f_ctrl_get_exp_ratectr_abs(IPA_CTRL_PT pt, CtrlVariable grp, integer instance,
140 CtrlVariable name, template integer exp) {
141 var charstring ctrl_resp;
142 var CtrlVariable variable := valueof(ts_ctrl_ratectr(grp, instance, name));
143 ctrl_resp := f_ctrl_get(pt, variable);
144 if (not match(str2int(ctrl_resp), exp)) {
145 setverdict(fail, variable & " value " & ctrl_resp & " didn't match ", exp);
Daniel Willmanne4ff5372018-07-05 17:35:03 +0200146 mtc.stop;
Harald Welte3ec493f2017-12-09 16:25:29 +0100147 }
148 }
149
Harald Welte852a3842017-12-09 14:19:36 +0100150
Harald Welte03c0e562017-12-09 02:55:12 +0100151}