Command arg tests.
parent
1ac099ebdd
commit
e25cb05fc9
@ -0,0 +1,53 @@
|
||||
#!/usr/bin/env python3
|
||||
|
||||
# Test whether command line args are handled
|
||||
|
||||
from mosq_test_helper import *
|
||||
|
||||
def start_broker(args):
|
||||
cmd = ['../../src/mosquitto'] + args
|
||||
|
||||
if os.environ.get('MOSQ_USE_VALGRIND') is not None:
|
||||
logfile = filename+'.'+str(vg_index)+'.vglog'
|
||||
if os.environ.get('MOSQ_USE_VALGRIND') == 'callgrind':
|
||||
cmd = ['valgrind', '-q', '--tool=callgrind', '--log-file='+logfile] + cmd
|
||||
elif os.environ.get('MOSQ_USE_VALGRIND') == 'massif':
|
||||
cmd = ['valgrind', '-q', '--tool=massif', '--log-file='+logfile] + cmd
|
||||
else:
|
||||
cmd = ['valgrind', '-q', '--trace-children=yes', '--leak-check=full', '--show-leak-kinds=all', '--log-file='+logfile] + cmd
|
||||
|
||||
return subprocess.Popen(cmd, stdout=subprocess.DEVNULL, stderr=subprocess.PIPE)
|
||||
|
||||
|
||||
def do_test(args, rc_expected):
|
||||
rc = 1
|
||||
port = mosq_test.get_port()
|
||||
|
||||
try:
|
||||
broker = start_broker(args)
|
||||
broker.wait(timeout=1)
|
||||
|
||||
if broker.returncode == rc_expected:
|
||||
rc = 0
|
||||
except mosq_test.TestError:
|
||||
pass
|
||||
except subprocess.TimeoutExpired:
|
||||
broker.terminate()
|
||||
except Exception as e:
|
||||
print(e)
|
||||
finally:
|
||||
(stdo, stde) = broker.communicate()
|
||||
if rc:
|
||||
print(stde.decode('utf-8'))
|
||||
exit(rc)
|
||||
|
||||
|
||||
do_test(["-h"], 3)
|
||||
do_test(["-p", "0"], 3) # Port invalid
|
||||
do_test(["-p", "65536"], 3) # Port invalid
|
||||
do_test(["-p"], 3) # Missing port
|
||||
do_test(["-c"], 3) # Missing config
|
||||
do_test(["--tls-keylog"], 3) # Missing filename
|
||||
do_test(["--unknown"], 3) # Unknown option
|
||||
|
||||
exit(0)
|
Loading…
Reference in New Issue