55 lines
1.3 KiB
Python
55 lines
1.3 KiB
Python
|
#!/usr/bin/env python3
|
||
|
from osmo_gsm_tester.testenv import *
|
||
|
|
||
|
hlr = suite.hlr()
|
||
|
bts = suite.bts()
|
||
|
pcu = bts.pcu()
|
||
|
mgcpgw = suite.mgcpgw(bts_ip=bts.remote_addr())
|
||
|
mgw_bsc = suite.mgw()
|
||
|
stp = suite.stp()
|
||
|
ggsn = suite.ggsn()
|
||
|
sgsn = suite.sgsn(hlr, ggsn)
|
||
|
msc = suite.msc(hlr, mgcpgw, stp)
|
||
|
bsc = suite.bsc(msc, mgw_bsc, stp)
|
||
|
ms = suite.modem()
|
||
|
|
||
|
bsc.bts_add(bts)
|
||
|
sgsn.bts_add(bts)
|
||
|
|
||
|
print('start network...')
|
||
|
hlr.start()
|
||
|
stp.start()
|
||
|
ggsn.start()
|
||
|
sgsn.start()
|
||
|
msc.start()
|
||
|
mgcpgw.start()
|
||
|
mgw_bsc.start()
|
||
|
bsc.start()
|
||
|
|
||
|
bts.start()
|
||
|
print('Waiting for bts to be ready...')
|
||
|
wait(bts.ready_for_pcu)
|
||
|
pcu.start()
|
||
|
|
||
|
hlr.subscriber_add(ms)
|
||
|
|
||
|
ms.connect(msc.mcc_mnc())
|
||
|
ms.attach()
|
||
|
|
||
|
ms.log_info()
|
||
|
|
||
|
print('waiting for modems to attach...')
|
||
|
wait(ms.is_connected, msc.mcc_mnc())
|
||
|
wait(msc.subscriber_attached, ms)
|
||
|
|
||
|
print('waiting for modems to attach to data services...')
|
||
|
wait(ms.is_attached)
|
||
|
ctx_id_v4 = ms.activate_context(apn='internet', protocol=ms.CTX_PROT_IPv4)
|
||
|
# IPv6 no supported in EC20: org.ofono.Error.NotImplemented: Implementation not provided (36)
|
||
|
# ctx_id_v6 = ms.activate_context(apn='inet6', protocol=ms.CTX_PROT_IPv6)
|
||
|
# IPv46 (dual) not supported in EC20: org.ofono.Error.Failed: Operation failed (36)
|
||
|
# ctx_id_v46 = ms.activate_context(apn='inet6', protocol=ms.CTX_PROT_IPv46)
|
||
|
sleep(5)
|
||
|
# TODO: send ping to server or open TCP conn with a socket in python
|
||
|
ms.deactivate_context(ctx_id_v4)
|