blob: 22fe80a05cdc61631494be7a78b3fe2c02648a00 [file] [log] [blame]
Pau Espin Pedrol3c9b80d2017-08-31 18:30:59 +02001#!/usr/bin/env python3
2from osmo_gsm_tester.testenv import *
3
4hlr = suite.hlr()
5bts = suite.bts()
6pcu = bts.pcu()
Pau Espin Pedrol86ea02f2018-02-26 12:14:46 +01007mgw_msc = suite.mgw()
Pau Espin Pedrol3c9b80d2017-08-31 18:30:59 +02008mgw_bsc = suite.mgw()
9stp = suite.stp()
10ggsn = suite.ggsn()
11sgsn = suite.sgsn(hlr, ggsn)
Pau Espin Pedrol86ea02f2018-02-26 12:14:46 +010012msc = suite.msc(hlr, mgw_msc, stp)
Pau Espin Pedrol3c9b80d2017-08-31 18:30:59 +020013bsc = suite.bsc(msc, mgw_bsc, stp)
14ms = suite.modem()
15
16bsc.bts_add(bts)
17sgsn.bts_add(bts)
18
19print('start network...')
20hlr.start()
21stp.start()
22ggsn.start()
23sgsn.start()
24msc.start()
Pau Espin Pedrol86ea02f2018-02-26 12:14:46 +010025mgw_msc.start()
Pau Espin Pedrol3c9b80d2017-08-31 18:30:59 +020026mgw_bsc.start()
27bsc.start()
28
29bts.start()
Pau Espin Pedrol1e191512017-12-11 15:12:55 +010030wait(bsc.bts_is_connected, bts)
Pau Espin Pedrol3c9b80d2017-08-31 18:30:59 +020031print('Waiting for bts to be ready...')
32wait(bts.ready_for_pcu)
33pcu.start()
34
35hlr.subscriber_add(ms)
36
37ms.connect(msc.mcc_mnc())
38ms.attach()
39
40ms.log_info()
41
42print('waiting for modems to attach...')
43wait(ms.is_connected, msc.mcc_mnc())
44wait(msc.subscriber_attached, ms)
45
46print('waiting for modems to attach to data services...')
47wait(ms.is_attached)
Pau Espin Pedrolfd150fb2017-12-12 16:42:45 +010048
49# We need to use inet46 since ofono qmi only uses ipv4v6 eua (OS#2713)
50ctx_id_v4 = ms.activate_context(apn='inet46', protocol=ms.CTX_PROT_IPv4)
Pau Espin Pedrolfd4c1442018-10-25 17:37:23 +020051print("Setting up data plan for %r" % repr(ctx_id_v4))
52ms.setup_context_data_plane(ctx_id_v4)
53print("Running 10 ping requests for %r" % repr(ctx_id_v4))
Pau Espin Pedrol8bf740a2020-04-06 13:35:24 +020054proc = ms.run_netns_wait('ping', ('ping', '-c', '10', ggsn.addr()))
55output = proc.get_stdout()
Pau Espin Pedrol3c9b80d2017-08-31 18:30:59 +020056ms.deactivate_context(ctx_id_v4)
Pau Espin Pedrolfd150fb2017-12-12 16:42:45 +010057
58# We need to use inet46 since ofono qmi only uses ipv4v6 eua (OS#2713)
Pau Espin Pedrol66419942017-12-13 20:04:09 +010059ctx_id_v6 = ms.activate_context(apn='inet46', protocol=ms.CTX_PROT_IPv6)
60sleep(5)
Pau Espin Pedrolfd150fb2017-12-12 16:42:45 +010061# TODO: send ping to server or open TCP conn with a socket in python
Pau Espin Pedrol66419942017-12-13 20:04:09 +010062ms.deactivate_context(ctx_id_v6)
Pau Espin Pedrolfd150fb2017-12-12 16:42:45 +010063
64# IPv46 (dual) not supported in ofono qmi: org.ofono.Error.Failed: Operation failed (36)
65# ctx_id_v46 = ms.activate_context(apn='inet46', protocol=ms.CTX_PROT_IPv46)
66# sleep(5)
67# TODO: send ping to server or open TCP conn with a socket in python
68# ms.deactivate_context(ctx_id_v46)
Pau Espin Pedrol8bf740a2020-04-06 13:35:24 +020069
70print(output)
71test.set_report_stdout(output)