<p>fixeria has uploaded this change for <strong>review</strong>.</p><p><a href="https://gerrit.osmocom.org/c/osmo-ttcn3-hacks/+/24482">View Change</a></p><pre style="font-family: monospace,monospace; white-space: pre-wrap;">[VAMOS] BTS: add RLL ESTablish REQuest test cases<br><br>Change-Id: I98aa6f77c39e0ef68f232a42c1096a2526d14c5b<br>Related: SYS#4895, OS#4941<br>---<br>M bts/BTS_Tests.ttcn<br>M bts/BTS_Tests_VAMOS.ttcn<br>2 files changed, 63 insertions(+), 6 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/82/24482/1</pre><pre style="font-family: monospace,monospace; white-space: pre-wrap;"><span>diff --git a/bts/BTS_Tests.ttcn b/bts/BTS_Tests.ttcn</span><br><span>index ee5258c..eacea3f 100644</span><br><span>--- a/bts/BTS_Tests.ttcn</span><br><span>+++ b/bts/BTS_Tests.ttcn</span><br><span>@@ -2211,7 +2211,7 @@</span><br><span> }</span><br><span> </span><br><span> /* Establish dedicated channel: L1CTL + RSL side */</span><br><span style="color: hsl(0, 100%, 40%);">-private function f_est_dchan(boolean encr_enable := false, RSL_IE_List more_ies := {}) runs on ConnHdlr {</span><br><span style="color: hsl(120, 100%, 40%);">+friend function f_est_dchan(boolean encr_enable := false, RSL_IE_List more_ies := {}) runs on ConnHdlr {</span><br><span>   var GsmFrameNumber fn;</span><br><span>       var ImmediateAssignment imm_ass;</span><br><span>     var ChannelDescription ch_desc;</span><br><span>diff --git a/bts/BTS_Tests_VAMOS.ttcn b/bts/BTS_Tests_VAMOS.ttcn</span><br><span>index ac7b2d7..570fffa 100644</span><br><span>--- a/bts/BTS_Tests_VAMOS.ttcn</span><br><span>+++ b/bts/BTS_Tests_VAMOS.ttcn</span><br><span>@@ -161,7 +161,8 @@</span><br><span>   }</span><br><span> }</span><br><span> </span><br><span style="color: hsl(0, 100%, 40%);">-private function f_TC_vamos_exec_sync(in ChanNrModeTest test, void_fn handler)</span><br><span style="color: hsl(120, 100%, 40%);">+private function f_TC_vamos_exec_sync(in ChanNrModeTest test, void_fn handler,</span><br><span style="color: hsl(120, 100%, 40%);">+                                    template (omit) TestSpecUnion spec := omit)</span><br><span> runs on test_CT {</span><br><span>       var ConnHdlrPars pars;</span><br><span>       var ConnHdlr vc_conn;</span><br><span>@@ -171,14 +172,17 @@</span><br><span>        for (var integer i := 0; i < lengthof(test); i := i + 1) {</span><br><span>                /* Start a ConnHdlr component for each logical channel */</span><br><span>            for (var integer ch := 0; ch < lengthof(test[i]); ch := ch + 1) {</span><br><span style="color: hsl(0, 100%, 40%);">-                    pars := valueof(t_Pars(test[i][ch].chan_nr, test[i][ch].chan_mode));</span><br><span style="color: hsl(0, 100%, 40%);">-                    vc_conn := f_start_handler(handler, pars, l1ctl := false);</span><br><span style="color: hsl(120, 100%, 40%);">+                    pars := valueof(t_Pars(test[i][ch].chan_nr,</span><br><span style="color: hsl(120, 100%, 40%);">+                                          test[i][ch].chan_mode,</span><br><span style="color: hsl(120, 100%, 40%);">+                                        spec := spec));</span><br><span style="color: hsl(120, 100%, 40%);">+                        vc_conn := f_start_handler(handler, pars);</span><br><span>                   vc_conn.done;</span><br><span>                }</span><br><span>    }</span><br><span> }</span><br><span> </span><br><span style="color: hsl(0, 100%, 40%);">-private function f_TC_vamos_exec_async(in ChanNrModeTest test, void_fn handler)</span><br><span style="color: hsl(120, 100%, 40%);">+private function f_TC_vamos_exec_async(in ChanNrModeTest test, void_fn handler,</span><br><span style="color: hsl(120, 100%, 40%);">+                                   template (omit) TestSpecUnion spec := omit)</span><br><span> runs on test_CT {</span><br><span>      /* Up to 4 simultenious lchans */</span><br><span>    var ConnHdlrPars pars[4];</span><br><span>@@ -190,7 +194,8 @@</span><br><span>              /* Start a ConnHdlr component for each logical channel */</span><br><span>            for (var integer ch := 0; ch < lengthof(test[i]); ch := ch + 1) {</span><br><span>                         pars[ch] := valueof(t_Pars(test[i][ch].chan_nr,</span><br><span style="color: hsl(0, 100%, 40%);">-                                            test[i][ch].chan_mode));</span><br><span style="color: hsl(120, 100%, 40%);">+                                              test[i][ch].chan_mode,</span><br><span style="color: hsl(120, 100%, 40%);">+                                                spec := spec));</span><br><span>                   vc_conn[ch] := f_start_handler(handler, pars[ch], l1ctl := false);</span><br><span>           }</span><br><span> </span><br><span>@@ -323,6 +328,58 @@</span><br><span>         f_TC_vamos_exec_async(test, refers(f_TC_vamos_chan_mode_modify));</span><br><span> }</span><br><span> </span><br><span style="color: hsl(120, 100%, 40%);">+private function f_TC_vamos_rll_est_req(charstring id)</span><br><span style="color: hsl(120, 100%, 40%);">+runs on ConnHdlr {</span><br><span style="color: hsl(120, 100%, 40%);">+        var RSL_IE tsc_ie := valueof(ts_RSL_IE_OsmoTSC);</span><br><span style="color: hsl(120, 100%, 40%);">+      var RllTestCase tc := g_pars.spec.rll;</span><br><span style="color: hsl(120, 100%, 40%);">+        timer T := 3.0;</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+     f_l1_tune(L1CTL);</span><br><span style="color: hsl(120, 100%, 40%);">+     L1CTL.clear;</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        /* CHANnel ACTIVation with Osmocom specific IEs */</span><br><span style="color: hsl(120, 100%, 40%);">+    f_est_dchan(more_ies := { tsc_ie });</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        log("f_TC_vamos_rll_est_req(): sending EST REQ");</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+ /* Establish a logical link towards the MS */</span><br><span style="color: hsl(120, 100%, 40%);">+ RSL.send(ts_RSL_EST_REQ(g_chan_nr, tc.link_id));</span><br><span style="color: hsl(120, 100%, 40%);">+      T.start;</span><br><span style="color: hsl(120, 100%, 40%);">+      alt {</span><br><span style="color: hsl(120, 100%, 40%);">+ [] as_l1_exp_lapdm(tr_LAPDm_SABM(tc.sapi, cr_MT_CMD, true, ''O));</span><br><span style="color: hsl(120, 100%, 40%);">+     [] T.timeout {</span><br><span style="color: hsl(120, 100%, 40%);">+                Misc_Helpers.f_shutdown(__BFILE__, __LINE__, fail,</span><br><span style="color: hsl(120, 100%, 40%);">+                                    "Timeout waiting for LAPDm func=SABM");</span><br><span style="color: hsl(120, 100%, 40%);">+             }</span><br><span style="color: hsl(120, 100%, 40%);">+     }</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+   log("f_TC_vamos_rll_est_req(): got EST REQ!");</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    /* DEACTivate the channel */</span><br><span style="color: hsl(120, 100%, 40%);">+  f_rsl_chan_deact();</span><br><span style="color: hsl(120, 100%, 40%);">+   f_rslem_unregister(0, g_chan_nr);</span><br><span style="color: hsl(120, 100%, 40%);">+}</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+/* VFF: V0(TCH/F) & V1(TCH/F), 2 channels total */</span><br><span style="color: hsl(120, 100%, 40%);">+testcase TC_vamos_rll_est_req_vff() runs on test_CT { /* TCH/F on TS1 */</span><br><span style="color: hsl(120, 100%, 40%);">+      var RllTestCase rll := valueof(t_EITC(0, ts_RslLinkID_DCCH(0), ''O, true));</span><br><span style="color: hsl(120, 100%, 40%);">+   var ChanNrModeTest test := valueof(ChanNrModeTestVFF(1));</span><br><span style="color: hsl(120, 100%, 40%);">+     f_TC_vamos_exec_sync(test, refers(f_TC_vamos_rll_est_req),</span><br><span style="color: hsl(120, 100%, 40%);">+                         TestSpecUnion:{ rll := rll });</span><br><span style="color: hsl(120, 100%, 40%);">+}</span><br><span style="color: hsl(120, 100%, 40%);">+testcase TC_vamos_rll_est_req_dyn_ipa_vff() runs on test_CT { /* TCH/F+PDCH on TS3 */</span><br><span style="color: hsl(120, 100%, 40%);">+ var RllTestCase rll := valueof(t_EITC(0, ts_RslLinkID_DCCH(0), ''O, true));</span><br><span style="color: hsl(120, 100%, 40%);">+   var ChanNrModeTest test := valueof(ChanNrModeTestVFF(3));</span><br><span style="color: hsl(120, 100%, 40%);">+     f_TC_vamos_exec_sync(test, refers(f_TC_vamos_rll_est_req),</span><br><span style="color: hsl(120, 100%, 40%);">+                         TestSpecUnion:{ rll := rll });</span><br><span style="color: hsl(120, 100%, 40%);">+}</span><br><span style="color: hsl(120, 100%, 40%);">+testcase TC_vamos_rll_est_req_dyn_osmo_vff() runs on test_CT { /* TCH/F+TCH/H+PDCH on TS4 */</span><br><span style="color: hsl(120, 100%, 40%);">+  var RllTestCase rll := valueof(t_EITC(0, ts_RslLinkID_DCCH(0), ''O, true));</span><br><span style="color: hsl(120, 100%, 40%);">+   var ChanNrModeTest test := valueof(ChanNrModeTestVFF(4));</span><br><span style="color: hsl(120, 100%, 40%);">+     f_TC_vamos_exec_sync(test, refers(f_TC_vamos_rll_est_req),</span><br><span style="color: hsl(120, 100%, 40%);">+                         TestSpecUnion:{ rll := rll });</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>        /* CHANnel ACTIVation tests */</span><br><span>       execute( TC_vamos_chan_act_vff() );</span><br><span></span><br></pre><p>To view, visit <a href="https://gerrit.osmocom.org/c/osmo-ttcn3-hacks/+/24482">change 24482</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/+/24482"/><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: I98aa6f77c39e0ef68f232a42c1096a2526d14c5b </div>
<div style="display:none"> Gerrit-Change-Number: 24482 </div>
<div style="display:none"> Gerrit-PatchSet: 1 </div>
<div style="display:none"> Gerrit-Owner: fixeria <vyanitskiy@sysmocom.de> </div>
<div style="display:none"> Gerrit-MessageType: newchange </div>