blob: e598273131d1e8c7264f7af61ed04820ea355a66 [file] [log] [blame]
Oliver Smithe1f08442019-12-09 15:13:44 +01001#!/usr/bin/env python3
Jacob Erlbeck0760a832013-09-16 11:20:28 +02002
3# (C) 2013 by Jacob Erlbeck <jerlbeck@sysmocom.de>
Holger Hans Peter Freyther3adb7722014-03-04 17:16:58 +01004# (C) 2014 by Holger Hans Peter Freyther
Jacob Erlbeck0760a832013-09-16 11:20:28 +02005# based on vty_test_runner.py:
6# (C) 2013 by Katerina Barone-Adesi <kat.obsc@gmail.com>
7# (C) 2013 by Holger Hans Peter Freyther
8# based on bsc_control.py.
9
10# This program is free software: you can redistribute it and/or modify
11# it under the terms of the GNU General Public License as published by
12# the Free Software Foundation, either version 3 of the License, or
13# (at your option) any later version.
14
15# This program is distributed in the hope that it will be useful,
16# but WITHOUT ANY WARRANTY; without even the implied warranty of
17# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18# GNU General Public License for more details.
19
20# You should have received a copy of the GNU General Public License
21# along with this program. If not, see <http://www.gnu.org/licenses/>.
22
23import os
24import time
25import unittest
26import socket
27import sys
28import struct
29
30import osmopy.obscvty as obscvty
31import osmopy.osmoutil as osmoutil
Maxf8dc5262017-12-19 18:04:18 +010032from osmopy.osmo_ipa import Ctrl, IPA
Max310b7302017-05-02 16:10:07 +020033
Neels Hofmeyr476c4bb2017-02-24 17:55:11 +010034# to be able to find $top_srcdir/doc/...
35confpath = os.path.join(sys.path[0], '..')
Jacob Erlbeck0760a832013-09-16 11:20:28 +020036verbose = False
37
38class TestCtrlBase(unittest.TestCase):
39
40 def ctrl_command(self):
41 raise Exception("Needs to be implemented by a subclass")
42
43 def ctrl_app(self):
44 raise Exception("Needs to be implemented by a subclass")
45
46 def setUp(self):
47 osmo_ctrl_cmd = self.ctrl_command()[:]
48 config_index = osmo_ctrl_cmd.index('-c')
49 if config_index:
50 cfi = config_index + 1
51 osmo_ctrl_cmd[cfi] = os.path.join(confpath, osmo_ctrl_cmd[cfi])
52
53 try:
Jacob Erlbeck0760a832013-09-16 11:20:28 +020054 self.proc = osmoutil.popen_devnull(osmo_ctrl_cmd)
55 except OSError:
Oliver Smithe1f08442019-12-09 15:13:44 +010056 print("Current directory: %s" % os.getcwd(), file=sys.stderr)
57 print("Consider setting -b", file=sys.stderr)
Jacob Erlbeck0760a832013-09-16 11:20:28 +020058 time.sleep(2)
59
60 appstring = self.ctrl_app()[2]
61 appport = self.ctrl_app()[0]
62 self.connect("127.0.0.1", appport)
63 self.next_id = 1000
64
65 def tearDown(self):
66 self.disconnect()
67 osmoutil.end_proc(self.proc)
68
Jacob Erlbeck0760a832013-09-16 11:20:28 +020069 def disconnect(self):
70 if not (self.sock is None):
71 self.sock.close()
72
73 def connect(self, host, port):
74 if verbose:
Oliver Smithe1f08442019-12-09 15:13:44 +010075 print("Connecting to host %s:%i" % (host, port))
Jacob Erlbeck0760a832013-09-16 11:20:28 +020076
Neels Hofmeyracc6e832017-02-27 02:01:37 +010077 retries = 30
78 while True:
79 try:
80 sck = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
81 sck.setblocking(1)
82 sck.connect((host, port))
83 except IOError:
84 retries -= 1
85 if retries <= 0:
86 raise
87 time.sleep(.1)
88 continue
89 break
Jacob Erlbeck0760a832013-09-16 11:20:28 +020090 self.sock = sck
91 return sck
92
93 def send(self, data):
94 if verbose:
Oliver Smithe1f08442019-12-09 15:13:44 +010095 print("Sending \"%s\"" %(data))
Max310b7302017-05-02 16:10:07 +020096 data = Ctrl().add_header(data)
Jacob Erlbeck0760a832013-09-16 11:20:28 +020097 return self.sock.send(data) == len(data)
98
99 def send_set(self, var, value, id):
100 setmsg = "SET %s %s %s" %(id, var, value)
101 return self.send(setmsg)
102
103 def send_get(self, var, id):
104 getmsg = "GET %s %s" %(id, var)
105 return self.send(getmsg)
106
107 def do_set(self, var, value):
108 id = self.next_id
109 self.next_id += 1
110 self.send_set(var, value, id)
111 return self.recv_msgs()[id]
112
113 def do_get(self, var):
114 id = self.next_id
115 self.next_id += 1
116 self.send_get(var, id)
117 return self.recv_msgs()[id]
118
119 def recv_msgs(self):
120 responses = {}
121 data = self.sock.recv(4096)
122 while (len(data)>0):
Max310b7302017-05-02 16:10:07 +0200123 (head, data) = IPA().split_combined(data)
Oliver Smithe1f08442019-12-09 15:13:44 +0100124 answer = Ctrl().rem_header(head).decode()
Jacob Erlbeck0760a832013-09-16 11:20:28 +0200125 if verbose:
Oliver Smithe1f08442019-12-09 15:13:44 +0100126 print("Got message:", answer)
Jacob Erlbeck0760a832013-09-16 11:20:28 +0200127 (mtype, id, msg) = answer.split(None, 2)
128 id = int(id)
129 rsp = {'mtype': mtype, 'id': id}
130 if mtype == "ERROR":
131 rsp['error'] = msg
132 else:
Holger Hans Peter Freyther4ecc6872014-03-04 15:38:00 +0100133 split = msg.split(None, 1)
134 rsp['var'] = split[0]
135 if len(split) > 1:
136 rsp['value'] = split[1]
137 else:
138 rsp['value'] = None
Jacob Erlbeck0760a832013-09-16 11:20:28 +0200139 responses[id] = rsp
140
141 if verbose:
Oliver Smithe1f08442019-12-09 15:13:44 +0100142 print("Decoded replies: ", responses)
Jacob Erlbeck0760a832013-09-16 11:20:28 +0200143
144 return responses
145
146
147class TestCtrlBSC(TestCtrlBase):
148
149 def tearDown(self):
150 TestCtrlBase.tearDown(self)
151 os.unlink("tmp_dummy_sock")
152
153 def ctrl_command(self):
154 return ["./src/osmo-bsc/osmo-bsc", "-r", "tmp_dummy_sock", "-c",
155 "doc/examples/osmo-bsc/osmo-bsc.cfg"]
156
157 def ctrl_app(self):
158 return (4249, "./src/osmo-bsc/osmo-bsc", "OsmoBSC", "bsc")
159
160 def testCtrlErrs(self):
161 r = self.do_get('invalid')
Oliver Smithe1f08442019-12-09 15:13:44 +0100162 self.assertEqual(r['mtype'], 'ERROR')
163 self.assertEqual(r['error'], 'Command not found')
Jacob Erlbeck0760a832013-09-16 11:20:28 +0200164
Jacob Erlbeck4f13d032013-09-16 11:20:29 +0200165 r = self.do_set('rf_locked', '999')
Oliver Smithe1f08442019-12-09 15:13:44 +0100166 self.assertEqual(r['mtype'], 'ERROR')
167 self.assertEqual(r['error'], 'Value failed verification.')
Jacob Erlbeck4f13d032013-09-16 11:20:29 +0200168
Jacob Erlbeck0760a832013-09-16 11:20:28 +0200169 r = self.do_get('bts')
Oliver Smithe1f08442019-12-09 15:13:44 +0100170 self.assertEqual(r['mtype'], 'ERROR')
171 self.assertEqual(r['error'], 'Error while parsing the index.')
Jacob Erlbeck0760a832013-09-16 11:20:28 +0200172
173 r = self.do_get('bts.999')
Oliver Smithe1f08442019-12-09 15:13:44 +0100174 self.assertEqual(r['mtype'], 'ERROR')
175 self.assertEqual(r['error'], 'Error while resolving object')
Jacob Erlbeck0760a832013-09-16 11:20:28 +0200176
Holger Hans Peter Freyther054bc242014-11-10 11:41:03 +0100177 def testBtsLac(self):
178 r = self.do_get('bts.0.location-area-code')
Oliver Smithe1f08442019-12-09 15:13:44 +0100179 self.assertEqual(r['mtype'], 'GET_REPLY')
180 self.assertEqual(r['var'], 'bts.0.location-area-code')
181 self.assertEqual(r['value'], '1')
Holger Hans Peter Freyther054bc242014-11-10 11:41:03 +0100182
183 r = self.do_set('bts.0.location-area-code', '23')
Oliver Smithe1f08442019-12-09 15:13:44 +0100184 self.assertEqual(r['mtype'], 'SET_REPLY')
185 self.assertEqual(r['var'], 'bts.0.location-area-code')
186 self.assertEqual(r['value'], '23')
Holger Hans Peter Freyther054bc242014-11-10 11:41:03 +0100187
188 r = self.do_get('bts.0.location-area-code')
Oliver Smithe1f08442019-12-09 15:13:44 +0100189 self.assertEqual(r['mtype'], 'GET_REPLY')
190 self.assertEqual(r['var'], 'bts.0.location-area-code')
191 self.assertEqual(r['value'], '23')
Holger Hans Peter Freyther054bc242014-11-10 11:41:03 +0100192
193 r = self.do_set('bts.0.location-area-code', '-1')
Oliver Smithe1f08442019-12-09 15:13:44 +0100194 self.assertEqual(r['mtype'], 'ERROR')
195 self.assertEqual(r['error'], 'Input not within the range')
Holger Hans Peter Freyther054bc242014-11-10 11:41:03 +0100196
Holger Hans Peter Freyther8a641412014-11-21 10:54:42 +0100197 def testBtsCi(self):
198 r = self.do_get('bts.0.cell-identity')
Oliver Smithe1f08442019-12-09 15:13:44 +0100199 self.assertEqual(r['mtype'], 'GET_REPLY')
200 self.assertEqual(r['var'], 'bts.0.cell-identity')
201 self.assertEqual(r['value'], '6969')
Holger Hans Peter Freyther8a641412014-11-21 10:54:42 +0100202
203 r = self.do_set('bts.0.cell-identity', '23')
Oliver Smithe1f08442019-12-09 15:13:44 +0100204 self.assertEqual(r['mtype'], 'SET_REPLY')
205 self.assertEqual(r['var'], 'bts.0.cell-identity')
206 self.assertEqual(r['value'], '23')
Holger Hans Peter Freyther8a641412014-11-21 10:54:42 +0100207
208 r = self.do_get('bts.0.cell-identity')
Oliver Smithe1f08442019-12-09 15:13:44 +0100209 self.assertEqual(r['mtype'], 'GET_REPLY')
210 self.assertEqual(r['var'], 'bts.0.cell-identity')
211 self.assertEqual(r['value'], '23')
Holger Hans Peter Freyther8a641412014-11-21 10:54:42 +0100212
213 r = self.do_set('bts.0.cell-identity', '-1')
Oliver Smithe1f08442019-12-09 15:13:44 +0100214 self.assertEqual(r['mtype'], 'ERROR')
215 self.assertEqual(r['error'], 'Input not within the range')
Holger Hans Peter Freyther8a641412014-11-21 10:54:42 +0100216
Holger Hans Peter Freythera49b2c02014-11-21 11:18:45 +0100217 def testBtsGenerateSystemInformation(self):
218 r = self.do_get('bts.0.send-new-system-informations')
Oliver Smithe1f08442019-12-09 15:13:44 +0100219 self.assertEqual(r['mtype'], 'ERROR')
220 self.assertEqual(r['error'], 'Write Only attribute')
Holger Hans Peter Freythera49b2c02014-11-21 11:18:45 +0100221
222 # No RSL links so it will fail
223 r = self.do_set('bts.0.send-new-system-informations', '1')
Oliver Smithe1f08442019-12-09 15:13:44 +0100224 self.assertEqual(r['mtype'], 'ERROR')
225 self.assertEqual(r['error'], 'Failed to generate SI')
Holger Hans Peter Freythera49b2c02014-11-21 11:18:45 +0100226
Holger Hans Peter Freyther5eebb7a2014-12-05 12:03:24 +0100227 def testBtsChannelLoad(self):
228 r = self.do_set('bts.0.channel-load', '1')
Oliver Smithe1f08442019-12-09 15:13:44 +0100229 self.assertEqual(r['mtype'], 'ERROR')
230 self.assertEqual(r['error'], 'Read Only attribute')
Holger Hans Peter Freyther5eebb7a2014-12-05 12:03:24 +0100231
232 # No RSL link so everything is 0
233 r = self.do_get('bts.0.channel-load')
Oliver Smithe1f08442019-12-09 15:13:44 +0100234 self.assertEqual(r['mtype'], 'GET_REPLY')
235 self.assertEqual(r['value'],
Neels Hofmeyr17a6bab2016-07-23 16:14:06 +0200236 'CCCH+SDCCH4,0,0 TCH/F,0,0 TCH/H,0,0 SDCCH8,0,0'
237 + ' TCH/F_PDCH,0,0 CCCH+SDCCH4+CBCH,0,0'
238 + ' SDCCH8+CBCH,0,0 TCH/F_TCH/H_PDCH,0,0')
Holger Hans Peter Freyther5eebb7a2014-12-05 12:03:24 +0100239
Holger Hans Peter Freyther1f6cce72014-12-05 14:44:21 +0100240 def testBtsOmlConnectionState(self):
241 """Check OML state. It will not be connected"""
242 r = self.do_set('bts.0.oml-connection-state', '1')
Oliver Smithe1f08442019-12-09 15:13:44 +0100243 self.assertEqual(r['mtype'], 'ERROR')
244 self.assertEqual(r['error'], 'Read Only attribute')
Holger Hans Peter Freyther1f6cce72014-12-05 14:44:21 +0100245
246 # No RSL link so everything is 0
247 r = self.do_get('bts.0.oml-connection-state')
Oliver Smithe1f08442019-12-09 15:13:44 +0100248 self.assertEqual(r['mtype'], 'GET_REPLY')
249 self.assertEqual(r['value'], 'disconnected')
Holger Hans Peter Freyther1f6cce72014-12-05 14:44:21 +0100250
Holger Hans Peter Freytherd092f482014-03-23 11:17:27 +0100251 def testTrxPowerRed(self):
252 r = self.do_get('bts.0.trx.0.max-power-reduction')
Oliver Smithe1f08442019-12-09 15:13:44 +0100253 self.assertEqual(r['mtype'], 'GET_REPLY')
254 self.assertEqual(r['var'], 'bts.0.trx.0.max-power-reduction')
255 self.assertEqual(r['value'], '20')
Holger Hans Peter Freytherd092f482014-03-23 11:17:27 +0100256
257 r = self.do_set('bts.0.trx.0.max-power-reduction', '22')
Oliver Smithe1f08442019-12-09 15:13:44 +0100258 self.assertEqual(r['mtype'], 'SET_REPLY')
259 self.assertEqual(r['var'], 'bts.0.trx.0.max-power-reduction')
260 self.assertEqual(r['value'], '22')
Holger Hans Peter Freytherd092f482014-03-23 11:17:27 +0100261
262 r = self.do_get('bts.0.trx.0.max-power-reduction')
Oliver Smithe1f08442019-12-09 15:13:44 +0100263 self.assertEqual(r['mtype'], 'GET_REPLY')
264 self.assertEqual(r['var'], 'bts.0.trx.0.max-power-reduction')
265 self.assertEqual(r['value'], '22')
Holger Hans Peter Freytherd092f482014-03-23 11:17:27 +0100266
267 r = self.do_set('bts.0.trx.0.max-power-reduction', '1')
Oliver Smithe1f08442019-12-09 15:13:44 +0100268 self.assertEqual(r['mtype'], 'ERROR')
269 self.assertEqual(r['error'], 'Value must be even')
Holger Hans Peter Freytherd092f482014-03-23 11:17:27 +0100270
Holger Hans Peter Freyther175a2402013-01-09 19:55:04 +0100271 def testTrxArfcn(self):
272 r = self.do_get('bts.0.trx.0.arfcn')
Oliver Smithe1f08442019-12-09 15:13:44 +0100273 self.assertEqual(r['mtype'], 'GET_REPLY')
274 self.assertEqual(r['var'], 'bts.0.trx.0.arfcn')
275 self.assertEqual(r['value'], '871')
Holger Hans Peter Freyther175a2402013-01-09 19:55:04 +0100276
277 r = self.do_set('bts.0.trx.0.arfcn', '873')
Oliver Smithe1f08442019-12-09 15:13:44 +0100278 self.assertEqual(r['mtype'], 'SET_REPLY')
279 self.assertEqual(r['var'], 'bts.0.trx.0.arfcn')
280 self.assertEqual(r['value'], '873')
Holger Hans Peter Freyther175a2402013-01-09 19:55:04 +0100281
282 r = self.do_get('bts.0.trx.0.arfcn')
Oliver Smithe1f08442019-12-09 15:13:44 +0100283 self.assertEqual(r['mtype'], 'GET_REPLY')
284 self.assertEqual(r['var'], 'bts.0.trx.0.arfcn')
285 self.assertEqual(r['value'], '873')
Holger Hans Peter Freyther175a2402013-01-09 19:55:04 +0100286
287 r = self.do_set('bts.0.trx.0.arfcn', '2000')
Oliver Smithe1f08442019-12-09 15:13:44 +0100288 self.assertEqual(r['mtype'], 'ERROR')
289 self.assertEqual(r['error'], 'Input not within the range')
Holger Hans Peter Freyther175a2402013-01-09 19:55:04 +0100290
Jacob Erlbeck0760a832013-09-16 11:20:28 +0200291 def testRfLock(self):
292 r = self.do_get('bts.0.rf_state')
Oliver Smithe1f08442019-12-09 15:13:44 +0100293 self.assertEqual(r['mtype'], 'GET_REPLY')
294 self.assertEqual(r['var'], 'bts.0.rf_state')
295 self.assertEqual(r['value'], 'inoperational,unlocked,on')
Jacob Erlbeck0760a832013-09-16 11:20:28 +0200296
297 r = self.do_set('rf_locked', '1')
Oliver Smithe1f08442019-12-09 15:13:44 +0100298 self.assertEqual(r['mtype'], 'SET_REPLY')
299 self.assertEqual(r['var'], 'rf_locked')
300 self.assertEqual(r['value'], '1')
Jacob Erlbeck0760a832013-09-16 11:20:28 +0200301
302 time.sleep(1.5)
303
304 r = self.do_get('bts.0.rf_state')
Oliver Smithe1f08442019-12-09 15:13:44 +0100305 self.assertEqual(r['mtype'], 'GET_REPLY')
306 self.assertEqual(r['var'], 'bts.0.rf_state')
307 self.assertEqual(r['value'], 'inoperational,locked,off')
Jacob Erlbeck0760a832013-09-16 11:20:28 +0200308
Holger Hans Peter Freyther66105fd2015-02-10 23:03:25 +0100309 r = self.do_get('rf_locked')
Oliver Smithe1f08442019-12-09 15:13:44 +0100310 self.assertEqual(r['mtype'], 'GET_REPLY')
311 self.assertEqual(r['var'], 'rf_locked')
312 self.assertEqual(r['value'], 'state=off,policy=off')
Holger Hans Peter Freyther66105fd2015-02-10 23:03:25 +0100313
Jacob Erlbeck0760a832013-09-16 11:20:28 +0200314 r = self.do_set('rf_locked', '0')
Oliver Smithe1f08442019-12-09 15:13:44 +0100315 self.assertEqual(r['mtype'], 'SET_REPLY')
316 self.assertEqual(r['var'], 'rf_locked')
317 self.assertEqual(r['value'], '0')
Jacob Erlbeck0760a832013-09-16 11:20:28 +0200318
319 time.sleep(1.5)
320
321 r = self.do_get('bts.0.rf_state')
Oliver Smithe1f08442019-12-09 15:13:44 +0100322 self.assertEqual(r['mtype'], 'GET_REPLY')
323 self.assertEqual(r['var'], 'bts.0.rf_state')
324 self.assertEqual(r['value'], 'inoperational,unlocked,on')
Jacob Erlbeck0760a832013-09-16 11:20:28 +0200325
Holger Hans Peter Freyther66105fd2015-02-10 23:03:25 +0100326 r = self.do_get('rf_locked')
Oliver Smithe1f08442019-12-09 15:13:44 +0100327 self.assertEqual(r['mtype'], 'GET_REPLY')
328 self.assertEqual(r['var'], 'rf_locked')
329 self.assertEqual(r['value'], 'state=off,policy=on')
Holger Hans Peter Freyther66105fd2015-02-10 23:03:25 +0100330
Jacob Erlbeckcc391b82013-10-01 13:26:42 +0200331 def testTimezone(self):
Neels Hofmeyr73983952016-05-10 13:29:33 +0200332 r = self.do_get('timezone')
Oliver Smithe1f08442019-12-09 15:13:44 +0100333 self.assertEqual(r['mtype'], 'GET_REPLY')
334 self.assertEqual(r['var'], 'timezone')
335 self.assertEqual(r['value'], 'off')
Jacob Erlbeckcc391b82013-10-01 13:26:42 +0200336
Neels Hofmeyr73983952016-05-10 13:29:33 +0200337 r = self.do_set('timezone', '-2,15,2')
Oliver Smithe1f08442019-12-09 15:13:44 +0100338 self.assertEqual(r['mtype'], 'SET_REPLY')
339 self.assertEqual(r['var'], 'timezone')
340 self.assertEqual(r['value'], '-2,15,2')
Jacob Erlbeckcc391b82013-10-01 13:26:42 +0200341
Neels Hofmeyr73983952016-05-10 13:29:33 +0200342 r = self.do_get('timezone')
Oliver Smithe1f08442019-12-09 15:13:44 +0100343 self.assertEqual(r['mtype'], 'GET_REPLY')
344 self.assertEqual(r['var'], 'timezone')
345 self.assertEqual(r['value'], '-2,15,2')
Jacob Erlbeckcc391b82013-10-01 13:26:42 +0200346
347 # Test invalid input
Neels Hofmeyr73983952016-05-10 13:29:33 +0200348 r = self.do_set('timezone', '-2,15,2,5,6,7')
Oliver Smithe1f08442019-12-09 15:13:44 +0100349 self.assertEqual(r['mtype'], 'SET_REPLY')
350 self.assertEqual(r['var'], 'timezone')
351 self.assertEqual(r['value'], '-2,15,2')
Jacob Erlbeckcc391b82013-10-01 13:26:42 +0200352
Neels Hofmeyr73983952016-05-10 13:29:33 +0200353 r = self.do_set('timezone', '-2,15')
Oliver Smithe1f08442019-12-09 15:13:44 +0100354 self.assertEqual(r['mtype'], 'ERROR')
Neels Hofmeyr73983952016-05-10 13:29:33 +0200355 r = self.do_set('timezone', '-2')
Oliver Smithe1f08442019-12-09 15:13:44 +0100356 self.assertEqual(r['mtype'], 'ERROR')
Neels Hofmeyr73983952016-05-10 13:29:33 +0200357 r = self.do_set('timezone', '1')
Jacob Erlbeckcc391b82013-10-01 13:26:42 +0200358
Neels Hofmeyr73983952016-05-10 13:29:33 +0200359 r = self.do_set('timezone', 'off')
Oliver Smithe1f08442019-12-09 15:13:44 +0100360 self.assertEqual(r['mtype'], 'SET_REPLY')
361 self.assertEqual(r['var'], 'timezone')
362 self.assertEqual(r['value'], 'off')
Jacob Erlbeckcc391b82013-10-01 13:26:42 +0200363
Neels Hofmeyr73983952016-05-10 13:29:33 +0200364 r = self.do_get('timezone')
Oliver Smithe1f08442019-12-09 15:13:44 +0100365 self.assertEqual(r['mtype'], 'GET_REPLY')
366 self.assertEqual(r['var'], 'timezone')
367 self.assertEqual(r['value'], 'off')
Jacob Erlbeckcc391b82013-10-01 13:26:42 +0200368
Holger Hans Peter Freythere9faa6f2014-04-24 10:30:05 +0200369 def testMcc(self):
370 r = self.do_set('mcc', '23')
371 r = self.do_get('mcc')
Oliver Smithe1f08442019-12-09 15:13:44 +0100372 self.assertEqual(r['mtype'], 'GET_REPLY')
373 self.assertEqual(r['var'], 'mcc')
374 self.assertEqual(r['value'], '023')
Holger Hans Peter Freythere9faa6f2014-04-24 10:30:05 +0200375
376 r = self.do_set('mcc', '023')
377 r = self.do_get('mcc')
Oliver Smithe1f08442019-12-09 15:13:44 +0100378 self.assertEqual(r['mtype'], 'GET_REPLY')
379 self.assertEqual(r['var'], 'mcc')
380 self.assertEqual(r['value'], '023')
Holger Hans Peter Freythere9faa6f2014-04-24 10:30:05 +0200381
382 def testMnc(self):
383 r = self.do_set('mnc', '9')
384 r = self.do_get('mnc')
Oliver Smithe1f08442019-12-09 15:13:44 +0100385 self.assertEqual(r['mtype'], 'GET_REPLY')
386 self.assertEqual(r['var'], 'mnc')
387 self.assertEqual(r['value'], '09')
Holger Hans Peter Freythere9faa6f2014-04-24 10:30:05 +0200388
389 r = self.do_set('mnc', '09')
390 r = self.do_get('mnc')
Oliver Smithe1f08442019-12-09 15:13:44 +0100391 self.assertEqual(r['mtype'], 'GET_REPLY')
392 self.assertEqual(r['var'], 'mnc')
393 self.assertEqual(r['value'], '09')
Holger Hans Peter Freythere9faa6f2014-04-24 10:30:05 +0200394
Neels Hofmeyr7cdd0692018-03-05 02:03:57 +0100395 r = self.do_set('mnc', '009')
396 r = self.do_get('mnc')
Oliver Smithe1f08442019-12-09 15:13:44 +0100397 self.assertEqual(r['mtype'], 'GET_REPLY')
398 self.assertEqual(r['var'], 'mnc')
399 self.assertEqual(r['value'], '009')
Neels Hofmeyr7cdd0692018-03-05 02:03:57 +0100400
Holger Hans Peter Freythere9faa6f2014-04-24 10:30:05 +0200401
Holger Hans Peter Freyther3adb7722014-03-04 17:16:58 +0100402 def testMccMncApply(self):
403 # Test some invalid input
404 r = self.do_set('mcc-mnc-apply', 'WRONG')
Oliver Smithe1f08442019-12-09 15:13:44 +0100405 self.assertEqual(r['mtype'], 'ERROR')
Holger Hans Peter Freyther3adb7722014-03-04 17:16:58 +0100406
407 r = self.do_set('mcc-mnc-apply', '1,')
Oliver Smithe1f08442019-12-09 15:13:44 +0100408 self.assertEqual(r['mtype'], 'ERROR')
Holger Hans Peter Freyther3adb7722014-03-04 17:16:58 +0100409
410 r = self.do_set('mcc-mnc-apply', '200,3')
Oliver Smithe1f08442019-12-09 15:13:44 +0100411 self.assertEqual(r['mtype'], 'SET_REPLY')
412 self.assertEqual(r['var'], 'mcc-mnc-apply')
413 self.assertEqual(r['value'], 'Tried to drop the BTS')
Holger Hans Peter Freyther3adb7722014-03-04 17:16:58 +0100414
415 # Set it again
416 r = self.do_set('mcc-mnc-apply', '200,3')
Oliver Smithe1f08442019-12-09 15:13:44 +0100417 self.assertEqual(r['mtype'], 'SET_REPLY')
418 self.assertEqual(r['var'], 'mcc-mnc-apply')
419 self.assertEqual(r['value'], 'Nothing changed')
Holger Hans Peter Freyther3adb7722014-03-04 17:16:58 +0100420
421 # Change it
422 r = self.do_set('mcc-mnc-apply', '200,4')
Oliver Smithe1f08442019-12-09 15:13:44 +0100423 self.assertEqual(r['mtype'], 'SET_REPLY')
424 self.assertEqual(r['var'], 'mcc-mnc-apply')
425 self.assertEqual(r['value'], 'Tried to drop the BTS')
Holger Hans Peter Freyther3adb7722014-03-04 17:16:58 +0100426
427 # Change it
428 r = self.do_set('mcc-mnc-apply', '201,4')
Oliver Smithe1f08442019-12-09 15:13:44 +0100429 self.assertEqual(r['mtype'], 'SET_REPLY')
430 self.assertEqual(r['var'], 'mcc-mnc-apply')
431 self.assertEqual(r['value'], 'Tried to drop the BTS')
Holger Hans Peter Freyther3adb7722014-03-04 17:16:58 +0100432
433 # Verify
434 r = self.do_get('mnc')
Oliver Smithe1f08442019-12-09 15:13:44 +0100435 self.assertEqual(r['mtype'], 'GET_REPLY')
436 self.assertEqual(r['var'], 'mnc')
437 self.assertEqual(r['value'], '04')
Holger Hans Peter Freyther3adb7722014-03-04 17:16:58 +0100438
439 r = self.do_get('mcc')
Oliver Smithe1f08442019-12-09 15:13:44 +0100440 self.assertEqual(r['mtype'], 'GET_REPLY')
441 self.assertEqual(r['var'], 'mcc')
442 self.assertEqual(r['value'], '201')
Holger Hans Peter Freyther3adb7722014-03-04 17:16:58 +0100443
Holger Hans Peter Freythere9faa6f2014-04-24 10:30:05 +0200444 # Change it
445 r = self.do_set('mcc-mnc-apply', '202,03')
Oliver Smithe1f08442019-12-09 15:13:44 +0100446 self.assertEqual(r['mtype'], 'SET_REPLY')
447 self.assertEqual(r['var'], 'mcc-mnc-apply')
448 self.assertEqual(r['value'], 'Tried to drop the BTS')
Holger Hans Peter Freythere9faa6f2014-04-24 10:30:05 +0200449
450 r = self.do_get('mnc')
Oliver Smithe1f08442019-12-09 15:13:44 +0100451 self.assertEqual(r['mtype'], 'GET_REPLY')
452 self.assertEqual(r['var'], 'mnc')
453 self.assertEqual(r['value'], '03')
Holger Hans Peter Freythere9faa6f2014-04-24 10:30:05 +0200454
455 r = self.do_get('mcc')
Oliver Smithe1f08442019-12-09 15:13:44 +0100456 self.assertEqual(r['mtype'], 'GET_REPLY')
457 self.assertEqual(r['var'], 'mcc')
458 self.assertEqual(r['value'], '202')
Holger Hans Peter Freythere9faa6f2014-04-24 10:30:05 +0200459
Neels Hofmeyr7cdd0692018-03-05 02:03:57 +0100460 # Test MNC with 3 digits
461 r = self.do_set('mcc-mnc-apply', '2,003')
Oliver Smithe1f08442019-12-09 15:13:44 +0100462 self.assertEqual(r['mtype'], 'SET_REPLY')
463 self.assertEqual(r['var'], 'mcc-mnc-apply')
464 self.assertEqual(r['value'], 'Tried to drop the BTS')
Neels Hofmeyr7cdd0692018-03-05 02:03:57 +0100465
466 r = self.do_get('mnc')
Oliver Smithe1f08442019-12-09 15:13:44 +0100467 self.assertEqual(r['mtype'], 'GET_REPLY')
468 self.assertEqual(r['var'], 'mnc')
469 self.assertEqual(r['value'], '003')
Neels Hofmeyr7cdd0692018-03-05 02:03:57 +0100470
471 r = self.do_get('mcc')
Oliver Smithe1f08442019-12-09 15:13:44 +0100472 self.assertEqual(r['mtype'], 'GET_REPLY')
473 self.assertEqual(r['var'], 'mcc')
474 self.assertEqual(r['value'], '002')
Neels Hofmeyr7cdd0692018-03-05 02:03:57 +0100475
476 # Set same MNC with 3 digits
477 r = self.do_set('mcc-mnc-apply', '2,003')
Oliver Smithe1f08442019-12-09 15:13:44 +0100478 self.assertEqual(r['mtype'], 'SET_REPLY')
479 self.assertEqual(r['var'], 'mcc-mnc-apply')
480 self.assertEqual(r['value'], 'Nothing changed')
Neels Hofmeyr7cdd0692018-03-05 02:03:57 +0100481
482 r = self.do_get('mnc')
Oliver Smithe1f08442019-12-09 15:13:44 +0100483 self.assertEqual(r['mtype'], 'GET_REPLY')
484 self.assertEqual(r['var'], 'mnc')
485 self.assertEqual(r['value'], '003')
Neels Hofmeyr7cdd0692018-03-05 02:03:57 +0100486
487 r = self.do_get('mcc')
Oliver Smithe1f08442019-12-09 15:13:44 +0100488 self.assertEqual(r['mtype'], 'GET_REPLY')
489 self.assertEqual(r['var'], 'mcc')
490 self.assertEqual(r['value'], '002')
Neels Hofmeyr7cdd0692018-03-05 02:03:57 +0100491
Jacob Erlbeck0760a832013-09-16 11:20:28 +0200492def add_bsc_test(suite, workdir):
493 if not os.path.isfile(os.path.join(workdir, "src/osmo-bsc/osmo-bsc")):
494 print("Skipping the BSC test")
495 return
496 test = unittest.TestLoader().loadTestsFromTestCase(TestCtrlBSC)
497 suite.addTest(test)
498
499if __name__ == '__main__':
500 import argparse
501 import sys
502
503 workdir = '.'
504
505 parser = argparse.ArgumentParser()
506 parser.add_argument("-v", "--verbose", dest="verbose",
507 action="store_true", help="verbose mode")
508 parser.add_argument("-p", "--pythonconfpath", dest="p",
509 help="searchpath for config")
510 parser.add_argument("-w", "--workdir", dest="w",
511 help="Working directory")
512 args = parser.parse_args()
513
514 verbose_level = 1
515 if args.verbose:
516 verbose_level = 2
517 verbose = True
518
519 if args.w:
520 workdir = args.w
521
522 if args.p:
523 confpath = args.p
524
Oliver Smithe1f08442019-12-09 15:13:44 +0100525 print("confpath %s, workdir %s" % (confpath, workdir))
Jacob Erlbeck0760a832013-09-16 11:20:28 +0200526 os.chdir(workdir)
Oliver Smithe1f08442019-12-09 15:13:44 +0100527 print("Running tests for specific control commands")
Jacob Erlbeck0760a832013-09-16 11:20:28 +0200528 suite = unittest.TestSuite()
529 add_bsc_test(suite, workdir)
Jacob Erlbeck0760a832013-09-16 11:20:28 +0200530 res = unittest.TextTestRunner(verbosity=verbose_level).run(suite)
531 sys.exit(len(res.errors) + len(res.failures))