2020-05-07 06:47:46 -04:00
|
|
|
from __future__ import unicode_literals
|
2021-01-25 21:49:01 -05:00
|
|
|
|
|
|
|
import os
|
2020-05-07 06:47:46 -04:00
|
|
|
import re
|
2021-01-25 21:49:01 -05:00
|
|
|
|
2020-05-07 06:47:46 -04:00
|
|
|
import ttfw_idf
|
|
|
|
|
|
|
|
|
2021-03-25 05:50:30 -04:00
|
|
|
@ttfw_idf.idf_example_test(env_tag='Example_WIFI_Protocols')
|
2020-05-07 06:47:46 -04:00
|
|
|
def test_examples_icmp_echo(env, extra_data):
|
|
|
|
|
|
|
|
dut = env.get_dut('icmp_echo', 'examples/protocols/icmp_echo')
|
|
|
|
dut.start_app()
|
|
|
|
|
2022-12-21 22:03:22 -05:00
|
|
|
dut.expect('example_connect: Connected to', timeout=60)
|
2020-05-07 06:47:46 -04:00
|
|
|
dut.expect('esp>')
|
2020-12-25 02:12:08 -05:00
|
|
|
|
|
|
|
ping_dest = os.getenv('EXAMPLE_ICMP_SERVER', 'www.espressif.com')
|
|
|
|
dut.write('ping {}'.format(ping_dest))
|
|
|
|
|
2020-05-07 06:47:46 -04:00
|
|
|
ip_re = r'\.'.join((r'\d{1,3}',) * 4)
|
|
|
|
ip = dut.expect(re.compile(r'64 bytes from ({}) icmp_seq=1 ttl=\d+ time=\d+ ms'.format(ip_re)))[0]
|
|
|
|
|
|
|
|
# expect at least one more (there could be lost packets)
|
2020-05-26 23:16:18 -04:00
|
|
|
dut.expect(re.compile(r'64 bytes from {} icmp_seq=[2-5] ttl=\d+ time='.format(ip)))
|
2020-05-07 06:47:46 -04:00
|
|
|
|
|
|
|
dut.expect(re.compile(r'5 packets transmitted, [2-5] received, \d{1,3}% packet loss'))
|
|
|
|
dut.write('')
|
|
|
|
dut.expect('esp>')
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
test_examples_icmp_echo()
|