diff options
Diffstat (limited to 'msc/MSC_Tests.ttcn')
-rw-r--r-- | msc/MSC_Tests.ttcn | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/msc/MSC_Tests.ttcn b/msc/MSC_Tests.ttcn index f7df81a..177c2f8 100644 --- a/msc/MSC_Tests.ttcn +++ b/msc/MSC_Tests.ttcn @@ -3695,6 +3695,44 @@ testcase TC_proc_ss_abort() runs on MTC_CT { } +/* Verify multiple concurrent MO SS/USSD transactions + * (one subscriber - one transaction) */ +testcase TC_multi_lu_and_mo_ussd() runs on MTC_CT { + var BSC_ConnHdlr vc_conn[16]; + var integer i; + + f_init(); + + for (i := 0; i < sizeof(vc_conn); i := i + 1) { + vc_conn[i] := f_start_handler(refers(f_tc_lu_and_mo_ussd_single_request), 210 + i); + } + + for (i := 0; i < sizeof(vc_conn); i := i + 1) { + vc_conn[i].done; + } +} + +/* Verify multiple concurrent MT SS/USSD transactions + * (one subscriber - one transaction) */ +testcase TC_multi_lu_and_mt_ussd() runs on MTC_CT { + var BSC_ConnHdlr vc_conn[16]; + var integer i; + var OCT4 sid; + + f_init(); + + for (i := 0; i < sizeof(vc_conn); i := i + 1) { + sid := '200001'O & int2oct(i, 1); /* All transactions must use different session ID */ + vc_conn[i] := f_start_handler_with_pars(refers(f_tc_lu_and_mt_ussd_notification), + f_init_pars(226 + i, gsup_sid := sid)); + } + + for (i := 0; i < sizeof(vc_conn); i := i + 1) { + vc_conn[i].done; + } +} + + /* A5/1 only permitted on network side; attempt an invalid CIPHER MODE COMPLETE with A5/3 which MSC should reject. */ private function f_tc_cipher_complete_with_invalid_cipher(charstring id, BSC_ConnHdlrPars pars) runs on BSC_ConnHdlr { pars.net.expect_auth := true; @@ -5845,6 +5883,9 @@ control { execute( TC_proc_ss_paging_fail() ); execute( TC_proc_ss_abort() ); + execute( TC_multi_lu_and_mo_ussd() ); + execute( TC_multi_lu_and_mt_ussd() ); + execute( TC_cipher_complete_with_invalid_cipher() ); execute( TC_cipher_complete_1_without_cipher() ); execute( TC_cipher_complete_3_without_cipher() ); |