From 1d2a470a30920a54d2ffc93908a79c60a395130c Mon Sep 17 00:00:00 2001 From: Runar Borge Date: Thu, 6 Feb 2020 21:51:51 +0100 Subject: Testsuite: redo smoketest executor and fix exitcode validator --- scripts/check-qemu-install | 45 ++++++++++++++++++++++++--------------------- 1 file changed, 24 insertions(+), 21 deletions(-) (limited to 'scripts') diff --git a/scripts/check-qemu-install b/scripts/check-qemu-install index a6cc9b60..94300d34 100755 --- a/scripts/check-qemu-install +++ b/scripts/check-qemu-install @@ -288,27 +288,30 @@ try: ################################################# log.info("Executing test-suite ") - def cr(child, command): - child.sendline(command) - i = child.expect(['\n +Invalid command:', - '\n +Set failed', - 'No such file or directory', - 'SMOKETEST FAILED!', - r'\n\S+@\S+[$#]'], timeout=1800) - - if i==0: - raise Exception('Invalid command detected') - elif i==1: - raise Exception('Set syntax failed :/') - elif i==2: - log.error("Did not find VyOS smoketest, this should be an exception") - raise Exception("WTF? did not find VyOS smoketest, this should be an exception") - elif i==3: - log.error("Smoketest failed with an non-zero exitcode") - - cr(c, '/usr/bin/vyos-smoketest || echo "SMOKETEST FAILED!"') - - log.info("Smoke test status") + c.sendline('/usr/bin/vyos-smoketest') + i = c.expect(['\n +Invalid command:', + '\n +Set failed', + 'No such file or directory', + r'\n\S+@\S+[$#]'], timeout=1800) + + if i==0: + raise Exception('Invalid command detected') + elif i==1: + raise Exception('Set syntax failed :/') + elif i==2: + log.error("Did not find VyOS smoketest, this should be an exception") + raise Exception("WTF? did not find VyOS smoketest, this should be an exception") + + c.sendline('echo EXITCODE:$\x16?') + i = c.expect(['EXITCODE:0', 'EXITCODE:\d+'], timeout=10) + if i==0: + log.info('Smoketest finished successfully!') + pass + if i==1: + log.error('Smoketest failed :/') + raise Exception("Smoketest-failed, please look into debug output") + + #log.info("Smoke test status") #data = c.before.decode() ################################################# -- cgit v1.2.3