blob: 52f6378d2bf65cfdc819e4c0be529035e52f1187 [file] [log] [blame]
Harald Welte08332302019-08-01 09:54:40 +02001module CBC_Tests {
2
3import from Osmocom_Types all;
Pau Espin Pedrol7c13cb72022-06-16 19:03:44 +02004import from Socket_API_Definitions all;
Harald Welte08332302019-08-01 09:54:40 +02005
6import from BSSAP_Types all;
7import from BSSMAP_Templates all;
8import from CBSP_Types all;
9import from CBSP_Templates all;
10import from CBSP_Adapter all;
11import from CBSP_CodecPort all;
Pau Espin Pedrol7c13cb72022-06-16 19:03:44 +020012
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +020013import from SABP_Types all;
14import from SABP_Templates all;
15import from SABP_IEs all;
16import from SABP_PDU_Descriptions all;
17
Pau Espin Pedrol7c13cb72022-06-16 19:03:44 +020018import from SBC_AP_IEs all;
19import from SBC_AP_Constants all;
20import from SBC_AP_PDU_Contents all;
21import from SBC_AP_PDU_Descriptions all;
22import from SBC_AP_Types all;
23import from SBC_AP_Templates all;
24import from SBC_AP_CodecPort all;
25import from SBC_AP_Adapter all;
Harald Welte08332302019-08-01 09:54:40 +020026
27import from HTTP_Adapter all;
28import from HTTPmsg_Types all;
29import from ECBE_Types all;
30
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +020031import from CBS_Message all;
32import from ECBE_Components all;
33import from BSC_ConnectionHandler all;
34import from MME_ConnectionHandler all;
35
Pau Espin Pedroldb247f82022-08-01 17:55:22 +020036const integer MAX_BSC := 2;
37const integer MAX_MME := 2;
38
39type record BSC_modulepar_cfg {
40 boolean tcp_is_client
41};
42type record of BSC_modulepar_cfg BSC_modulepar_cfgs;
43
44type record MME_modulepar_cfg {
45 boolean sctp_is_client
46};
47type record of MME_modulepar_cfg MME_modulepar_cfgs;
48
Harald Welte08332302019-08-01 09:54:40 +020049modulepar {
Pau Espin Pedroldb247f82022-08-01 17:55:22 +020050 charstring mp_local_host := "127.0.0.2";
Harald Welte08332302019-08-01 09:54:40 +020051 charstring mp_cbc_host := "127.0.0.1";
Pau Espin Pedrol07746ad2022-06-16 19:02:04 +020052 integer mp_cbc_cbsp_port := 48049;
Pau Espin Pedrol7c13cb72022-06-16 19:03:44 +020053 integer mp_cbc_sbcap_port := c_SBC_AP_PORT;
Pau Espin Pedrol07746ad2022-06-16 19:02:04 +020054 integer mp_cbc_ecbe_port := 12345;
Pau Espin Pedrole14c2082022-07-29 16:41:02 +020055 integer mp_local_cbsp_port := 15000;
56 integer mp_local_sbcap_port := 16000;
Pau Espin Pedroldb247f82022-08-01 17:55:22 +020057 /* Must match osmo-cbc.cfg: */
58 BSC_modulepar_cfgs mp_bsc_cfg := {
59 { tcp_is_client := true },
60 { tcp_is_client := false }
61 };
62 MME_modulepar_cfgs mp_mme_cfg := {
63 { sctp_is_client := true },
64 { sctp_is_client := false }
65 };
Harald Welte08332302019-08-01 09:54:40 +020066};
67
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +020068type component test_CT extends CBSP_Adapter_CT, http_CT {
Pau Espin Pedrol7e451282022-08-01 19:32:23 +020069 timer g_Tguard := 60.0;
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +020070 var integer g_num_bsc;
71 var integer g_num_mme;
72 var BSC_ConnHdlr g_vc_conn_BSC[MAX_BSC];
73 var MME_ConnHdlr g_vc_conn_MME[MAX_MME];
74 var BSC_ConnHdlrPars g_pars_BSC[MAX_BSC];
75 var MME_ConnHdlrPars g_pars_MME[MAX_MME];
Pau Espin Pedroldb247f82022-08-01 17:55:22 +020076 port BSC_ConnHdlr_Coord_PT COORD_BSC[MAX_BSC];
77 port MME_ConnHdlr_Coord_PT COORD_MME[MAX_BSC];
Harald Welte08332302019-08-01 09:54:40 +020078};
79
Pau Espin Pedrol9d8b6bf2022-06-23 12:19:47 +020080private function f_shutdown_helper() runs on test_CT {
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +020081 /* Wait for all BSC cons to terminate */
82 for (var integer i := 0; i < g_num_bsc; i := i + 1) {
83 g_vc_conn_BSC[i].done;
84 }
85 /* Wait for all MME cons to terminate */
86 for (var integer i := 0; i < g_num_mme; i := i + 1) {
87 g_vc_conn_MME[i].done;
88 }
Pau Espin Pedrol9d8b6bf2022-06-23 12:19:47 +020089 all component.stop;
90 setverdict(pass);
91 mtc.stop;
92}
93
Pau Espin Pedrol7e451282022-08-01 19:32:23 +020094/* altstep for the global guard timer */
95private altstep as_Tguard() runs on test_CT {
96 [] g_Tguard.timeout {
97 setverdict(fail, "Tguard timeout");
98 all component.stop;
99 mtc.stop;
100 }
101}
102
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200103/*
104 * BSC Conn Handler:
105 */
106private function f_BSC_ConnHdlr_start_fn_void() runs on BSC_ConnHdlr {
107 log("Default start_fn() function called!");
108}
Pau Espin Pedroldb247f82022-08-01 17:55:22 +0200109private function f_init_pars_bsc(charstring bsc_host, integer bsc_cbsp_port,
110 charstring cbc_host, integer cbc_cbsp_port,
111 boolean tcp_is_client)
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200112 runs on test_CT return BSC_ConnHdlrPars {
113 var BSC_ConnHdlrPars pars := {
Pau Espin Pedroldb247f82022-08-01 17:55:22 +0200114 bsc_host := bsc_host,
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200115 bsc_cbsp_port := bsc_cbsp_port,
116 cbc_host := cbc_host,
117 cbc_cbsp_port := cbc_cbsp_port,
Pau Espin Pedroldb247f82022-08-01 17:55:22 +0200118 tcp_is_client := tcp_is_client,
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200119 start_fn := refers(f_BSC_ConnHdlr_start_fn_void),
120 exp_cbs_msg := omit,
Pau Espin Pedrol6dd5a0f2022-08-05 15:16:48 +0200121 cell_list_success := omit,
122 tx_fail_list := omit
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200123 };
124 return pars;
125}
Harald Welte08332302019-08-01 09:54:40 +0200126
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200127private function f_init_bsc(integer idx, charstring id) runs on test_CT return BSC_ConnHdlr {
128 var BSC_ConnHdlr vc_conn;
129 id := id & "-BSC" & int2str(idx);
130 vc_conn := BSC_ConnHdlr.create(id) alive;
Pau Espin Pedroldb247f82022-08-01 17:55:22 +0200131 g_pars_BSC[idx] := f_init_pars_bsc(mp_local_host, mp_local_cbsp_port + idx,
132 mp_cbc_host, mp_cbc_cbsp_port,
133 mp_bsc_cfg[idx].tcp_is_client);
134 connect(self:COORD_BSC[idx], vc_conn:COORD);
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200135 return vc_conn;
136}
137
138private function f_start_bsc(integer idx, charstring id, BSC_ConnHdlrPars pars)
139 runs on test_CT {
140 id := id & "-BSC" & int2str(idx);
141 g_vc_conn_BSC[idx] := f_init_bsc(idx, id);
142 g_vc_conn_BSC[idx].start(f_BSC_ConnHdlr_main(id, pars));
143}
144
145/*
146 * MME Conn Handler:
147 */
148private function f_MME_ConnHdlr_start_fn_void() runs on MME_ConnHdlr {
149 log("Default start_fn() function called!");
150}
Pau Espin Pedroldb247f82022-08-01 17:55:22 +0200151private function f_init_pars_mme(charstring mme_host, integer mme_sbcap_port,
152 charstring cbc_host, integer cbc_sbcap_port,
153 boolean sctp_is_client)
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200154 runs on test_CT return MME_ConnHdlrPars {
155 var MME_ConnHdlrPars pars := {
Pau Espin Pedroldb247f82022-08-01 17:55:22 +0200156 mme_host := mme_host,
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200157 mme_sbcap_port := mme_sbcap_port,
158 cbc_host := cbc_host,
159 cbc_sbcap_port := cbc_sbcap_port,
Pau Espin Pedroldb247f82022-08-01 17:55:22 +0200160 sctp_is_client := sctp_is_client,
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200161 start_fn := refers(f_MME_ConnHdlr_start_fn_void),
Pau Espin Pedrolae2e5152022-07-29 19:16:23 +0200162 exp_cbs_msg := omit,
Pau Espin Pedrol6b3e8e32022-08-05 16:21:32 +0200163 write_replace_warning_req_cause := SBC_AP_Cause_message_accepted,
Pau Espin Pedrolae2e5152022-07-29 19:16:23 +0200164 write_replace_warning_ind_cause := omit,
Pau Espin Pedrolb1a83fb2022-08-02 13:17:47 +0200165 write_repl_unknown_TAIs := omit,
Pau Espin Pedrolae2e5152022-07-29 19:16:23 +0200166 bcast_cell_id_list := omit
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200167 };
168 return pars;
169}
170
171private function f_init_mme(integer idx, charstring id) runs on test_CT return MME_ConnHdlr {
172 var MME_ConnHdlr vc_conn;
173 id := id & "-MME" & int2str(idx);
174 vc_conn := MME_ConnHdlr.create(id) alive;
Pau Espin Pedroldb247f82022-08-01 17:55:22 +0200175 g_pars_MME[idx] := f_init_pars_mme(mp_local_host, mp_local_sbcap_port + idx,
176 mp_cbc_host, mp_cbc_sbcap_port,
177 mp_mme_cfg[idx].sctp_is_client);
178 connect(self:COORD_MME[idx], vc_conn:COORD);
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200179 return vc_conn;
180}
181
182private function f_start_mme(integer idx, charstring id, MME_ConnHdlrPars pars)
183 runs on test_CT {
184 id := id & "-MME" & int2str(idx);
185 g_vc_conn_MME[idx] := f_init_mme(idx, id);
186 g_vc_conn_MME[idx].start(f_MME_ConnHdlr_main(id, pars));
187}
188
Pau Espin Pedrol19763462022-07-29 10:47:33 +0200189private function f_init(integer num_bsc := 0, integer num_mme := 0) runs on test_CT {
Vadim Yanitskiy11f8ac82024-04-25 15:55:10 +0700190 var HTTP_Adapter_Params http_adapter_pars := {
Philipp Maier260f7082024-04-19 13:12:49 +0200191 http_host := mp_cbc_host,
Vadim Yanitskiy11f8ac82024-04-25 15:55:10 +0700192 http_port := mp_cbc_ecbe_port,
193 use_ssl := false
Philipp Maier260f7082024-04-19 13:12:49 +0200194 };
195 f_http_init(http_adapter_pars);
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200196
197 g_num_bsc := num_bsc;
198 for (var integer i := 0; i < g_num_bsc; i := i + 1) {
199 g_vc_conn_BSC[i] := f_init_bsc(i, testcasename());
200 }
201
202 g_num_mme := num_mme;
203 for (var integer i := 0; i < g_num_mme; i := i + 1) {
204 g_vc_conn_MME[i] := f_init_mme(i, testcasename());
Harald Welte08332302019-08-01 09:54:40 +0200205 }
206}
207
Pau Espin Pedrol7e451282022-08-01 19:32:23 +0200208function f_start(float t_guard := 60.0) runs on test_CT {
209 /* Start guard timer and activate it as default */
210 g_Tguard.start(t_guard);
211 activate(as_Tguard());
212
Pau Espin Pedrol3dfa8072022-07-29 16:29:43 +0200213 for (var integer i := 0; i < g_num_bsc; i := i + 1) {
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200214 f_start_bsc(i, testcasename(), g_pars_BSC[i]);
215 }
216 for (var integer i := 0; i < g_num_mme; i := i + 1) {
217 f_start_mme(i, testcasename(), g_pars_MME[i]);
218 }
Pau Espin Pedroldb247f82022-08-01 17:55:22 +0200219
220 /* Now wait for conns to be ready: */
221 for (var integer i := 0; i < g_num_bsc; i := i + 1) {
222 COORD_BSC[i].receive(COORD_MSG_CONNECTED);
223 }
224 for (var integer i := 0; i < g_num_mme; i := i + 1) {
225 COORD_MME[i].receive(COORD_MSG_CONNECTED);
226 }
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200227}
228
Harald Welte08332302019-08-01 09:54:40 +0200229/* test whether or not we receive a valid KEEP-ALIVE from the CBC */
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200230private function f_bsc_TC_rx_keepalive() runs on BSC_ConnHdlr {
Harald Welte08332302019-08-01 09:54:40 +0200231 var CBSP_PDU rx;
232 var CBSP_IE ie;
Harald Welte08332302019-08-01 09:54:40 +0200233 rx := f_cbsp_exp(tr_CBSP_KEEP_ALIVE(?));
234 f_cbsp_find_ie(rx, CBSP_IEI_KEEP_ALIVE_REP_PERIOD, ie);
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200235}
236testcase TC_rx_keepalive() runs on test_CT {
Harald Welte08332302019-08-01 09:54:40 +0200237
Pau Espin Pedrol19763462022-07-29 10:47:33 +0200238 f_init(num_bsc := 1);
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200239 g_pars_BSC[0].start_fn := refers(f_bsc_TC_rx_keepalive);
240 f_start();
Pau Espin Pedrol9d8b6bf2022-06-23 12:19:47 +0200241 f_shutdown_helper();
Harald Welte08332302019-08-01 09:54:40 +0200242}
243
244/* test whether CBC terminates connection if KEEP-ALIVE is not answered by BSC */
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200245private function f_bsc_TC_rx_keepalive_timeout() runs on BSC_ConnHdlr {
Harald Welte08332302019-08-01 09:54:40 +0200246 var CBSP_PDU rx;
247 var CBSP_IE ie;
248 var integer ka_rep_per_s;
249
Harald Welte08332302019-08-01 09:54:40 +0200250 rx := f_cbsp_exp(tr_CBSP_KEEP_ALIVE(?));
251 f_cbsp_find_ie(rx, CBSP_IEI_KEEP_ALIVE_REP_PERIOD, ie);
252
253 /* sleep for longer than the keep-alive period */
254 ka_rep_per_s := f_cbsp_period2s(ie.body.keep_alive_rep_period);
255 f_sleep(int2float(ka_rep_per_s + 5));
256
257 /* expect the CBSP connection to be closed */
258 CBSP[0].receive(PortEvent:{connClosed:=?})
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200259}
260testcase TC_rx_keepalive_timeout() runs on test_CT {
Pau Espin Pedrol19763462022-07-29 10:47:33 +0200261 f_init(num_bsc := 1);
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200262 g_pars_BSC[0].start_fn := refers(f_bsc_TC_rx_keepalive_timeout);
Pau Espin Pedrol7e451282022-08-01 19:32:23 +0200263 f_start(t_guard := 100.0);
Pau Espin Pedrol9d8b6bf2022-06-23 12:19:47 +0200264 f_shutdown_helper();
Harald Welte08332302019-08-01 09:54:40 +0200265}
266
Harald Welte08332302019-08-01 09:54:40 +0200267private const BSSMAP_FIELD_CellIdentificationList cil_BSS := {
268 cIl_allInBSS := ''O
269};
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200270private function f_bsc_TC_write_replace() runs on BSC_ConnHdlr {
271 f_cbsp_handle_write(g_pars.exp_cbs_msg);
272 f_sleep(100.0);
273}
Harald Welte08332302019-08-01 09:54:40 +0200274testcase TC_write_replace() runs on test_CT {
Harald Welte08332302019-08-01 09:54:40 +0200275 var CBS_Message msg := {
276 msg_id := 42,
277 ser_nr := 16752,
278 old_ser_nr := omit,
279 cell_list := cil_BSS,
280 channel_ind := 0,
281 category := CBSP_CATEG_NORMAL,
282 rep_period := 5,
283 num_bcast_req := 3,
284 dcs := 1,
285 content := {
286 { '00'O, 1 }
287 }
288 };
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200289
Pau Espin Pedrol19763462022-07-29 10:47:33 +0200290 f_init(num_bsc := 1);
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200291 g_pars_BSC[0].exp_cbs_msg := msg;
292 g_pars_BSC[0].start_fn := refers(f_bsc_TC_write_replace);
293 f_start();
Pau Espin Pedrol9d8b6bf2022-06-23 12:19:47 +0200294 f_shutdown_helper();
Harald Welte08332302019-08-01 09:54:40 +0200295}
296
297testcase TC_selftest() runs on test_CT {
298 const octetstring c_load_q := '0700000d0400080000f110012345671200'O;
299 const octetstring c_load_q_compl := '0800000f0a000a0000f1100123456700001200'O;
300 const octetstring c_reset := '1000000b0400080000f11001234567'O;
301 const octetstring c_reset_compl := '1100000b0400080000f11001234567'O;
302 const octetstring c_msg_sts_q := '0a0000130e022b0200000400080000f110012345671200'O;
303 const octetstring c_msg_sts_q_fail := '0c0000140e022b0200000900090000f11001234567021200'O;
304 const octetstring c_kill := '040000110e00000200000400080000f11001234567'O;
305 const octetstring c_kill_fail := '060000120e00000200000900090000f1100123456702'O;
306 const octetstring c_write_repl := '010000c70e022b0300300400080000f110012345671200050006000407000613020c400107f4f29c9e769f5de337b90c921d1b8d46a3d168341a8d46a3d168341a8d46a3d168341a8d46a3d168341a8d46a3d168341a8d46a3d168341a8d46a3d168341a8d46a3d168341a8d46a3d168341a8d46a3d100'O;
307 const octetstring c_write_repl_compl := '020000130e022b0300300400080000f110012345671200'O;
308 const octetstring c_write_repl_fail := '030000140e022b0300300900090000f110012345670d1200'O;
309 const octetstring c_msg_s_q := '0a0000130e022b0200900400080000f110012345671200'O;
310 const octetstring c_msg_s_q_compl := '0b0000160e022b02009008000b0000f110012345670008001200'O;
311 const octetstring c_kill_compl := '050000160e022b02008008000b0000f110012345670006001200'O;
312
313 log(dec_CBSP_PDU(c_load_q));
314 log(dec_CBSP_PDU(c_load_q_compl));
315 log(dec_CBSP_PDU(c_reset));
316 log(dec_CBSP_PDU(c_reset_compl));
317 log(dec_CBSP_PDU(c_msg_sts_q));
318 log(dec_CBSP_PDU(c_msg_sts_q_fail));
319 log(dec_CBSP_PDU(c_kill));
320 log(dec_CBSP_PDU(c_kill_fail));
321 log(dec_CBSP_PDU(c_write_repl));
322 log(dec_CBSP_PDU(c_write_repl_compl));
323 log(dec_CBSP_PDU(c_write_repl_fail));
324 log(dec_CBSP_PDU(c_msg_s_q));
325 log(dec_CBSP_PDU(c_msg_s_q_compl));
326 log(dec_CBSP_PDU(c_kill_compl));
327}
328
Harald Welte08332302019-08-01 09:54:40 +0200329testcase TC_selftest_sabp() runs on test_CT {
330 const octetstring c_write := '00000080930000080006000211120007000240c0000f0010000113f0030282ec0613f0030282ec070001400100000d0002012a000900020000000400010100000056029f01b4d90d064297d9ec37e8fe96b3c9a0303bdd68341a8d46a3d168341a8d46a3d168341a8d46a3d168341a8d46a3d168341a8d46a3d168341a8d46a3d168341a8d46a3d168341a8d46a3d168341a8d46a3d10012'O;
331
332 log(dec_SABP_PDU(c_write));
333 log(enc_SABP_PDU(dec_SABP_PDU(c_write)));
334
335 var template (value) Service_Areas_List sa_list := {
336 ts_SabpSai('62F224'O, '0023'O, '0042'O)
337 };
338 var template (value) SABP_PDU tx;
339
340 tx := ts_SABP_Write(int2bit(1, 16), int2bit(1, 16), sa_list, 23, 42, '00000000'B, '01011010'B);
341 log("Write: ", enc_SABP_PDU(valueof(tx)))
342
343 var Service_Areas_List sa_list2 := { valueof(ts_SabpSai('62F224'O, '1000'O, '0042'O)) };
344 for (var integer i := 0; i < 2500; i := i+1) {
345 sa_list2 := sa_list2 & {valueof(ts_SabpSai('62F224'O, '2000'O, int2oct(i,2))) };
346 }
347 tx := ts_SABP_Write(int2bit(2, 16), int2bit(2, 16), sa_list2, 23, 42, '00000000'B, '01011010'B);
348 log("Write: ", enc_SABP_PDU(valueof(tx)))
349
350 tx := ts_SABP_Restart(sa_list);
351 log("Restart: ", enc_SABP_PDU(valueof(tx)));
352}
353
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200354private function f_bsc_create_and_delete() runs on BSC_ConnHdlr {
Pau Espin Pedrol855c56c2022-08-05 15:52:00 +0200355 f_cbsp_handle_write(g_pars.exp_cbs_msg, 0, g_pars.cell_list_success);
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200356 f_cbsp_handle_kill(0, g_pars.exp_cbs_msg.msg_id, g_pars.exp_cbs_msg.ser_nr,
Pau Espin Pedrol855c56c2022-08-05 15:52:00 +0200357 exp_list:=g_pars.cell_list_success, tx_list:=g_pars.cell_list_success,
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200358 tx_fail_list:=omit, tx_compl_list:=omit,
359 channel_ind:=g_pars.exp_cbs_msg.channel_ind);
360}
Harald Welte08332302019-08-01 09:54:40 +0200361
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200362private function f_mme_create_and_delete() runs on MME_ConnHdlr {
363 f_sbcap_handle_write_replace_warn_req(g_pars.exp_cbs_msg, 0);
Pau Espin Pedrolae2e5152022-07-29 19:16:23 +0200364 if (ispresent(g_pars.write_replace_warning_ind_cause) and
365 ispresent(g_pars.bcast_cell_id_list)) {
366 f_sbcap_tx_write_replace_warn_ind(0, g_pars.exp_cbs_msg,
367 g_pars.write_replace_warning_ind_cause,
368 g_pars.bcast_cell_id_list)
369 }
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200370 f_sbcap_handle_stop_warn_req(0, g_pars.exp_cbs_msg);
371}
372
373function f_create_and_delete(CBS_Message msg)
Harald Welte08332302019-08-01 09:54:40 +0200374runs on test_CT {
375 var EcbeCbcMessage ecbe := f_cbs2ecbe(msg, "TTCN-3");
376 f_ecbe_tx_post_cbs(ecbe);
Harald Welte08332302019-08-01 09:54:40 +0200377 f_ecbe_rx_resp(201);
378
379 f_sleep(2.0);
380
381 f_ecbe_tx_delete_cbs(msg.msg_id);
Harald Welte08332302019-08-01 09:54:40 +0200382 f_ecbe_rx_resp(200);
383}
384
385private template (value) CBS_Message t_CBSmsg(uint16_t msg_id, uint16_t ser_nr) := {
386 msg_id := msg_id,
387 ser_nr := ser_nr,
388 old_ser_nr := omit,
389 cell_list := cil_BSS,
390 channel_ind := 0,
391 category := CBSP_CATEG_NORMAL,
392 rep_period := 5,
393 num_bcast_req := 3,
394 dcs := 1,
395 content := {
396 { '00'O, 1 }
397 }
398};
399
400/* specify a variety of different Cell Identifier formats to extend test coverage */
401testcase TC_ecbe_create_delete_cgi() runs on test_CT {
Pau Espin Pedrol19763462022-07-29 10:47:33 +0200402 f_init(num_bsc := 1);
Harald Welte08332302019-08-01 09:54:40 +0200403 var template (value) BSSMAP_FIELD_CellIdentificationList cell_list_success;
404 var template (value) CBS_Message msg := t_CBSmsg(43, 16752);
405
406 cell_list_success := ts_BSSMAP_CIL_CGI({
407 ts_BSSMAP_CI_CGI('901'H, '70'H, 23, 42),
408 ts_BSSMAP_CI_CGI('901'H, '70'H, 24, 42),
409 ts_BSSMAP_CI_CGI('901'H, '70'H, 24, 43)
410 });
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200411 g_pars_BSC[0].start_fn := refers(f_bsc_create_and_delete);
412 g_pars_BSC[0].exp_cbs_msg := valueof(msg);
413 g_pars_BSC[0].cell_list_success := valueof(cell_list_success);
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200414 f_start();
415 f_create_and_delete(valueof(msg));
Pau Espin Pedrol9d8b6bf2022-06-23 12:19:47 +0200416 f_shutdown_helper();
Harald Welte08332302019-08-01 09:54:40 +0200417}
418testcase TC_ecbe_create_delete_lac_ci() runs on test_CT {
Pau Espin Pedrol19763462022-07-29 10:47:33 +0200419 f_init(num_bsc := 1);
Harald Welte08332302019-08-01 09:54:40 +0200420 var template (value) BSSMAP_FIELD_CellIdentificationList cell_list_success;
421 var template (value) CBS_Message msg := t_CBSmsg(44, 16752);
422 cell_list_success := ts_BSSMAP_CIL_LAC_CI({
423 ts_BSSMAP_CI_LAC_CI(10001, 50001),
424 ts_BSSMAP_CI_LAC_CI(10002, 50002),
425 ts_BSSMAP_CI_LAC_CI(10003, 50003)
426 });
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200427 g_pars_BSC[0].start_fn := refers(f_bsc_create_and_delete);
428 g_pars_BSC[0].exp_cbs_msg := valueof(msg);
429 g_pars_BSC[0].cell_list_success := valueof(cell_list_success);
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200430 f_start();
431 f_create_and_delete(valueof(msg));
Pau Espin Pedrol9d8b6bf2022-06-23 12:19:47 +0200432 f_shutdown_helper();
Harald Welte08332302019-08-01 09:54:40 +0200433}
434testcase TC_ecbe_create_delete_lac() runs on test_CT {
Pau Espin Pedrol19763462022-07-29 10:47:33 +0200435 f_init(num_bsc := 1);
Harald Welte08332302019-08-01 09:54:40 +0200436 var template (value) BSSMAP_FIELD_CellIdentificationList cell_list_success;
437 var template (value) CBS_Message msg := t_CBSmsg(45, 16752);
438 cell_list_success := ts_BSSMAP_CIL_LAC({
439 ts_BSSMAP_CI_LAC(10001),
440 ts_BSSMAP_CI_LAC(10002),
441 ts_BSSMAP_CI_LAC(10003)
442 });
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200443 g_pars_BSC[0].start_fn := refers(f_bsc_create_and_delete);
444 g_pars_BSC[0].exp_cbs_msg := valueof(msg);
445 g_pars_BSC[0].cell_list_success := valueof(cell_list_success);
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200446 f_start();
447 f_create_and_delete(valueof(msg));
Pau Espin Pedrol9d8b6bf2022-06-23 12:19:47 +0200448 f_shutdown_helper();
Harald Welte08332302019-08-01 09:54:40 +0200449}
450testcase TC_ecbe_create_delete_ci() runs on test_CT {
Pau Espin Pedrol19763462022-07-29 10:47:33 +0200451 f_init(num_bsc := 1);
Harald Welte08332302019-08-01 09:54:40 +0200452 var template (value) BSSMAP_FIELD_CellIdentificationList cell_list_success;
453 var template (value) CBS_Message msg := t_CBSmsg(46, 16752);
454 cell_list_success := ts_BSSMAP_CIL_CI({
455 ts_BSSMAP_CI_CI(50001),
456 ts_BSSMAP_CI_CI(50002),
457 ts_BSSMAP_CI_CI(50003)
458 });
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200459 g_pars_BSC[0].start_fn := refers(f_bsc_create_and_delete);
460 g_pars_BSC[0].exp_cbs_msg := valueof(msg);
461 g_pars_BSC[0].cell_list_success := valueof(cell_list_success);
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200462 f_start();
463 f_create_and_delete(valueof(msg));
Pau Espin Pedrol9d8b6bf2022-06-23 12:19:47 +0200464 f_shutdown_helper();
Harald Welte08332302019-08-01 09:54:40 +0200465}
466testcase TC_ecbe_create_delete_lai() runs on test_CT {
Pau Espin Pedrol19763462022-07-29 10:47:33 +0200467 f_init(num_bsc := 1);
Harald Welte08332302019-08-01 09:54:40 +0200468 var template (value) BSSMAP_FIELD_CellIdentificationList cell_list_success;
469 var template (value) CBS_Message msg := t_CBSmsg(47, 16752);
470 cell_list_success := ts_BSSMAP_CIL_LAI({
471 ts_BSSMAP_CI_LAI('901'H, '70'H, 25),
472 ts_BSSMAP_CI_LAI('901'H, '70'H, 26),
473 ts_BSSMAP_CI_LAI('901'H, '70'H, 27)
474 });
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200475 g_pars_BSC[0].start_fn := refers(f_bsc_create_and_delete);
476 g_pars_BSC[0].exp_cbs_msg := valueof(msg);
477 g_pars_BSC[0].cell_list_success := valueof(cell_list_success);
Pau Espin Pedrol19763462022-07-29 10:47:33 +0200478 f_start();
479 f_create_and_delete(valueof(msg));
480 f_shutdown_helper();
481}
482
Pau Espin Pedrolae2e5152022-07-29 19:16:23 +0200483/* Create and delete message with MME available. MME reports
484 * Write-Replace-Warning-Indication and Stop-Warning-Indication to CBC
485 */
486testcase TC_ecbe_create_delete_mme_indication() runs on test_CT {
487 var template (value) CellId_Broadcast_List bcast_cell_id_li;
488 var template (value) CBS_Message msg := t_CBSmsg(48, 16752);
489
490 f_init(num_bsc := 0, num_mme := 1);
491
492 bcast_cell_id_li := {
493 ts_SBCAP_CellId_Broadcast_List_Item(ts_SBCAP_ECGI(f_enc_mcc_mnc('901'H, '70'H), 1234)),
494 ts_SBCAP_CellId_Broadcast_List_Item(ts_SBCAP_ECGI(f_enc_mcc_mnc('901'H, '70'H), 5678))
495 };
496 g_pars_MME[0].start_fn := refers(f_mme_create_and_delete);
497 g_pars_MME[0].exp_cbs_msg := valueof(msg);
498 g_pars_MME[0].write_replace_warning_ind_cause := SBC_AP_Cause_message_accepted;
499 g_pars_MME[0].bcast_cell_id_list := valueof(bcast_cell_id_li);
500 f_start();
501 f_create_and_delete(valueof(msg));
502 f_shutdown_helper();
503}
504
Pau Espin Pedrolb1a83fb2022-08-02 13:17:47 +0200505/* Create and delete message with MME available. MME reports
506 * Write-Replace-Response with Unknown TAI IE.
507 */
508testcase TC_ecbe_create_delete_mme_unknown_tai() runs on test_CT {
509 var template (value) List_of_TAIs write_repl_unknown_TAIs;
510 var template (value) CBS_Message msg := t_CBSmsg(48, 16752);
511
512 f_init(num_bsc := 0, num_mme := 1);
513
514 write_repl_unknown_TAIs := {{ts_SBCAP_TAI(f_enc_mcc_mnc('901'H, '70'H), 1234)}};
515 g_pars_MME[0].start_fn := refers(f_mme_create_and_delete);
516 g_pars_MME[0].exp_cbs_msg := valueof(msg);
517 g_pars_MME[0].write_replace_warning_ind_cause := SBC_AP_Cause_message_accepted;
518 g_pars_MME[0].write_repl_unknown_TAIs := valueof(write_repl_unknown_TAIs);
519 f_start();
520 f_create_and_delete(valueof(msg));
521 f_shutdown_helper();
522}
523
Pau Espin Pedrol19763462022-07-29 10:47:33 +0200524/* Create and delete message with both BSC and MME available */
525testcase TC_ecbe_create_delete_bsc_and_mme() runs on test_CT {
526 f_init(num_bsc := 1, num_mme := 1);
527 var template (value) BSSMAP_FIELD_CellIdentificationList cell_list_success;
Pau Espin Pedrolae2e5152022-07-29 19:16:23 +0200528 var template (value) CellId_Broadcast_List bcast_cell_id_li;
Pau Espin Pedrol19763462022-07-29 10:47:33 +0200529 var template (value) CBS_Message msg := t_CBSmsg(43, 16752);
530
531 cell_list_success := ts_BSSMAP_CIL_CGI({
532 ts_BSSMAP_CI_CGI('901'H, '70'H, 23, 42),
533 ts_BSSMAP_CI_CGI('901'H, '70'H, 24, 42),
534 ts_BSSMAP_CI_CGI('901'H, '70'H, 24, 43)
535 });
536 g_pars_BSC[0].start_fn := refers(f_bsc_create_and_delete);
537 g_pars_BSC[0].exp_cbs_msg := valueof(msg);
538 g_pars_BSC[0].cell_list_success := valueof(cell_list_success);
Pau Espin Pedrolae2e5152022-07-29 19:16:23 +0200539
540 bcast_cell_id_li := {
541 ts_SBCAP_CellId_Broadcast_List_Item(ts_SBCAP_ECGI(f_enc_mcc_mnc('901'H, '70'H), 1234))
542 };
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200543 g_pars_MME[0].start_fn := refers(f_mme_create_and_delete);
544 g_pars_MME[0].exp_cbs_msg := valueof(msg);
Pau Espin Pedrolae2e5152022-07-29 19:16:23 +0200545 g_pars_MME[0].write_replace_warning_ind_cause := SBC_AP_Cause_message_accepted;
546 g_pars_MME[0].bcast_cell_id_list := valueof(bcast_cell_id_li);
Pau Espin Pedrol4ff118a2022-07-28 17:37:47 +0200547 f_start();
548 f_create_and_delete(valueof(msg));
Pau Espin Pedrol9d8b6bf2022-06-23 12:19:47 +0200549 f_shutdown_helper();
Harald Welte08332302019-08-01 09:54:40 +0200550}
551
Pau Espin Pedroldb247f82022-08-01 17:55:22 +0200552/* Create and delete message with BSC acting as TCP server */
553testcase TC_ecbe_create_delete_bsc_server() runs on test_CT {
554 var template (value) BSSMAP_FIELD_CellIdentificationList cell_list_success;
555 var template (value) CBS_Message msg := t_CBSmsg(46, 16752);
556
557 /* The 2nd BSC is the one configured as server, but we only want to test
558 * that one, so initialize both but copy over config of the 2nd one to
559 * the first one, to start only one BSC: */
560 f_init(num_bsc := 2);
561 g_num_bsc := 1;
562 g_pars_BSC[0] := g_pars_BSC[1];
563
564 cell_list_success := ts_BSSMAP_CIL_CI({
565 ts_BSSMAP_CI_CI(50001),
566 ts_BSSMAP_CI_CI(50002),
567 ts_BSSMAP_CI_CI(50003)
568 });
569 g_pars_BSC[0].start_fn := refers(f_bsc_create_and_delete);
570 g_pars_BSC[0].exp_cbs_msg := valueof(msg);
571 g_pars_BSC[0].cell_list_success := valueof(cell_list_success);
572 f_start();
573 f_create_and_delete(valueof(msg));
574 f_shutdown_helper();
575}
576
577/* Create and delete message with MME acting as SCTP server */
578testcase TC_ecbe_create_delete_mme_server() runs on test_CT {
579 var template (value) CellId_Broadcast_List bcast_cell_id_li;
580 var template (value) CBS_Message msg := t_CBSmsg(48, 16752);
581
582 /* The 2nd MME is the one configured as server, but we only want to test
583 * that one, so initialize both but copy over config of the 2nd one to
584 * the first one, to start only one MME: */
585 f_init(num_bsc := 0, num_mme := 2);
586 g_num_mme := 1;
587 g_pars_MME[0] := g_pars_MME[1];
588
589 bcast_cell_id_li := {
590 ts_SBCAP_CellId_Broadcast_List_Item(ts_SBCAP_ECGI(f_enc_mcc_mnc('901'H, '70'H), 1234)),
591 ts_SBCAP_CellId_Broadcast_List_Item(ts_SBCAP_ECGI(f_enc_mcc_mnc('901'H, '70'H), 5678))
592 };
593 g_pars_MME[0].start_fn := refers(f_mme_create_and_delete);
594 g_pars_MME[0].exp_cbs_msg := valueof(msg);
595 g_pars_MME[0].write_replace_warning_ind_cause := SBC_AP_Cause_message_accepted;
596 g_pars_MME[0].bcast_cell_id_list := valueof(bcast_cell_id_li);
597 f_start();
598 f_create_and_delete(valueof(msg));
599 f_shutdown_helper();
600}
601
Pau Espin Pedrola5536b62022-08-02 18:53:08 +0200602/* Create 2 concurrent messages against an MME, then delete them */
603private function f_mme_TC_concurrent_cbs_msg_mme() runs on MME_ConnHdlr {
604 var CBS_Message msg[2];
605 msg[0] := g_pars.exp_cbs_msg;
606 msg[1] := msg[0];
607 msg[1].msg_id := msg[0].msg_id + 1;
608
609 for (var integer i := 0; i < lengthof(msg); i := i + 1) {
610 f_sbcap_handle_write_replace_warn_req(msg[i], 0);
611 if (ispresent(g_pars.write_replace_warning_ind_cause) and
612 ispresent(g_pars.bcast_cell_id_list)) {
613 f_sbcap_tx_write_replace_warn_ind(0, msg[i],
614 g_pars.write_replace_warning_ind_cause,
615 g_pars.bcast_cell_id_list)
616 }
617 }
618 /* Now handle Stop: */
619 for (var integer i := 0; i < lengthof(msg); i := i + 1) {
620 f_sbcap_handle_stop_warn_req(0, msg[i]);
621 }
622}
623testcase TC_concurrent_cbs_msg_mme() runs on test_CT {
624 var template (value) CellId_Broadcast_List bcast_cell_id_li;
625 var CBS_Message msg[2];
626 var EcbeCbcMessage ecbe;
627
628 msg[0] := valueof(t_CBSmsg(49, 16752));
629 msg[1] := msg[0];
630 msg[1].msg_id := msg[0].msg_id + 1;
631
632 f_init(num_bsc := 0, num_mme := 1);
633
634 bcast_cell_id_li := {
635 ts_SBCAP_CellId_Broadcast_List_Item(ts_SBCAP_ECGI(f_enc_mcc_mnc('901'H, '70'H), 1234))
636 };
637 g_pars_MME[0].start_fn := refers(f_mme_TC_concurrent_cbs_msg_mme);
638 g_pars_MME[0].exp_cbs_msg := msg[0];
639 g_pars_MME[0].write_replace_warning_ind_cause := SBC_AP_Cause_message_accepted;
640 g_pars_MME[0].bcast_cell_id_list := valueof(bcast_cell_id_li);
641 f_start();
642
643 for (var integer i := 0; i < lengthof(msg); i := i + 1) {
644 ecbe := f_cbs2ecbe(msg[i], "TTCN-3");
645 f_ecbe_tx_post_cbs(ecbe);
646 f_ecbe_rx_resp(201);
647 }
648
649 f_sleep(2.0);
650
651 for (var integer i := 0; i < lengthof(msg); i := i + 1) {
652 f_ecbe_tx_delete_cbs(msg[i].msg_id);
653 f_ecbe_rx_resp(200);
654 }
655
656 f_shutdown_helper();
657}
658
Pau Espin Pedrole7d3d992022-08-04 12:21:10 +0200659/* Test ETWS message over CBSP. TS 23.041 9.4.1.2.2 */
Pau Espin Pedrolad5d2db2022-08-03 14:02:02 +0200660testcase TC_ecbe_create_delete_etws_bsc() runs on test_CT {
661 f_init(num_bsc := 1);
662 var template (value) BSSMAP_FIELD_CellIdentificationList cell_list_success;
663 var template (value) CBS_Message msg := t_CBSmsg(4352 /* Earthquake */, 16752);
664 msg.channel_ind := omit;
665
666 cell_list_success := ts_BSSMAP_CIL_CGI({
667 ts_BSSMAP_CI_CGI('901'H, '70'H, 23, 42),
668 ts_BSSMAP_CI_CGI('901'H, '70'H, 24, 42)
669 });
670 g_pars_BSC[0].start_fn := refers(f_bsc_create_and_delete);
671 g_pars_BSC[0].exp_cbs_msg := valueof(msg);
672 g_pars_BSC[0].cell_list_success := valueof(cell_list_success);
673 f_start();
674 f_create_and_delete(valueof(msg));
675 f_shutdown_helper();
676}
677
Pau Espin Pedrole7d3d992022-08-04 12:21:10 +0200678/* Test ETWS message over SBc-AP. TS 23.041 9.4.1.2.2 */
679testcase TC_ecbe_create_delete_etws_mme() runs on test_CT {
680 f_init(num_mme := 1);
681 var template (value) CBS_Message msg := t_CBSmsg(4352 /* Earthquake */, 16753);
682 msg.channel_ind := omit;
683
684 g_pars_MME[0].start_fn := refers(f_mme_create_and_delete);
685 g_pars_MME[0].exp_cbs_msg := valueof(msg);
686 f_start();
687 f_create_and_delete(valueof(msg));
688 f_shutdown_helper();
689}
690
Pau Espin Pedrol6dd5a0f2022-08-05 15:16:48 +0200691/* Test BSC answering WRITE-REPLACE REQUEST with WRITE-REPLACE FAILURE */
692private function f_bsc_TC_create_nack_bsc() runs on BSC_ConnHdlr {
693 f_cbsp_handle_write(g_pars.exp_cbs_msg, 0, g_pars.cell_list_success, g_pars.tx_fail_list);
694}
695testcase TC_create_nack_bsc() runs on test_CT {
696 var template (value) BSSMAP_FIELD_CellIdentificationList cell_list_success;
697 var template (value) CBSP_FailureListItems tx_fail_list;
698 var CBS_Message msg;
699 var EcbeCbcMessage ecbe;
700
701 msg := valueof(t_CBSmsg(49, 16752));
702
703 f_init(num_bsc := 1, num_mme := 0);
704
705 cell_list_success := ts_BSSMAP_CIL_CGI({
706 ts_BSSMAP_CI_CGI('901'H, '70'H, 23, 42),
707 ts_BSSMAP_CI_CGI('901'H, '70'H, 24, 42)
708 });
709 tx_fail_list := {
710 CBSP_FailureListItem_CGI(ts_BSSMAP_CI_CGI('901'H, '70'H, 24, 48), CBSP_CAUSE_CELL_ID_NOT_VALID),
711 CBSP_FailureListItem_LAC_CI(ts_BSSMAP_CI_LAC_CI(10001, 50001), CBSP_CAUSE_LAI_OR_LAC_NPT_VALID)
712 };
713 g_pars_BSC[0].start_fn := refers(f_bsc_TC_create_nack_bsc);
714 g_pars_BSC[0].exp_cbs_msg := msg;
715 g_pars_BSC[0].cell_list_success := valueof(cell_list_success);
716 g_pars_BSC[0].tx_fail_list := valueof(tx_fail_list);
717 f_start();
718
719 ecbe := f_cbs2ecbe(msg, "TTCN-3");
720 f_ecbe_tx_post_cbs(ecbe);
721 f_ecbe_rx_resp(201);
722
723 f_shutdown_helper();
724}
725
Pau Espin Pedrol6b3e8e32022-08-05 16:21:32 +0200726/* Test MME answering Write-Replace Warning Request with Write-Replace Warning Response cause != accepted */
727private function f_mme_TC_create_nack_mme() runs on MME_ConnHdlr {
728 f_sbcap_handle_write_replace_warn_req(g_pars.exp_cbs_msg, 0);
729}
730testcase TC_create_nack_mme() runs on test_CT {
731 var template (value) CBS_Message msg := t_CBSmsg(48, 16752);
732
733 f_init(num_bsc := 0, num_mme := 1);
734
735 g_pars_MME[0].start_fn := refers(f_mme_TC_create_nack_mme);
736 g_pars_MME[0].exp_cbs_msg := valueof(msg);
737 g_pars_MME[0].write_replace_warning_req_cause := SBcAP_Cause_unspecifed_error;
738 f_start();
739 f_create_and_delete(valueof(msg));
740 f_shutdown_helper();
741}
742
Pau Espin Pedrol715d6782022-08-05 17:36:11 +0200743
744/* Test cell in BSC going unavailable for broadcasting and going available again */
745private function f_bsc_TC_cell_failure_restart_idle_bsc() runs on BSC_ConnHdlr {
746 var template (value) CBSP_FailureListItems fail_list := {
747 CBSP_FailureListItem_CGI(ts_BSSMAP_CI_CGI('901'H, '70'H, 23, 42), CBSP_CAUSE_CB_NOT_OPERATIONAL),
748 CBSP_FailureListItem_CGI(ts_BSSMAP_CI_CGI('901'H, '70'H, 24, 42), CBSP_CAUSE_CB_NOT_OPERATIONAL)
749 };
750 f_cbsp_send(ts_CBSP_FAILURE(fail_list, CBSP_BC_MSGT_CBS));
751 f_cbsp_send(ts_CBSP_FAILURE(fail_list, CBSP_BC_MSGT_EMERG));
752
753 f_sleep(1.0);
754
755 var template (value) BSSMAP_FIELD_CellIdentificationList cell_list;
756 cell_list := ts_BSSMAP_CIL_CGI({
757 ts_BSSMAP_CI_CGI('901'H, '70'H, 23, 42),
758 ts_BSSMAP_CI_CGI('901'H, '70'H, 24, 42)
759 });
760 f_cbsp_send(ts_CBSP_RESTART(cell_list, CBSP_BC_MSGT_CBS, CBSP_RI_DATA_LOST));
761 f_cbsp_send(ts_CBSP_RESTART(cell_list, CBSP_BC_MSGT_EMERG, CBSP_RI_DATA_LOST));
762}
763testcase TC_cell_failure_restart_idle_bsc() runs on test_CT {
764 f_init(num_bsc := 1, num_mme := 0);
765 g_pars_BSC[0].start_fn := refers(f_bsc_TC_cell_failure_restart_idle_bsc);
766 f_start();
767 f_shutdown_helper();
768}
769
Pau Espin Pedrol45ef7752022-08-05 18:08:48 +0200770/* Test cell in MME going unavailable for broadcasting and going available again */
771private function f_mme_TC_cell_failure_restart_idle_mme() runs on MME_ConnHdlr {
772 var template (value) Global_ENB_ID enb_id := ts_Global_ENB_ID_MACRO(f_enc_mcc_mnc('901'H, '70'H), 90);
773 var template (value) Failed_Cell_List fail_list := {
774 ts_SBCAP_ECGI(f_enc_mcc_mnc('901'H, '70'H), 1234),
775 ts_SBCAP_ECGI(f_enc_mcc_mnc('901'H, '70'H), 5678)
776 };
777 f_SBC_AP_send(ts_SBCAP_PWS_FAILURE(fail_list, enb_id));
778
779 f_sleep(1.0);
780
781 var template (value) Restarted_Cell_List cell_list;
782 cell_list := {
783 ts_SBCAP_ECGI(f_enc_mcc_mnc('901'H, '70'H), 1234),
784 ts_SBCAP_ECGI(f_enc_mcc_mnc('901'H, '70'H), 5678)
785 };
786 f_SBC_AP_send(ts_SBCAP_PWS_RESTART(cell_list, enb_id));
787}
788testcase TC_cell_failure_restart_idle_mme() runs on test_CT {
789 f_init(num_bsc := 0, num_mme := 1);
790 g_pars_MME[0].start_fn := refers(f_mme_TC_cell_failure_restart_idle_mme);
791 f_start();
792 f_shutdown_helper();
793}
794
Pau Espin Pedrole7195132022-08-05 15:16:27 +0200795/* Test cell actively broadcasting a message in BSC going unavailable for
796 broadcasting and going available again. The CBC should reload the announced
797 cell with the active messages. See 3GPP TS 48.049 7.8 */
798private function f_bsc_TC_cell_failure_restart_active_bsc() runs on BSC_ConnHdlr {
799 var template (value) CBSP_FailureListItems fail_list := {
800 CBSP_FailureListItem_CGI(g_pars.cell_list_success.cIl_CGI[0], CBSP_CAUSE_CB_NOT_OPERATIONAL)
801 };
802 var template (value) BSSMAP_FIELD_CellIdentificationList cell_list := ts_BSSMAP_CIL_CGI({
803 g_pars.cell_list_success.cIl_CGI[0]
804 });
805
806 /* Guide cell into active broadcast msg state: */
807 f_cbsp_handle_write(g_pars.exp_cbs_msg, 0, g_pars.cell_list_success);
808
809 /* BSC reports the cell is down */
810 f_cbsp_send(ts_CBSP_FAILURE(fail_list, CBSP_BC_MSGT_CBS));
811 f_cbsp_send(ts_CBSP_FAILURE(fail_list, CBSP_BC_MSGT_EMERG));
812 f_sleep(1.0);
813
814 /* BSC reports the cell is up again */
815 f_cbsp_send(ts_CBSP_RESTART(cell_list, CBSP_BC_MSGT_CBS, CBSP_RI_DATA_LOST));
816 f_cbsp_send(ts_CBSP_RESTART(cell_list, CBSP_BC_MSGT_EMERG, CBSP_RI_DATA_LOST));
817
818/* TODO: OS#5641
819 * The BSC informs the CBC by sending the RESTART message (see figure 7.8.2.1)
820 * containing the Cell List IE identifying the cell(s) being in CBS message
821 * operational state or in emergency message operational state and the Recovery
822 * Indication IE, indicating whether the broadcast information data is lost or
823 * not in the BSC.
824 * The RESTART message is sent once per broadcast message type
825 * as indicated by the Broadcast Message Type IE.
826 */
827 f_bsc_create_and_delete();
828}
829testcase TC_cell_failure_restart_active_bsc() runs on test_CT {
830 f_init(num_bsc := 1);
831 var template (value) BSSMAP_FIELD_CellIdentificationList cell_list_success;
832 var template (value) CBS_Message msg := t_CBSmsg(43, 16752);
833
834 cell_list_success := ts_BSSMAP_CIL_CGI({
835 ts_BSSMAP_CI_CGI('901'H, '70'H, 23, 42)
836 });
837 g_pars_BSC[0].start_fn := refers(f_bsc_TC_cell_failure_restart_active_bsc);
838 g_pars_BSC[0].exp_cbs_msg := valueof(msg);
839 g_pars_BSC[0].cell_list_success := valueof(cell_list_success);
840 f_start();
841
842 var EcbeCbcMessage ecbe := f_cbs2ecbe(valueof(msg), "TTCN-3");
843 f_ecbe_tx_post_cbs(ecbe);
844 f_ecbe_rx_resp(201);
845
846 f_shutdown_helper();
847}
848
849/* Test cell actively broadcasting a message in MME going unavailable for
850 broadcasting and going available again. The CBC should reload the announced
851 cell with the active messages. See 3GPP TS 29.168 4.3.3E.2 */
852private function f_mme_TC_cell_failure_restart_active_mme() runs on MME_ConnHdlr {
853 var template (value) Global_ENB_ID enb_id := ts_Global_ENB_ID_MACRO(f_enc_mcc_mnc('901'H, '70'H), 90);
854 var template (value) Failed_Cell_List fail_list := {
855 g_pars.bcast_cell_id_list[0].eCGI
856 }
857 var template (value) Restarted_Cell_List cell_list := {
858 g_pars.bcast_cell_id_list[0].eCGI
859 };
860 /* Guide cell into active broadcast msg state: */
861 f_sbcap_handle_write_replace_warn_req(g_pars.exp_cbs_msg, 0);
862 if (ispresent(g_pars.write_replace_warning_ind_cause) and
863 ispresent(g_pars.bcast_cell_id_list)) {
864 f_sbcap_tx_write_replace_warn_ind(0, g_pars.exp_cbs_msg,
865 g_pars.write_replace_warning_ind_cause,
866 g_pars.bcast_cell_id_list)
867 }
868
869 /* MME reports the cell is down */
870 f_SBC_AP_send(ts_SBCAP_PWS_FAILURE(fail_list, enb_id));
871
872 f_sleep(1.0);
873
874 /* MME reports the cell is up again */
875 f_SBC_AP_send(ts_SBCAP_PWS_RESTART(cell_list, enb_id));
876
877/* TODO: OS#5641
878 * The CBC shall reload the warning message data (with the same Message
879 * Identifier and Serial Number) to the (H)eNB by initiating Write Replace
880 * Warning procedure(s) as specified in clause 4.3.3.2 with the following
881 * additions:
882 * - the CBC should set the Warning Area List IE in the Write-Replace
883 * Warning Request message to the identities of the cell(s) received in the
884 * Restarted-Cell-List which are relevant to the warning message data being
885 * reloaded;
886 * - the CBC shall copy the Global eNB ID into the Write-Replace
887 * Warning Request message; and
888 * - the CBC may update the Number of Broadcast Requested, if necessary.
889 */
890 f_mme_create_and_delete();
891}
892testcase TC_cell_failure_restart_active_mme() runs on test_CT {
893 var template (value) CellId_Broadcast_List bcast_cell_id_li;
894 var template (value) CBS_Message msg := t_CBSmsg(48, 16752);
895
896 f_init(num_bsc := 0, num_mme := 1);
897
898 bcast_cell_id_li := {
899 ts_SBCAP_CellId_Broadcast_List_Item(ts_SBCAP_ECGI(f_enc_mcc_mnc('901'H, '70'H), 1234))
900 };
901 g_pars_MME[0].start_fn := refers(f_mme_TC_cell_failure_restart_active_mme);
902 g_pars_MME[0].exp_cbs_msg := valueof(msg);
903 g_pars_MME[0].write_replace_warning_ind_cause := SBC_AP_Cause_message_accepted;
904 g_pars_MME[0].bcast_cell_id_list := valueof(bcast_cell_id_li);
905 f_start();
906
907 var EcbeCbcMessage ecbe := f_cbs2ecbe(valueof(msg), "TTCN-3");
908 f_ecbe_tx_post_cbs(ecbe);
909 f_ecbe_rx_resp(201);
910
911 f_shutdown_helper();
912}
913
Harald Welte08332302019-08-01 09:54:40 +0200914control {
915 execute( TC_rx_keepalive() );
916 execute( TC_rx_keepalive_timeout() );
917 execute( TC_ecbe_create_delete_cgi() );
918 execute( TC_ecbe_create_delete_lac_ci() );
919 execute( TC_ecbe_create_delete_lac() );
920 execute( TC_ecbe_create_delete_ci() );
921 execute( TC_ecbe_create_delete_lai() );
Pau Espin Pedrolae2e5152022-07-29 19:16:23 +0200922 execute( TC_ecbe_create_delete_mme_indication() );
Pau Espin Pedrolb1a83fb2022-08-02 13:17:47 +0200923 execute( TC_ecbe_create_delete_mme_unknown_tai() );
Pau Espin Pedrol19763462022-07-29 10:47:33 +0200924 execute( TC_ecbe_create_delete_bsc_and_mme() );
Pau Espin Pedroldb247f82022-08-01 17:55:22 +0200925 execute( TC_ecbe_create_delete_bsc_server() );
926 execute( TC_ecbe_create_delete_mme_server() );
Pau Espin Pedrola5536b62022-08-02 18:53:08 +0200927 execute( TC_concurrent_cbs_msg_mme() );
Pau Espin Pedrolad5d2db2022-08-03 14:02:02 +0200928
929 execute( TC_ecbe_create_delete_etws_bsc() );
Pau Espin Pedrole7d3d992022-08-04 12:21:10 +0200930 execute( TC_ecbe_create_delete_etws_mme() );
Pau Espin Pedrol6dd5a0f2022-08-05 15:16:48 +0200931
932 execute( TC_create_nack_bsc() );
Pau Espin Pedrol6b3e8e32022-08-05 16:21:32 +0200933 execute( TC_create_nack_mme() );
Pau Espin Pedrol715d6782022-08-05 17:36:11 +0200934
935 execute( TC_cell_failure_restart_idle_bsc() );
Pau Espin Pedrol45ef7752022-08-05 18:08:48 +0200936 execute( TC_cell_failure_restart_idle_mme() );
Pau Espin Pedrole7195132022-08-05 15:16:27 +0200937
938 execute( TC_cell_failure_restart_active_bsc() );
939 execute( TC_cell_failure_restart_active_mme() );
Harald Welte08332302019-08-01 09:54:40 +0200940}
941
942}