Onionr/src/runtests/__init__.py

107 lines
3.5 KiB
Python
Raw Normal View History

"""Onionr - Private P2P Communication.
2019-09-26 07:43:03 +00:00
Test Onionr as it is running
2019-09-26 07:43:03 +00:00
"""
import os
from secrets import SystemRandom
2021-02-05 04:38:57 +00:00
import traceback
import logger
from onionrutils import epoch
from . import uicheck, inserttest, stresstest
2019-12-22 19:42:10 +00:00
from . import ownnode
from .webpasstest import webpass_test
2020-02-06 02:31:38 +00:00
from .osver import test_os_ver_endpoint
from .clearnettor import test_clearnet_tor_request
from .housekeeping import test_inserted_housekeeping
from .lanservertest import test_lan_server
from .sneakernettest import test_sneakernet_import
2020-04-04 04:34:23 +00:00
from .dnsrebindingtest import test_dns_rebinding
from .serviceonlinetest import test_service_online
2019-09-26 07:43:03 +00:00
"""
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <https://www.gnu.org/licenses/>.
"""
RUN_TESTS = [uicheck.check_ui,
inserttest.insert_bin_test,
2019-12-22 19:42:10 +00:00
ownnode.test_tor_adder,
ownnode.test_own_node,
stresstest.stress_test_block_insert,
2020-02-06 02:31:38 +00:00
webpass_test,
test_os_ver_endpoint,
test_clearnet_tor_request,
test_inserted_housekeeping,
test_lan_server,
test_sneakernet_import,
test_dns_rebinding,
test_service_online
2019-12-22 19:42:10 +00:00
]
2019-09-26 07:43:03 +00:00
SUCCESS_FILE = os.path.dirname(os.path.realpath(__file__)) + '/../../tests/runtime-result.txt'
2019-09-26 07:43:03 +00:00
class OnionrRunTestManager:
def __init__(self):
self.success: bool = True
self.run_date: int = 0
2021-01-31 04:40:51 +00:00
self.plugin_tests = []
2019-09-26 07:43:03 +00:00
def run_tests(self):
2021-02-05 04:38:57 +00:00
try:
assert 1 == 2
except AssertionError:
pass
else:
logger.error(
"Cannot perform runtests when Python interpreter is optimized",
terminal=True)
return
2020-10-22 14:25:57 +00:00
tests = list(RUN_TESTS)
2021-01-31 04:40:51 +00:00
tests.extend(self.plugin_tests)
2020-10-22 14:25:57 +00:00
SystemRandom().shuffle(tests)
2019-09-26 07:43:03 +00:00
cur_time = epoch.get_epoch()
logger.info(f"Doing runtime tests at {cur_time}")
2019-12-22 19:42:10 +00:00
try:
os.remove(SUCCESS_FILE)
except FileNotFoundError:
pass
done_count: int = 0
total_to_do: int = len(tests)
2019-09-26 07:43:03 +00:00
try:
for i in tests:
2019-09-26 07:43:03 +00:00
last = i
logger.info("[RUNTIME TEST] " + last.__name__ + " started",
terminal=True, timestamp=True)
2019-09-26 07:43:03 +00:00
i(self)
done_count += 1
logger.info("[RUNTIME TEST] " + last.__name__ +
f" passed {done_count}/{total_to_do}",
terminal=True, timestamp=True)
2019-12-22 19:42:10 +00:00
except (ValueError, AttributeError):
logger.error(last.__name__ + ' failed assertions', terminal=True)
except Exception as e:
logger.error(last.__name__ + ' failed with non-asserting exception')
2021-02-05 04:38:57 +00:00
logger.error(traceback.format_exc())
else:
ep = str(epoch.get_epoch())
logger.info(f'All runtime tests passed at {ep}', terminal=True)
with open(SUCCESS_FILE, 'w') as f:
f.write(ep)