renamed onionr dir and bugfixes/linting progress
This commit is contained in:
parent
2b996da17f
commit
720efe4fca
226 changed files with 179 additions and 142 deletions
42
src/runtests/__init__.py
Normal file
42
src/runtests/__init__.py
Normal file
|
@ -0,0 +1,42 @@
|
|||
"""
|
||||
Onionr - Private P2P Communication
|
||||
|
||||
Test Onionr as it is running
|
||||
"""
|
||||
"""
|
||||
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/>.
|
||||
"""
|
||||
import logger
|
||||
from onionrutils import epoch
|
||||
|
||||
from . import uicheck, inserttest, stresstest
|
||||
|
||||
RUN_TESTS = [uicheck.check_ui, inserttest.insert_bin_test, stresstest.stress_test_block_insert]
|
||||
|
||||
class OnionrRunTestManager:
|
||||
def __init__(self):
|
||||
self.success:bool = True
|
||||
self.run_date:int = 0
|
||||
|
||||
def run_tests(self):
|
||||
cur_time = epoch.get_epoch()
|
||||
logger.info(f"Doing runtime tests at {cur_time}")
|
||||
try:
|
||||
for i in RUN_TESTS:
|
||||
last = i
|
||||
i(self)
|
||||
logger.info(last.__name__ + " passed")
|
||||
except ValueError:
|
||||
logger.error(last.__name__ + ' failed')
|
||||
|
18
src/runtests/inserttest.py
Normal file
18
src/runtests/inserttest.py
Normal file
|
@ -0,0 +1,18 @@
|
|||
import os
|
||||
import time
|
||||
|
||||
import onionrblocks
|
||||
import logger
|
||||
import coredb
|
||||
from communicator import peeraction
|
||||
|
||||
def _check_remote_node(testmanager):
|
||||
return
|
||||
|
||||
def insert_bin_test(testmanager):
|
||||
data = os.urandom(32)
|
||||
b_hash = onionrblocks.insert(data, )
|
||||
|
||||
if not b_hash in coredb.blockmetadb.get_block_list():
|
||||
logger.error(str(b_hash) + 'is not in bl')
|
||||
raise ValueError
|
16
src/runtests/stresstest.py
Normal file
16
src/runtests/stresstest.py
Normal file
|
@ -0,0 +1,16 @@
|
|||
import os
|
||||
|
||||
import onionrblocks
|
||||
import logger
|
||||
import coredb
|
||||
from onionrutils import epoch
|
||||
|
||||
def stress_test_block_insert(testmanager):
|
||||
start = epoch.get_epoch()
|
||||
count = 100
|
||||
max_insert_speed = 120
|
||||
for x in range(count): onionrblocks.insert(os.urandom(32))
|
||||
speed = epoch.get_epoch() - start
|
||||
if speed < max_insert_speed:
|
||||
raise ValueError(f'{count} blocks inserted too fast, {max_insert_speed}, got {speed}')
|
||||
logger.info(f'runtest stress block insertion: {count} blocks inserted in {speed}s')
|
9
src/runtests/uicheck.py
Normal file
9
src/runtests/uicheck.py
Normal file
|
@ -0,0 +1,9 @@
|
|||
from onionrutils import localcommand
|
||||
def check_ui(test_manager):
|
||||
endpoints = ['/', '/mail/', '/friends/', '/board/']
|
||||
for point in endpoints:
|
||||
result = localcommand.local_command(point)
|
||||
if not result: raise ValueError
|
||||
result = result.lower()
|
||||
if not 'script' in result:
|
||||
raise ValueError(f'uicheck failed on {point}')
|
Loading…
Add table
Add a link
Reference in a new issue