1
0
mirror of https://github.com/SpaceVim/SpaceVim.git synced 2025-02-03 15:10:04 +08:00
SpaceVim/bundle/jedi-vim/pythonx/jedi/scripts/wx_check.py

63 lines
1.6 KiB
Python
Raw Normal View History

2022-10-23 15:41:52 +08:00
#! /usr/bin/env python
"""
Depends: ``objgraph`` (third party Python library)
``wx._core`` is a very nice module to test Jedi's speed and memory performance
on big Python modules. Its size is ~16kLOC (one file). It also seems to look
like a typical big Python modules. A mix between a lot of different Python
things.
You can view a markup version of it here:
https://github.com/wxWidgets/wxPython/blob/master/src/gtk/_core.py
"""
import resource
import time
import sys
try:
import urllib.request as urllib2
except ImportError:
import urllib2
import gc
from os.path import abspath, dirname
import objgraph
sys.path.insert(0, dirname(dirname(abspath(__file__))))
import jedi
def process_memory():
"""
In kB according to
https://stackoverflow.com/questions/938733/total-memory-used-by-python-process
"""
return resource.getrusage(resource.RUSAGE_SELF).ru_maxrss
uri = 'https://raw.githubusercontent.com/wxWidgets/wxPython/master/src/gtk/_core.py'
wx_core = urllib2.urlopen(uri).read()
def run():
start = time.time()
print('Process Memory before: %skB' % process_memory())
# After this the module should be cached.
# Need to invent a path so that it's really cached.
jedi.Script(wx_core, path='foobar.py').complete()
gc.collect() # make sure that it's all fair and the gc did its job.
print('Process Memory after: %skB' % process_memory())
print(objgraph.most_common_types(limit=50))
print('\nIt took %s seconds to parse the file.' % (time.time() - start))
print('First pass')
run()
print('\nSecond pass')
run()
print('\nThird pass')
run()