blob: 21ac1ef5127b4d7da14270f2ee7bf6b515a22009 [file] [log] [blame]
Pau Espin Pedrole913e372017-08-24 17:21:51 +02001#!/usr/bin/env python3
2from osmo_gsm_tester.test import *
3
4hlr = suite.hlr()
5bts = suite.bts()
Neels Hofmeyr9b27a852017-09-07 18:55:58 +02006mgw = suite.mgw(bts_ip=bts.remote_addr())
7msc = suite.msc(hlr, mgw)
Pau Espin Pedrole913e372017-08-24 17:21:51 +02008bsc = suite.bsc(msc)
9stp = suite.stp()
10ms = suite.modem()
11
12print('start network...')
13msc.set_authentication(True)
Pau Espin Pedrolabd556a2017-09-04 16:26:08 +020014msc.set_encryption('a5_1')
15bsc.set_encryption('a5_1')
Pau Espin Pedrole913e372017-08-24 17:21:51 +020016hlr.start()
17stp.start()
18msc.start()
Neels Hofmeyr9b27a852017-09-07 18:55:58 +020019mgw.start()
Pau Espin Pedrole913e372017-08-24 17:21:51 +020020bsc.bts_add(bts)
21bsc.start()
22bts.start()
23
24ms.log_info()
25good_ki = ms.ki()
26bad_ki = ("%1X" % (int(good_ki[0], 16) ^ 0x01)) + good_ki[1:]
27
28print('KI changed: ' + good_ki + " => " + bad_ki)
29ms.set_ki(bad_ki)
30hlr.subscriber_add(ms)
31print('Attempt connection with wrong KI...')
32ms.connect(msc.mcc_mnc())
33
Pau Espin Pedrol6680ef22017-09-11 01:24:05 +020034sleep(40) # TODO: read pcap or CTRL interface and look for Rejected? (gsm_a.dtap.msg_mm_type == 0x04)
Pau Espin Pedrole913e372017-08-24 17:21:51 +020035print('Asserting modem did not register')
36# FIXME: this can fail because ofono qmi signals registered before being accepted by network. See OS#2458
37# assert not ms.is_connected(msc.mcc_mnc())
38assert not msc.subscriber_attached(ms)
39
40hlr.subscriber_delete(ms)
41print('KI changed: ' + bad_ki + " => " + good_ki)
42ms.set_ki(good_ki)
43hlr.subscriber_add(ms, ms.msisdn)
44print('Attempt connection with correct KI...')
45ms.connect(msc.mcc_mnc())
46wait(ms.is_connected, msc.mcc_mnc())
47wait(msc.subscriber_attached, ms)