Added conditions for API test cases
This commit is contained in:
parent
6bbe8ef22a
commit
53d46dbdf0
|
@ -183,12 +183,8 @@ class Main(object):
|
|||
adjustHalfOpenConnectionsLimit()
|
||||
config = BMConfigParser()
|
||||
daemon = config.safeGetBoolean('bitmessagesettings', 'daemon')
|
||||
print('+++++++++++++++++++++++++++++++++++++++++++++++')
|
||||
print('config.safeGetBoolean(bitmessagesettings' 'daemon)-{}'.format(
|
||||
config.safeGetBoolean('bitmessagesettings', 'daemon')))
|
||||
print('daemon -{}'.format(daemon))
|
||||
print('+++++++++++++++++++++++++++++++++++++++++++++++')
|
||||
print('------------------192-------------------------')
|
||||
try:
|
||||
opts, _ = getopt.getopt(
|
||||
sys.argv[1:], "hcdt",
|
||||
|
@ -197,7 +193,6 @@ class Main(object):
|
|||
except getopt.GetoptError:
|
||||
self.usage()
|
||||
sys.exit(2)
|
||||
print('------------------196-------------------------')
|
||||
for opt, _ in opts:
|
||||
if opt in ("-h", "--help"):
|
||||
self.usage()
|
||||
|
@ -210,8 +205,7 @@ class Main(object):
|
|||
state.testmode = True
|
||||
if os.path.isfile(os.path.join(
|
||||
state.appdata, 'unittest.lock')):
|
||||
pass
|
||||
# daemon = True
|
||||
daemon = True
|
||||
# run without a UI
|
||||
state.enableGUI = False
|
||||
# Fallback: in case when no api command was issued
|
||||
|
@ -227,18 +221,12 @@ class Main(object):
|
|||
'bitmessagesettings', 'apinotifypath',
|
||||
os.path.join(app_dir, 'tests', 'apinotify_handler.py')
|
||||
)
|
||||
print('------------------225-------------------------')
|
||||
print('+++++++++++++++++++++++++++++++++++++++++++++++')
|
||||
print('config.safeGetBoolean(bitmessagesettings' 'daemon)-{}'.format(
|
||||
config.safeGetBoolean('bitmessagesettings', 'daemon')))
|
||||
print('daemon -{}'.format(daemon))
|
||||
print('+++++++++++++++++++++++++++++++++++++++++++++++')
|
||||
config.safeGetBoolean('bitmessagesettings', 'daemon')
|
||||
if daemon:
|
||||
# run without a UI
|
||||
state.enableGUI = False
|
||||
|
||||
# is the application already running? If yes then exit.
|
||||
print('------------------232-------------------------')
|
||||
if state.enableGUI and not state.curses and not state.kivy and not depends.check_pyqt():
|
||||
sys.exit(
|
||||
'PyBitmessage requires PyQt unless you want'
|
||||
|
@ -254,7 +242,6 @@ class Main(object):
|
|||
)
|
||||
# is the application already running? If yes then exit.
|
||||
state.thisapp = singleinstance("", daemon)
|
||||
print('------------------248-------------------------')
|
||||
if daemon:
|
||||
with printLock:
|
||||
print('Running as a daemon. Send TERM signal to end.')
|
||||
|
@ -267,11 +254,8 @@ class Main(object):
|
|||
state.dandelion = config.safeGet('network', 'dandelion')
|
||||
# dandelion requires outbound connections, without them,
|
||||
# stem objects will get stuck forever
|
||||
print('------------------261-------------------------')
|
||||
|
||||
if state.dandelion and not (config.safeGet('bitmessagesettings', 'sendoutgoingconnections') == 'True'):
|
||||
state.dandelion = 0
|
||||
print('------------------265-------------------------')
|
||||
if state.testmode or config.safeGetBoolean(
|
||||
'bitmessagesettings', 'extralowdifficulty'):
|
||||
defaults.networkDefaultProofOfWorkNonceTrialsPerByte = int(
|
||||
|
@ -282,7 +266,6 @@ class Main(object):
|
|||
readKnownNodes()
|
||||
|
||||
# Not needed if objproc is disabled
|
||||
print('------------------276-------------------------')
|
||||
if state.enableObjProc:
|
||||
|
||||
# Start the address generation thread
|
||||
|
@ -298,7 +281,6 @@ class Main(object):
|
|||
singleWorkerThread.start()
|
||||
# set_thread_name("singleWorkerThread")
|
||||
# Start the SQL thread
|
||||
print('------------------292-------------------------')
|
||||
sqlLookup = sqlThread()
|
||||
# DON'T close the main program even if there are threads left.
|
||||
# The closeEvent should command this thread to exit gracefully.
|
||||
|
@ -309,8 +291,6 @@ class Main(object):
|
|||
# init, needs to be early because other thread may access it early
|
||||
Dandelion()
|
||||
# Enable object processor and SMTP only if objproc enabled
|
||||
print('------------------303-------------------------')
|
||||
|
||||
if state.enableObjProc:
|
||||
# SMTP delivery thread
|
||||
if daemon and config.safeGet(
|
||||
|
@ -341,7 +321,6 @@ class Main(object):
|
|||
singleCleanerThread.start()
|
||||
# set_thread_name("singleCleanerThread")
|
||||
# Not needed if objproc disabled
|
||||
print('------------------335-------------------------')
|
||||
if state.enableObjProc:
|
||||
shared.reloadMyAddressHashes()
|
||||
shared.reloadBroadcastSendersForWhichImWatching()
|
||||
|
@ -355,7 +334,6 @@ class Main(object):
|
|||
singleAPIThread.start()
|
||||
# set_thread_name("singleAPIThread")
|
||||
# start network components if networking is enabled
|
||||
print('------------------351-------------------------')
|
||||
if state.enableNetwork:
|
||||
start_proxyconfig()
|
||||
BMConnectionPool().connectToStream(1)
|
||||
|
@ -388,7 +366,6 @@ class Main(object):
|
|||
state.uploadThread.daemon = True
|
||||
state.uploadThread.start()
|
||||
# set_thread_name("downloadThread")
|
||||
print('------------------383-------------------------')
|
||||
|
||||
if config.safeGetBoolean('bitmessagesettings', 'upnp'):
|
||||
import upnp
|
||||
|
@ -419,9 +396,6 @@ class Main(object):
|
|||
else:
|
||||
config.remove_option('bitmessagesettings', 'dontconnect')
|
||||
|
||||
print('2222222222222222222222222222222222222222222222222222')
|
||||
print('bitmessagemain is the excaution are coming to this part')
|
||||
print('2222222222222222222222222222222222222222222222222222')
|
||||
if daemon:
|
||||
while state.shutdown == 0:
|
||||
time.sleep(1)
|
||||
|
@ -450,88 +424,58 @@ class Main(object):
|
|||
@staticmethod
|
||||
def daemonize():
|
||||
"""Running as a daemon. Send signal in end."""
|
||||
print('---------------441-------------------')
|
||||
grandfatherPid = os.getpid()
|
||||
print('---------------444-------------------')
|
||||
parentPid = None
|
||||
try:
|
||||
print('---------------447-------------------')
|
||||
if os.fork():
|
||||
# unlock
|
||||
print('---------------450-------------------')
|
||||
state.thisapp.cleanup()
|
||||
print('---------------452-------------------')
|
||||
# wait until grandchild ready
|
||||
print('---------------454-------------------')
|
||||
while True:
|
||||
time.sleep(1)
|
||||
print('---------------457-------------------')
|
||||
os._exit(0) # pylint: disable=protected-access
|
||||
except AttributeError:
|
||||
# fork not implemented
|
||||
print('---------------461-------------------')
|
||||
pass
|
||||
else:
|
||||
print('---------------465-------------------')
|
||||
parentPid = os.getpid()
|
||||
print('---------------466-------------------')
|
||||
state.thisapp.lock() # relock
|
||||
print('---------------468-------------------')
|
||||
print('---------------469-------------------')
|
||||
os.umask(0)
|
||||
try:
|
||||
print('---------------472-------------------')
|
||||
os.setsid()
|
||||
except AttributeError:
|
||||
# setsid not implemented
|
||||
print('---------------476-------------------')
|
||||
pass
|
||||
try:
|
||||
print('---------------479-------------------')
|
||||
if os.fork():
|
||||
# unlock
|
||||
print('---------------482-------------------')
|
||||
state.thisapp.cleanup()
|
||||
print('---------------485-------------------')
|
||||
# wait until child ready
|
||||
print('---------------485-------------------')
|
||||
|
||||
# while True:
|
||||
# print('---------------489-------------------')
|
||||
# time.sleep(1)
|
||||
os._exit(0) # pylint: disable=protected-access
|
||||
except AttributeError:
|
||||
print('---------------493-------------------')
|
||||
# fork not implemented
|
||||
pass
|
||||
else:
|
||||
print('---------------497-------------------')
|
||||
state.thisapp.lock() # relock
|
||||
print('---------------499-------------------')
|
||||
state.thisapp.lockPid = None # indicate we're the final child
|
||||
print('---------------501-------------------')
|
||||
sys.stdout.flush()
|
||||
print('---------------502-------------------')
|
||||
sys.stderr.flush()
|
||||
print('---------------505-------------------')
|
||||
if not sys.platform.startswith('win'):
|
||||
si = open(os.devnull)
|
||||
so = open(os.devnull, 'a+')
|
||||
se = open(os.devnull, 'a+')
|
||||
try:
|
||||
os.dup2(si.fileno(), sys.stdin.fileno())
|
||||
print('99999999999999999999999999999999999')
|
||||
os.dup2(so.fileno(), sys.stdout.fileno())
|
||||
print('8888888888888888888888888888888')
|
||||
os.dup2(se.fileno(), sys.stderr.fileno())
|
||||
print('777777777777777777777777777777777')
|
||||
except:
|
||||
pass
|
||||
if parentPid:
|
||||
# signal ready
|
||||
print('---------------522-------------------')
|
||||
os.kill(parentPid, signal.SIGTERM)
|
||||
print('---------------524-------------------')
|
||||
os.kill(grandfatherPid, signal.SIGTERM)
|
||||
|
||||
@staticmethod
|
||||
|
|
|
@ -4,6 +4,7 @@ A thread for creating addresses
|
|||
import hashlib
|
||||
import time
|
||||
from binascii import hexlify
|
||||
import threading
|
||||
try:
|
||||
import defaults
|
||||
import highlevelcrypto
|
||||
|
@ -19,6 +20,7 @@ try:
|
|||
from network.threads import StoppableThread
|
||||
except ModuleNotFoundError:
|
||||
from pybitmessage import defaults
|
||||
from pybitmessage.debug import logger
|
||||
from pybitmessage import highlevelcrypto
|
||||
from pybitmessage import queues
|
||||
from pybitmessage import shared
|
||||
|
@ -50,7 +52,12 @@ class addressGenerator(StoppableThread):
|
|||
# pylint: disable=too-many-locals, too-many-branches
|
||||
# pylint: disable=protected-access, too-many-statements
|
||||
while state.shutdown == 0:
|
||||
logger.info('&&&&&&&&&&&&&&&&&&&&&&&')
|
||||
logger.info('inside the class_addressGenerator\n')
|
||||
logger.info('current thread -{}'.format(threading.current_thread().name))
|
||||
queueValue = queues.addressGeneratorQueue.get()
|
||||
logger.info('$$$$$$$$$$$$ queueValue $$$$$$$$$$$$-{}'.format(queueValue))
|
||||
logger.info('&&&&&&&&&&&&&&&&&&&&&&&')
|
||||
nonceTrialsPerByte = 0
|
||||
payloadLengthExtraBytes = 0
|
||||
live = True
|
||||
|
@ -85,6 +92,9 @@ class addressGenerator(StoppableThread):
|
|||
# the default
|
||||
numberOfNullBytesDemandedOnFrontOfRipeHash = 1
|
||||
elif len(queueValue) == 9:
|
||||
logger.info('&&&&&&&&&&&&&&&&&&&&&&&')
|
||||
logger.info('---------94--------------')
|
||||
logger.info('&&&&&&&&&&&&&&&&&&&&&&&\n')
|
||||
command, addressVersionNumber, streamNumber, label, \
|
||||
numberOfAddressesToMake, deterministicPassphrase, \
|
||||
eighteenByteRipe, nonceTrialsPerByte, \
|
||||
|
@ -102,9 +112,12 @@ class addressGenerator(StoppableThread):
|
|||
# the default
|
||||
numberOfNullBytesDemandedOnFrontOfRipeHash = 1
|
||||
elif queueValue[0] == 'stopThread':
|
||||
logger.info('!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!')
|
||||
logger.info('queueValue[0] == stopThread is this condition are true')
|
||||
logger.info('!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!')
|
||||
break
|
||||
else:
|
||||
self.logger.error(
|
||||
self.logger.info(
|
||||
'Programming error: A structure with the wrong number'
|
||||
' of values was passed into the addressGeneratorQueue.'
|
||||
' Here is the queueValue: %r\n', queueValue)
|
||||
|
@ -132,6 +145,9 @@ class addressGenerator(StoppableThread):
|
|||
queues.UISignalQueue.put((
|
||||
'updateStatusBar', ""
|
||||
))
|
||||
logger.info('&&&&&&&&&&&&&&&&&&&&&&&')
|
||||
logger.info('---------144--------------')
|
||||
logger.info('&&&&&&&&&&&&&&&&&&&&&&&\n')
|
||||
# This next section is a little bit strange. We're going
|
||||
# to generate keys over and over until we find one
|
||||
# that starts with either \x00 or \x00\x00. Then when
|
||||
|
@ -142,6 +158,9 @@ class addressGenerator(StoppableThread):
|
|||
potentialPrivSigningKey = OpenSSL.rand(32)
|
||||
potentialPubSigningKey = highlevelcrypto.pointMult(
|
||||
potentialPrivSigningKey)
|
||||
logger.info('&&&&&&&&&&&&&&&&&&&&&&&')
|
||||
logger.info('---------157--------------')
|
||||
logger.info('&&&&&&&&&&&&&&&&&&&&&&&\n')
|
||||
while True:
|
||||
numberOfAddressesWeHadToMakeBeforeWeFoundOneWithTheCorrectRipePrefix += 1
|
||||
potentialPrivEncryptionKey = OpenSSL.rand(32)
|
||||
|
@ -156,6 +175,9 @@ class addressGenerator(StoppableThread):
|
|||
'\x00'.encode('utf-8') * numberOfNullBytesDemandedOnFrontOfRipeHash
|
||||
):
|
||||
break
|
||||
logger.info('&&&&&&&&&&&&&&&&&&&&&&&')
|
||||
logger.info('---------174--------------')
|
||||
logger.info('&&&&&&&&&&&&&&&&&&&&&&&\n')
|
||||
self.logger.info(
|
||||
'Generated address with ripe digest: %s', hexlify(ripe))
|
||||
try:
|
||||
|
@ -170,20 +192,22 @@ class addressGenerator(StoppableThread):
|
|||
# The user must have a pretty fast computer.
|
||||
# time.time() - startTime equaled zero.
|
||||
pass
|
||||
|
||||
logger.info('&&&&&&&&&&&&&&&&&&&&&&&')
|
||||
logger.info('---------191--------------')
|
||||
logger.info('&&&&&&&&&&&&&&&&&&&&&&&\n')
|
||||
address = encodeAddress(
|
||||
addressVersionNumber, streamNumber, ripe)
|
||||
|
||||
# An excellent way for us to store our keys
|
||||
# is in Wallet Import Format. Let us convert now.
|
||||
# https://en.bitcoin.it/wiki/Wallet_import_format
|
||||
privSigningKey = '\x80'.encode('utf-8')[1:] + potentialPrivSigningKey
|
||||
privSigningKey = '\x80'.encode('raw_unicode_escape') + potentialPrivSigningKey
|
||||
checksum = hashlib.sha256(hashlib.sha256(
|
||||
privSigningKey).digest()).digest()[0:4]
|
||||
privSigningKeyWIF = arithmetic.changebase(
|
||||
privSigningKey + checksum, 256, 58)
|
||||
|
||||
privEncryptionKey = '\x80'.encode('utf-8')[1:] + potentialPrivEncryptionKey
|
||||
privEncryptionKey = '\x80'.encode('raw_unicode_escape') + potentialPrivEncryptionKey
|
||||
checksum = hashlib.sha256(hashlib.sha256(
|
||||
privEncryptionKey).digest()).digest()[0:4]
|
||||
privEncryptionKeyWIF = arithmetic.changebase(
|
||||
|
@ -267,13 +291,13 @@ class addressGenerator(StoppableThread):
|
|||
# An excellent way for us to store our keys
|
||||
# is in Wallet Import Format. Let us convert now.
|
||||
# https://en.bitcoin.it/wiki/Wallet_import_format
|
||||
privSigningKey = '\x80'.encode('utf-8')[1:] + potentialPrivSigningKey
|
||||
privSigningKey ='\x80'.encode('raw_unicode_escape') + potentialPrivSigningKey
|
||||
checksum = hashlib.sha256(hashlib.sha256(
|
||||
privSigningKey).digest()).digest()[0:4]
|
||||
privSigningKeyWIF = arithmetic.changebase(
|
||||
privSigningKey + checksum, 256, 58)
|
||||
|
||||
privEncryptionKey = '\x80'.encode('utf-8')[1:] + potentialPrivEncryptionKey
|
||||
privEncryptionKey ='\x80'.encode('raw_unicode_escape') + potentialPrivEncryptionKey
|
||||
checksum = hashlib.sha256(hashlib.sha256(
|
||||
privEncryptionKey).digest()).digest()[0:4]
|
||||
privEncryptionKeyWIF = arithmetic.changebase(
|
||||
|
@ -333,7 +357,7 @@ class addressGenerator(StoppableThread):
|
|||
# We fill out this list no matter what although we only
|
||||
# need it if we end up passing the info to the API.
|
||||
listOfNewAddressesToSendOutThroughTheAPI = []
|
||||
|
||||
logger
|
||||
for _ in range(numberOfAddressesToMake):
|
||||
# This next section is a little bit strange. We're
|
||||
# going to generate keys over and over until we find
|
||||
|
@ -365,7 +389,7 @@ class addressGenerator(StoppableThread):
|
|||
ripe = RIPEMD160Hash(sha.digest()).digest()
|
||||
if (
|
||||
ripe[:numberOfNullBytesDemandedOnFrontOfRipeHash] ==
|
||||
'\x00' * numberOfNullBytesDemandedOnFrontOfRipeHash
|
||||
'\x00'.encode() * numberOfNullBytesDemandedOnFrontOfRipeHash
|
||||
):
|
||||
break
|
||||
|
||||
|
@ -402,13 +426,13 @@ class addressGenerator(StoppableThread):
|
|||
# An excellent way for us to store our keys is
|
||||
# in Wallet Import Format. Let us convert now.
|
||||
# https://en.bitcoin.it/wiki/Wallet_import_format
|
||||
privSigningKey = '\x80' + potentialPrivSigningKey
|
||||
privSigningKey = '\x80'.encode('raw_unicode_escape') + potentialPrivSigningKey
|
||||
checksum = hashlib.sha256(hashlib.sha256(
|
||||
privSigningKey).digest()).digest()[0:4]
|
||||
privSigningKeyWIF = arithmetic.changebase(
|
||||
privSigningKey + checksum, 256, 58)
|
||||
|
||||
privEncryptionKey = '\x80' + \
|
||||
privEncryptionKey = '\x80'.encode('raw_unicode_escape') + \
|
||||
potentialPrivEncryptionKey
|
||||
checksum = hashlib.sha256(hashlib.sha256(
|
||||
privEncryptionKey).digest()).digest()[0:4]
|
||||
|
@ -502,6 +526,8 @@ class addressGenerator(StoppableThread):
|
|||
elif command == 'getDeterministicAddress':
|
||||
queues.apiAddressGeneratorReturnQueue.put(address)
|
||||
else:
|
||||
logger.info("Error in the addressGenerator thread. Thread was" +
|
||||
" given a command it could not understand:{} " .format(command))
|
||||
raise Exception(
|
||||
"Error in the addressGenerator thread. Thread was" +
|
||||
" given a command it could not understand: " + command)
|
||||
|
|
|
@ -278,7 +278,7 @@ class singleWorker(StoppableThread):
|
|||
TTL = int(28 * 24 * 60 * 60 + helper_random.randomrandrange(-300, 300))
|
||||
embeddedTime = int(time.time() + TTL)
|
||||
payload = pack('>Q', (embeddedTime))
|
||||
payload += '\x00\x00\x00\x01' # object type: pubkey
|
||||
payload += '\x00\x00\x00\x01'.encode() # object type: pubkey
|
||||
payload += encodeVarint(addressVersionNumber) # Address version number
|
||||
payload += encodeVarint(streamNumber)
|
||||
# bitfield of features supported by me (see the wiki).
|
||||
|
@ -352,7 +352,7 @@ class singleWorker(StoppableThread):
|
|||
# expiresTime time.
|
||||
|
||||
payload = pack('>Q', (embeddedTime))
|
||||
payload += '\x00\x00\x00\x01' # object type: pubkey
|
||||
payload += '\x00\x00\x00\x01'.encode() # object type: pubkey
|
||||
payload += encodeVarint(addressVersionNumber) # Address version number
|
||||
payload += encodeVarint(streamNumber)
|
||||
# bitfield of features supported by me (see the wiki).
|
||||
|
|
35
src/debug.py
35
src/debug.py
|
@ -52,8 +52,7 @@ helper_startup.loadConfig()
|
|||
# logging.config.fileConfig interface
|
||||
# examples are here:
|
||||
# https://bitmessage.org/forum/index.php/topic,4820.msg11163.html#msg11163
|
||||
log_level = 'WARNING'
|
||||
|
||||
log_level = 'INFO'
|
||||
|
||||
def log_uncaught_exceptions(ex_cls, ex, tb):
|
||||
"""The last resort logging function used for sys.excepthook"""
|
||||
|
@ -69,14 +68,19 @@ def configureLogging():
|
|||
sys.excepthook = log_uncaught_exceptions
|
||||
fail_msg = ''
|
||||
try:
|
||||
logging_config = os.path.join(state.appdata, 'logging.dat')
|
||||
logging.config.fileConfig(
|
||||
logging_config, disable_existing_loggers=False)
|
||||
return (
|
||||
False,
|
||||
'Loaded logger configuration from %s' % logging_config
|
||||
)
|
||||
logger = logging.getLogger(state.appdata+'/logging.dat')
|
||||
logger.setLevel(logging.DEBUG)
|
||||
# create console handler and set level to debug
|
||||
logging_streamHandler = logging.StreamHandler()
|
||||
logging_streamHandler.setLevel(logging.DEBUG)
|
||||
# create formatter
|
||||
formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
|
||||
# add formatter to ch
|
||||
logging_streamHandler.setFormatter(formatter)
|
||||
# add ch to logger
|
||||
logger.addHandler(logging_streamHandler)
|
||||
except (OSError, configparser.NoSectionError):
|
||||
logging_config = os.path.join(state.appdata, 'logging.dat')
|
||||
if os.path.isfile(logging_config):
|
||||
fail_msg = \
|
||||
'Failed to load logger configuration from %s, using default' \
|
||||
|
@ -142,23 +146,14 @@ def resetLogging():
|
|||
"""Reconfigure logging in runtime when state.appdata dir changed"""
|
||||
# pylint: disable=global-statement, used-before-assignment
|
||||
global logger
|
||||
try:
|
||||
for i in logger.handlers:
|
||||
logger.removeHandler(i)
|
||||
iresetLogging.flush()
|
||||
i.flush()
|
||||
i.close()
|
||||
configureLogging()
|
||||
except:
|
||||
pass
|
||||
logger = logging.getLogger('default')
|
||||
|
||||
|
||||
# !
|
||||
try:
|
||||
preconfigured, msg = configureLogging()
|
||||
logger = logging.getLogger('default')
|
||||
if msg:
|
||||
logger.log(logging.WARNING if preconfigured else logging.INFO, msg)
|
||||
|
||||
except:
|
||||
pass
|
||||
logger = logging.getLogger('default')
|
||||
|
|
|
@ -40,6 +40,8 @@ def sqlQuery(sqlStatement, *args):
|
|||
sqlSubmitQueue.put('')
|
||||
elif isinstance(args[0], (list, tuple)):
|
||||
sqlSubmitQueue.put(args[0])
|
||||
elif isinstance(args[0], memoryview):
|
||||
sqlSubmitQueue.put(bytes(args[0]))
|
||||
else:
|
||||
sqlSubmitQueue.put(args)
|
||||
queryreturn, _ = sqlReturnQueue.get()
|
||||
|
|
|
@ -1,8 +1,12 @@
|
|||
# pylint: disable=missing-docstring
|
||||
import asyncore
|
||||
|
||||
try:
|
||||
from .http import HttpConnection
|
||||
from .tls import TLSDispatcher
|
||||
except:
|
||||
from pybitmessage.network.http import HttpConnection
|
||||
from pybitmessage.network.tls import TLSDispatcher
|
||||
"""
|
||||
self.sslSock = ssl.wrap_socket(
|
||||
self.sock,
|
||||
|
|
|
@ -8,7 +8,7 @@ import struct
|
|||
try:
|
||||
from network.proxy import Proxy, ProxyError, GeneralProxyError
|
||||
except ModuleNotFoundError:
|
||||
from .proxy import Proxy, ProxyError, GeneralProxyError
|
||||
from pybitmessage.network.proxy import Proxy, ProxyError, GeneralProxyError
|
||||
|
||||
|
||||
class Socks4aError(ProxyError):
|
||||
|
|
|
@ -131,3 +131,8 @@ thisapp = None
|
|||
"""Singleton instance"""
|
||||
|
||||
imageDir = None
|
||||
import tempfile
|
||||
import os
|
||||
tmp = os.environ['BITMESSAGE_HOME'] = tempfile.gettempdir()
|
||||
log_file = os.path.join(tmp, 'debuging.log')
|
||||
dst = open(log_file,'a')
|
|
@ -10,6 +10,7 @@ import xmlrpc.client as xmlrpclib # nosec
|
|||
from .test_process import TestProcessProto, TestProcessShutdown
|
||||
from .tests_compatibility import utils
|
||||
|
||||
from pybitmessage.debug import logger
|
||||
class TestAPIProto(TestProcessProto):
|
||||
"""Test case logic for testing API"""
|
||||
_process_cmd = ['pybitmessage', '-t']
|
||||
|
@ -49,6 +50,9 @@ class TestAPIShutdown(TestAPIProto, TestProcessShutdown):
|
|||
self.assertEqual(self.api.shutdown(), 'done')
|
||||
for _ in range(5):
|
||||
if not self.process.is_running():
|
||||
logger.info('-----------------------------------------')
|
||||
logger.info('test_shutdown test_shutdown test_shutdown inside the break condition')
|
||||
logger.info('-----------------------------------------')
|
||||
break
|
||||
time.sleep(2)
|
||||
else:
|
||||
|
@ -139,6 +143,7 @@ class TestAPI(TestAPIProto):
|
|||
r'API Error 0003:'
|
||||
)
|
||||
|
||||
#currently working on this condition
|
||||
def test_create_random_address(self):
|
||||
"""API command 'createRandomAddress': basic BM-address validation"""
|
||||
addr = self._add_random_address('random_1'.encode())
|
||||
|
|
|
@ -58,10 +58,10 @@ handlers=default
|
|||
except ImportError:
|
||||
self.fail('There is no package pybitmessage. Things gone wrong.')
|
||||
finally:
|
||||
os.remove(log_config)
|
||||
pass
|
||||
# os.remove(log_config)
|
||||
logger_ = logging.getLogger('default')
|
||||
|
||||
self.assertEqual(logger, logger_)
|
||||
|
||||
logger_.info('Testing the logger...')
|
||||
self.assertRegex(open(log_file).read(), pattern)
|
||||
|
|
|
@ -31,7 +31,7 @@ class TestProcessProto(unittest.TestCase):
|
|||
_process_cmd = ['pybitmessage', '-d']
|
||||
_threads_count = 15
|
||||
_files = (
|
||||
'keys.dat', 'debug.log', 'messages.dat', 'knownnodes.dat',
|
||||
'keys.dat', 'messages.dat', 'knownnodes.dat',
|
||||
'.api_started', 'unittest.lock','singleton.lock'
|
||||
)
|
||||
|
||||
|
@ -65,8 +65,38 @@ class TestProcessProto(unittest.TestCase):
|
|||
|
||||
@classmethod
|
||||
def _cleanup_files(cls):
|
||||
print('the printing _cleanup_files -{}'.format(cls._files))
|
||||
for pfile in cls._files:
|
||||
try:
|
||||
if pfile == 'debug.log':
|
||||
print('***************************')
|
||||
print('72727272727272772727272727')
|
||||
print('going to open the debug.log file-{}'.format(pfile))
|
||||
print(os.path.join(cls.home, pfile))
|
||||
print('75757575757575757575757')
|
||||
import pdb; pdb.set_trace()
|
||||
try:
|
||||
with open(os.path.join(cls.home, pfile), 'r') as outfile:
|
||||
print(outfile.readlines())
|
||||
print('with with with with ')
|
||||
print('is coming inside the open function')
|
||||
print('with with with with ')
|
||||
except:
|
||||
print('!!!!!!!!!!!!!!!!!!!!!!!!!')
|
||||
print('expectation are occured ')
|
||||
print('!!!!!!!!!!!!!!!!!!!!!!!!!')
|
||||
print('***************************')
|
||||
print('----------------------------')
|
||||
print(' pfile pfile pfile -{}'.format(pfile))
|
||||
try:
|
||||
with open(os.path.join(cls.home, pfile), 'r') as outfile:
|
||||
pass
|
||||
# print(outfile.read())
|
||||
print('----------------------------')
|
||||
except:
|
||||
print('``````````````````````````````````````')
|
||||
print('exceptation are occured while working opening th file-{}'.format(pfile))
|
||||
print('``````````````````````````````````````')
|
||||
os.remove(os.path.join(cls.home, pfile))
|
||||
except OSError:
|
||||
pass
|
||||
|
@ -79,7 +109,6 @@ class TestProcessProto(unittest.TestCase):
|
|||
print('######################################')
|
||||
try:
|
||||
if not cls._stop_process():
|
||||
print(open(os.path.join(cls.home, 'debug.log'), 'rb').read())
|
||||
cls.process.kill()
|
||||
except (psutil.NoSuchProcess, FileNotFoundError, AttributeError) as e:
|
||||
pass
|
||||
|
|
Reference in New Issue
Block a user