mirror of
https://github.com/Mikaela/Limnoria.git
synced 2025-01-25 19:44:13 +01:00
Added a --trace option, moved tracing to utils.
This commit is contained in:
parent
28b05cffcf
commit
35acc6c583
@ -55,13 +55,6 @@ def configure(advanced):
|
|||||||
from questions import expect, anything, something, yn
|
from questions import expect, anything, something, yn
|
||||||
conf.registerPlugin('Debug', True)
|
conf.registerPlugin('Debug', True)
|
||||||
|
|
||||||
def getTracer(fd):
|
|
||||||
def tracer(frame, event, _):
|
|
||||||
if event == 'call':
|
|
||||||
code = frame.f_code
|
|
||||||
print >>fd, '%s: %s' % (code.co_filename, code.co_name)
|
|
||||||
return tracer
|
|
||||||
|
|
||||||
|
|
||||||
class Debug(privmsgs.CapabilityCheckingPrivmsg):
|
class Debug(privmsgs.CapabilityCheckingPrivmsg):
|
||||||
capability = 'owner'
|
capability = 'owner'
|
||||||
@ -104,7 +97,7 @@ class Debug(privmsgs.CapabilityCheckingPrivmsg):
|
|||||||
fd = file(filename, 'a')
|
fd = file(filename, 'a')
|
||||||
else:
|
else:
|
||||||
fd = sys.stdout
|
fd = sys.stdout
|
||||||
sys.settrace(getTracer(fd))
|
sys.settrace(utils.callTracer(fd))
|
||||||
irc.replySuccess()
|
irc.replySuccess()
|
||||||
|
|
||||||
def unsettrace(self, irc, msg, args):
|
def unsettrace(self, irc, msg, args):
|
||||||
|
45
src/utils.py
45
src/utils.py
@ -490,7 +490,6 @@ def saltHash(password, salt=None, hash='sha'):
|
|||||||
def safeEval(s, namespace={'True': True, 'False': False, 'None': None}):
|
def safeEval(s, namespace={'True': True, 'False': False, 'None': None}):
|
||||||
"""Evaluates s, safely. Useful for turning strings into tuples/lists/etc.
|
"""Evaluates s, safely. Useful for turning strings into tuples/lists/etc.
|
||||||
without unsafely using eval()."""
|
without unsafely using eval()."""
|
||||||
#print s, '::', stackTrace()
|
|
||||||
try:
|
try:
|
||||||
node = compiler.parse(s)
|
node = compiler.parse(s)
|
||||||
except SyntaxError, e:
|
except SyntaxError, e:
|
||||||
@ -704,21 +703,6 @@ def mungeEmailForWeb(s):
|
|||||||
s = s.replace('.', ' DOT ')
|
s = s.replace('.', ' DOT ')
|
||||||
return s
|
return s
|
||||||
|
|
||||||
def stackTrace(frame=None, compact=True):
|
|
||||||
if frame is None:
|
|
||||||
frame = sys._getframe()
|
|
||||||
if compact:
|
|
||||||
L = []
|
|
||||||
while frame:
|
|
||||||
lineno = frame.f_lineno
|
|
||||||
funcname = frame.f_code.co_name
|
|
||||||
filename = os.path.basename(frame.f_code.co_filename)
|
|
||||||
L.append('[%s|%s|%s]' % (filename, funcname, lineno))
|
|
||||||
frame = frame.f_back
|
|
||||||
return textwrap.fill(' '.join(L))
|
|
||||||
else:
|
|
||||||
return traceback.format_stack(frame)
|
|
||||||
|
|
||||||
class AtomicFile(file):
|
class AtomicFile(file):
|
||||||
"""Used for files that need to be atomically written -- i.e., if there's a
|
"""Used for files that need to be atomically written -- i.e., if there's a
|
||||||
failure, the original file remains, unmodified. mode must be 'w' or 'wb'"""
|
failure, the original file remains, unmodified. mode must be 'w' or 'wb'"""
|
||||||
@ -773,6 +757,35 @@ def transactionalFile(*args, **kwargs):
|
|||||||
# We do that replacement in conf.py.
|
# We do that replacement in conf.py.
|
||||||
return AtomicFile(*args, **kwargs)
|
return AtomicFile(*args, **kwargs)
|
||||||
|
|
||||||
|
def stackTrace(frame=None, compact=True):
|
||||||
|
if frame is None:
|
||||||
|
frame = sys._getframe()
|
||||||
|
if compact:
|
||||||
|
L = []
|
||||||
|
while frame:
|
||||||
|
lineno = frame.f_lineno
|
||||||
|
funcname = frame.f_code.co_name
|
||||||
|
filename = os.path.basename(frame.f_code.co_filename)
|
||||||
|
L.append('[%s|%s|%s]' % (filename, funcname, lineno))
|
||||||
|
frame = frame.f_back
|
||||||
|
return textwrap.fill(' '.join(L))
|
||||||
|
else:
|
||||||
|
return traceback.format_stack(frame)
|
||||||
|
|
||||||
|
def callTracer(fd=None, basename=True):
|
||||||
|
if fd is None:
|
||||||
|
fd = sys.stdout
|
||||||
|
def tracer(frame, event, _):
|
||||||
|
if event == 'call':
|
||||||
|
code = frame.f_code
|
||||||
|
lineno = frame.f_lineno
|
||||||
|
funcname = code.co_name
|
||||||
|
filename = code.co_filename
|
||||||
|
if basename:
|
||||||
|
filename = os.path.basename(filename)
|
||||||
|
print >>fd, '%s: %s(%s)' % (filename, funcname, lineno)
|
||||||
|
return tracer
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
import doctest
|
import doctest
|
||||||
doctest.testmod(sys.modules['__main__'])
|
doctest.testmod(sys.modules['__main__'])
|
||||||
|
12
test/test.py
12
test/test.py
@ -70,10 +70,13 @@ conf.supybot.flush.setValue(False)
|
|||||||
import supybot.fix as fix
|
import supybot.fix as fix
|
||||||
|
|
||||||
import re
|
import re
|
||||||
|
import sys
|
||||||
import glob
|
import glob
|
||||||
|
import atexit
|
||||||
import os.path
|
import os.path
|
||||||
import unittest
|
import unittest
|
||||||
|
|
||||||
|
import supybot.utils as utils
|
||||||
import supybot.world as world
|
import supybot.world as world
|
||||||
|
|
||||||
class path(str):
|
class path(str):
|
||||||
@ -123,6 +126,8 @@ if __name__ == '__main__':
|
|||||||
help='Causes the network-based tests not to run.')
|
help='Causes the network-based tests not to run.')
|
||||||
parser.add_option('', '--noplugins', action='store_true', default=False,
|
parser.add_option('', '--noplugins', action='store_true', default=False,
|
||||||
help='Causes the plugin tests not to run.')
|
help='Causes the plugin tests not to run.')
|
||||||
|
parser.add_option('', '--trace', action='store_true', default=False,
|
||||||
|
help='Traces all calls made.')
|
||||||
(options, args) = parser.parse_args()
|
(options, args) = parser.parse_args()
|
||||||
if not args:
|
if not args:
|
||||||
if options.noplugins:
|
if options.noplugins:
|
||||||
@ -143,6 +148,13 @@ if __name__ == '__main__':
|
|||||||
if options.timeout:
|
if options.timeout:
|
||||||
PluginTestCase.timeout = options.timeout
|
PluginTestCase.timeout = options.timeout
|
||||||
|
|
||||||
|
if options.trace:
|
||||||
|
traceFilename = conf.supybot.directories.log.dirize('trace.log')
|
||||||
|
fd = file(traceFilename, 'w')
|
||||||
|
sys.settrace(utils.callTracer(fd))
|
||||||
|
atexit.register(fd.close)
|
||||||
|
atexit.register(lambda : sys.settrace(None))
|
||||||
|
|
||||||
if options.plugindirs:
|
if options.plugindirs:
|
||||||
options.plugindirs.reverse()
|
options.plugindirs.reverse()
|
||||||
conf.pluginDirs.extend(options.plugindirs)
|
conf.pluginDirs.extend(options.plugindirs)
|
||||||
|
Loading…
Reference in New Issue
Block a user