<p>neels has uploaded this change for <strong>review</strong>.</p><p><a href="https://gerrit.osmocom.org/c/osmo-ttcn3-hacks/+/25169">View Change</a></p><pre style="font-family: monospace,monospace; white-space: pre-wrap;">bsc: add TC_imm_ass_pre_chan_ack_dyn_ts<br><br>Related: SYS#5559<br>Change-Id: Ic5a3b930c57a5c61514137986eb4f8f8c1f2a1ba<br>---<br>M bsc/BSC_Tests.ttcn<br>M bsc/BSC_Tests_2.ttcn<br>2 files changed, 72 insertions(+), 4 deletions(-)<br><br></pre><pre style="font-family: monospace,monospace; white-space: pre-wrap;">git pull ssh://gerrit.osmocom.org:29418/osmo-ttcn3-hacks refs/changes/69/25169/1</pre><pre style="font-family: monospace,monospace; white-space: pre-wrap;"><span>diff --git a/bsc/BSC_Tests.ttcn b/bsc/BSC_Tests.ttcn</span><br><span>index f9900f7..1cc876f 100644</span><br><span>--- a/bsc/BSC_Tests.ttcn</span><br><span>+++ b/bsc/BSC_Tests.ttcn</span><br><span>@@ -4232,14 +4232,14 @@</span><br><span>     f_shutdown_helper();</span><br><span> }</span><br><span> </span><br><span style="color: hsl(0, 100%, 40%);">-private function f_disable_all_tch_f() runs on test_CT {</span><br><span style="color: hsl(120, 100%, 40%);">+function f_disable_all_tch_f() runs on test_CT {</span><br><span>      f_vty_transceive(BSCVTY, "bts 0 trx 0 timeslot 1 sub-slot 0 borken");</span><br><span>      f_vty_transceive(BSCVTY, "bts 0 trx 0 timeslot 2 sub-slot 0 borken");</span><br><span>      f_vty_transceive(BSCVTY, "bts 0 trx 0 timeslot 3 sub-slot 0 borken");</span><br><span>      f_vty_transceive(BSCVTY, "bts 0 trx 0 timeslot 4 sub-slot 0 borken");</span><br><span> }</span><br><span> </span><br><span style="color: hsl(0, 100%, 40%);">-private function f_disable_all_tch_h() runs on test_CT {</span><br><span style="color: hsl(120, 100%, 40%);">+function f_disable_all_tch_h() runs on test_CT {</span><br><span>   f_vty_transceive(BSCVTY, "bts 0 trx 0 timeslot 5 sub-slot 0 borken");</span><br><span>      f_vty_transceive(BSCVTY, "bts 0 trx 0 timeslot 5 sub-slot 1 borken");</span><br><span> }</span><br><span>@@ -4253,7 +4253,7 @@</span><br><span>         f_vty_transceive(BSCVTY, "bts 0 trx 0 timeslot 5 sub-slot 1 unused");</span><br><span> }</span><br><span> </span><br><span style="color: hsl(0, 100%, 40%);">-private function f_disable_all_sdcch() runs on test_CT {</span><br><span style="color: hsl(120, 100%, 40%);">+function f_disable_all_sdcch() runs on test_CT {</span><br><span>   f_vty_transceive(BSCVTY, "bts 0 trx 0 timeslot 0 sub-slot 0 borken");</span><br><span>      f_vty_transceive(BSCVTY, "bts 0 trx 0 timeslot 0 sub-slot 1 borken");</span><br><span>      f_vty_transceive(BSCVTY, "bts 0 trx 0 timeslot 0 sub-slot 2 borken");</span><br><span>@@ -6748,7 +6748,7 @@</span><br><span>      }</span><br><span> }</span><br><span> </span><br><span style="color: hsl(0, 100%, 40%);">-private function f_ts_set_chcomb(integer bts_nr, integer trx_nr, integer ts_nr, charstring chcomb)</span><br><span style="color: hsl(120, 100%, 40%);">+function f_ts_set_chcomb(integer bts_nr, integer trx_nr, integer ts_nr, charstring chcomb)</span><br><span> runs on test_CT {</span><br><span>        f_vty_enter_cfg_ts(BSCVTY, bts_nr, trx_nr, ts_nr);</span><br><span>   f_vty_transceive(BSCVTY, "phys_chan_config " & chcomb);</span><br><span>diff --git a/bsc/BSC_Tests_2.ttcn b/bsc/BSC_Tests_2.ttcn</span><br><span>index bbf869f..b211a37 100644</span><br><span>--- a/bsc/BSC_Tests_2.ttcn</span><br><span>+++ b/bsc/BSC_Tests_2.ttcn</span><br><span>@@ -185,8 +185,76 @@</span><br><span>    f_shutdown_helper();</span><br><span> }</span><br><span> </span><br><span style="color: hsl(120, 100%, 40%);">+testcase TC_imm_ass_pre_chan_ack_dyn_ts() runs on test_CT {</span><br><span style="color: hsl(120, 100%, 40%);">+    /* change Timeslot 6 before f_init() starts RSL */</span><br><span style="color: hsl(120, 100%, 40%);">+    f_init_vty();</span><br><span style="color: hsl(120, 100%, 40%);">+ f_ts_set_chcomb(0, 0, 6, "TCH/F_TCH/H_PDCH");</span><br><span style="color: hsl(120, 100%, 40%);">+       f_vty_transceive(BSCVTY, "drop bts connection 0 oml");</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    f_init(1, false);</span><br><span style="color: hsl(120, 100%, 40%);">+     f_sleep(1.0);</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+       var RslChannelNr chan_nr := valueof(t_RslChanNr_PDCH(6));</span><br><span style="color: hsl(120, 100%, 40%);">+     /* The BSC will activate the dynamic PDCH by default, so confirm that */</span><br><span style="color: hsl(120, 100%, 40%);">+      f_exp_ipa_rx(0, tr_RSL_CHAN_ACT_PDCH(chan_nr, ?));</span><br><span style="color: hsl(120, 100%, 40%);">+    f_ipa_tx(0, ts_RSL_CHAN_ACT_ACK(chan_nr, 2323));</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    /* clean up timeslot 6 config, will only take effect when the OML drops the next time */</span><br><span style="color: hsl(120, 100%, 40%);">+      f_ts_set_chcomb(0, 0, 6, "PDCH");</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+ /* block all static timeslots so that the dyn TS will be used */</span><br><span style="color: hsl(120, 100%, 40%);">+      f_disable_all_tch_f();</span><br><span style="color: hsl(120, 100%, 40%);">+        f_disable_all_tch_h();</span><br><span style="color: hsl(120, 100%, 40%);">+        f_disable_all_sdcch();</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+      var RSL_Message chan_act;</span><br><span style="color: hsl(120, 100%, 40%);">+     var RSL_Message imm_ass;</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    f_init(1, false);</span><br><span style="color: hsl(120, 100%, 40%);">+     f_sleep(1.0);</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+       f_vty_set_imm_ass(BSCVTY, 0, "pre-chan-ack");</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+     /* RA containing reason=LU */</span><br><span style="color: hsl(120, 100%, 40%);">+ var GsmFrameNumber fn := 2342;</span><br><span style="color: hsl(120, 100%, 40%);">+        var uint8_t ra := 2;</span><br><span style="color: hsl(120, 100%, 40%);">+  f_ipa_tx(0, ts_RSL_CHAN_RQD(int2oct(ra, 1), fn));</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+   /* (set bts 0 cfg back to default) */</span><br><span style="color: hsl(120, 100%, 40%);">+ f_vty_set_imm_ass(BSCVTY);</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+  /* Expect the dyn TS to deactivate PDCH first */</span><br><span style="color: hsl(120, 100%, 40%);">+      f_exp_ipa_rx(0, tr_RSL_RF_CHAN_REL(chan_nr));</span><br><span style="color: hsl(120, 100%, 40%);">+ f_ipa_tx(0, ts_RSL_RF_CHAN_REL_ACK(chan_nr));</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+       /* Now activation as SDCCH8 */</span><br><span style="color: hsl(120, 100%, 40%);">+        chan_nr := valueof(t_RslChanNr_SDCCH8(tn := 6, sub_slot := 0));</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+     chan_act := f_exp_ipa_rx(0, tr_RSL_MsgTypeD(RSL_MT_CHAN_ACTIV));</span><br><span style="color: hsl(120, 100%, 40%);">+      //var RslChannelNr chan_nr := chan_act.ies[0].body.chan_nr;</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+ /* *FIRST* expect the Immediate Assignment, before we ACK the chan act */</span><br><span style="color: hsl(120, 100%, 40%);">+     imm_ass := f_exp_ipa_rx(0, tr_RSL_IMM_ASSIGN(0));</span><br><span style="color: hsl(120, 100%, 40%);">+     f_verify_imm_ass(imm_ass, ra, fn, chan_nr);</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+ /* Only now send the Chan Act ACK */</span><br><span style="color: hsl(120, 100%, 40%);">+  f_ipa_tx(0, ts_RSL_CHAN_ACT_ACK(chan_nr, fn+10));</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+   /* Check that the lchan is working */</span><br><span style="color: hsl(120, 100%, 40%);">+ var octetstring l3 := '00010203040506'O;</span><br><span style="color: hsl(120, 100%, 40%);">+      f_ipa_tx(0, ts_RSL_EST_IND(chan_nr, valueof(ts_RslLinkID_DCCH(0)), l3));</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    var BSSAP_N_CONNECT_ind rx_c_ind;</span><br><span style="color: hsl(120, 100%, 40%);">+     BSSAP.receive(tr_BSSAP_CONNECT_ind(?, ?, tr_BSSMAP_ComplL3(l3))) -> value rx_c_ind;</span><br><span style="color: hsl(120, 100%, 40%);">+        BSSAP.send(ts_BSSAP_CONNECT_res(rx_c_ind.connectionId));</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    f_sleep(1.0);</span><br><span style="color: hsl(120, 100%, 40%);">+ f_shutdown_helper();</span><br><span style="color: hsl(120, 100%, 40%);">+}</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span> control {</span><br><span>       execute( TC_imm_ass_post_chan_ack() );</span><br><span>       execute( TC_imm_ass_pre_chan_ack() );</span><br><span style="color: hsl(120, 100%, 40%);">+ execute( TC_imm_ass_pre_chan_ack_dyn_ts() );</span><br><span> }</span><br><span> }</span><br><span></span><br></pre><p>To view, visit <a href="https://gerrit.osmocom.org/c/osmo-ttcn3-hacks/+/25169">change 25169</a>. To unsubscribe, or for help writing mail filters, visit <a href="https://gerrit.osmocom.org/settings">settings</a>.</p><div itemscope itemtype="http://schema.org/EmailMessage"><div itemscope itemprop="action" itemtype="http://schema.org/ViewAction"><link itemprop="url" href="https://gerrit.osmocom.org/c/osmo-ttcn3-hacks/+/25169"/><meta itemprop="name" content="View Change"/></div></div>

<div style="display:none"> Gerrit-Project: osmo-ttcn3-hacks </div>
<div style="display:none"> Gerrit-Branch: master </div>
<div style="display:none"> Gerrit-Change-Id: Ic5a3b930c57a5c61514137986eb4f8f8c1f2a1ba </div>
<div style="display:none"> Gerrit-Change-Number: 25169 </div>
<div style="display:none"> Gerrit-PatchSet: 1 </div>
<div style="display:none"> Gerrit-Owner: neels <nhofmeyr@sysmocom.de> </div>
<div style="display:none"> Gerrit-MessageType: newchange </div>