2018-07-03 16:27:41 +05:30
|
|
|
#!/usr/bin/env python
|
|
|
|
#
|
2022-05-10 16:16:58 +05:30
|
|
|
# SPDX-FileCopyrightText: 2018-2022 Espressif Systems (Shanghai) CO LTD
|
|
|
|
# SPDX-License-Identifier: Apache-2.0
|
2018-07-03 16:27:41 +05:30
|
|
|
|
|
|
|
import argparse
|
2021-01-26 10:49:01 +08:00
|
|
|
import http.client
|
2022-05-10 16:16:58 +05:30
|
|
|
import logging
|
2019-11-27 11:58:07 +08:00
|
|
|
|
2018-12-04 08:32:48 +01:00
|
|
|
|
|
|
|
def start_session(ip, port):
|
2018-09-10 15:13:47 +02:00
|
|
|
return http.client.HTTPConnection(ip, int(port), timeout=15)
|
2018-07-03 16:27:41 +05:30
|
|
|
|
2018-12-04 08:32:48 +01:00
|
|
|
|
|
|
|
def end_session(conn):
|
2018-07-03 16:27:41 +05:30
|
|
|
conn.close()
|
|
|
|
|
2018-12-04 08:32:48 +01:00
|
|
|
|
|
|
|
def getreq(conn, path, verbose=False):
|
2021-01-26 10:49:01 +08:00
|
|
|
conn.request('GET', path)
|
2018-07-03 16:27:41 +05:30
|
|
|
resp = conn.getresponse()
|
|
|
|
data = resp.read()
|
|
|
|
if verbose:
|
2022-05-10 16:16:58 +05:30
|
|
|
logging.info('GET : {}'.format(path))
|
|
|
|
logging.info('Status : {}'.format(resp.status))
|
|
|
|
logging.info('Reason : {}'.format(resp.reason))
|
|
|
|
logging.info('Data length : {}'.format(len(data)))
|
|
|
|
logging.info('Data content : {}'.format(data))
|
2018-07-03 16:27:41 +05:30
|
|
|
return data
|
|
|
|
|
2018-12-04 08:32:48 +01:00
|
|
|
|
|
|
|
def postreq(conn, path, data, verbose=False):
|
2021-01-26 10:49:01 +08:00
|
|
|
conn.request('POST', path, data)
|
2018-07-03 16:27:41 +05:30
|
|
|
resp = conn.getresponse()
|
|
|
|
data = resp.read()
|
|
|
|
if verbose:
|
2022-05-10 16:16:58 +05:30
|
|
|
logging.info('POST : {}'.format(data))
|
|
|
|
logging.info('Status : {}'.format(resp.status))
|
|
|
|
logging.info('Reason : {}'.format(resp.reason))
|
|
|
|
logging.info('Data length : {}'.format(len(data)))
|
|
|
|
logging.info('Data content : {}'.format(data))
|
2018-07-03 16:27:41 +05:30
|
|
|
return data
|
|
|
|
|
2018-12-04 08:32:48 +01:00
|
|
|
|
|
|
|
def putreq(conn, path, body, verbose=False):
|
2021-01-26 10:49:01 +08:00
|
|
|
conn.request('PUT', path, body)
|
2018-07-03 16:27:41 +05:30
|
|
|
resp = conn.getresponse()
|
|
|
|
data = resp.read()
|
|
|
|
if verbose:
|
2022-05-10 16:16:58 +05:30
|
|
|
logging.info('PUT : {} {}'.format(path, body))
|
|
|
|
logging.info('Status : {}'.format(resp.status))
|
|
|
|
logging.info('Reason : {}'.format(resp.reason))
|
|
|
|
logging.info('Data length : {}'.format(len(data)))
|
|
|
|
logging.info('Data content : {}'.format(data))
|
2018-07-03 16:27:41 +05:30
|
|
|
return data
|
|
|
|
|
2018-12-04 08:32:48 +01:00
|
|
|
|
2018-07-03 16:27:41 +05:30
|
|
|
if __name__ == '__main__':
|
|
|
|
# Configure argument parser
|
|
|
|
parser = argparse.ArgumentParser(description='Run HTTPd Test')
|
2018-12-04 08:32:48 +01:00
|
|
|
parser.add_argument('IP', metavar='IP', type=str, help='Server IP')
|
2018-07-03 16:27:41 +05:30
|
|
|
parser.add_argument('port', metavar='port', type=str, help='Server port')
|
2018-12-04 08:32:48 +01:00
|
|
|
parser.add_argument('N', metavar='integer', type=int, help='Integer to sum upto')
|
2018-07-03 16:27:41 +05:30
|
|
|
args = vars(parser.parse_args())
|
|
|
|
|
|
|
|
# Get arguments
|
|
|
|
ip = args['IP']
|
|
|
|
port = args['port']
|
|
|
|
N = args['N']
|
|
|
|
|
|
|
|
# Establish HTTP connection
|
2022-05-10 16:16:58 +05:30
|
|
|
logging.info('Connecting to => ' + ip + ':' + port)
|
2018-12-04 08:32:48 +01:00
|
|
|
conn = start_session(ip, port)
|
2018-07-03 16:27:41 +05:30
|
|
|
|
|
|
|
# Reset adder context to specified value(0)
|
|
|
|
# -- Not needed as new connection will always
|
|
|
|
# -- have zero value of the accumulator
|
2022-05-10 16:16:58 +05:30
|
|
|
logging.info('Reset the accumulator to 0')
|
2021-01-26 10:49:01 +08:00
|
|
|
putreq(conn, '/adder', str(0))
|
2018-07-03 16:27:41 +05:30
|
|
|
|
|
|
|
# Sum numbers from 1 to specified value(N)
|
2022-05-10 16:16:58 +05:30
|
|
|
logging.info('Summing numbers from 1 to {}'.format(N))
|
2018-12-04 08:32:48 +01:00
|
|
|
for i in range(1, N + 1):
|
2021-01-26 10:49:01 +08:00
|
|
|
postreq(conn, '/adder', str(i))
|
2018-07-03 16:27:41 +05:30
|
|
|
|
|
|
|
# Fetch the result
|
2022-05-10 16:16:58 +05:30
|
|
|
logging.info('Result :{}'.format(getreq(conn, '/adder')))
|
2018-07-03 16:27:41 +05:30
|
|
|
|
|
|
|
# Close HTTP connection
|
2018-12-04 08:32:48 +01:00
|
|
|
end_session(conn)
|