|
|
|
#!/usr/bin/env python3
|
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
# Requires Python 2.7 or later
|
|
|
|
|
|
|
|
from __future__ import with_statement
|
|
|
|
from __future__ import unicode_literals
|
|
|
|
|
|
|
|
import os, string, sys, time, unittest
|
|
|
|
|
|
|
|
try:
|
|
|
|
start = time.perf_counter()
|
|
|
|
timer = time.perf_counter
|
|
|
|
except AttributeError:
|
|
|
|
timer = time.time
|
|
|
|
|
|
|
|
if sys.platform == "win32":
|
|
|
|
import XiteWin as Xite
|
|
|
|
else:
|
|
|
|
import XiteQt as Xite
|
|
|
|
|
|
|
|
class TestPerformance(unittest.TestCase):
|
|
|
|
|
|
|
|
def setUp(self):
|
|
|
|
self.xite = Xite.xiteFrame
|
|
|
|
self.ed = self.xite.ed
|
|
|
|
self.ed.ClearAll()
|
|
|
|
self.ed.EmptyUndoBuffer()
|
|
|
|
|
|
|
|
def testAddLine(self):
|
|
|
|
data = (string.ascii_letters + string.digits + "\n").encode('utf-8')
|
|
|
|
start = timer()
|
|
|
|
for i in range(1000):
|
|
|
|
self.ed.AddText(len(data), data)
|
|
|
|
self.assertEquals(self.ed.LineCount, i + 2)
|
|
|
|
end = timer()
|
|
|
|
duration = end - start
|
|
|
|
print("%6.3f testAddLine" % duration)
|
|
|
|
self.xite.DoEvents()
|
|
|
|
self.assert_(self.ed.Length > 0)
|
|
|
|
|
|
|
|
def testAddLineMiddle(self):
|
|
|
|
data = (string.ascii_letters + string.digits + "\n").encode('utf-8')
|
|
|
|
start = timer()
|
|
|
|
for i in range(1000):
|
|
|
|
self.ed.AddText(len(data), data)
|
|
|
|
self.assertEquals(self.ed.LineCount, i + 2)
|
|
|
|
end = timer()
|
|
|
|
duration = end - start
|
|
|
|
print("%6.3f testAddLineMiddle" % duration)
|
|
|
|
self.xite.DoEvents()
|
|
|
|
self.assert_(self.ed.Length > 0)
|
|
|
|
|
|
|
|
def testHuge(self):
|
|
|
|
data = (string.ascii_letters + string.digits + "\n").encode('utf-8')
|
|
|
|
data = data * 100000
|
|
|
|
start = timer()
|
|
|
|
self.ed.AddText(len(data), data)
|
|
|
|
end = timer()
|
|
|
|
duration = end - start
|
|
|
|
print("%6.3f testHuge" % duration)
|
|
|
|
self.xite.DoEvents()
|
|
|
|
self.assert_(self.ed.Length > 0)
|
|
|
|
|
|
|
|
def testHugeInserts(self):
|
|
|
|
data = (string.ascii_letters + string.digits + "\n").encode('utf-8')
|
|
|
|
data = data * 100000
|
|
|
|
insert = (string.digits + "\n").encode('utf-8')
|
|
|
|
self.ed.AddText(len(data), data)
|
|
|
|
start = timer()
|
|
|
|
for i in range(1000):
|
|
|
|
self.ed.InsertText(0, insert)
|
|
|
|
end = timer()
|
|
|
|
duration = end - start
|
|
|
|
print("%6.3f testHugeInserts" % duration)
|
|
|
|
self.xite.DoEvents()
|
|
|
|
self.assert_(self.ed.Length > 0)
|
|
|
|
|
|
|
|
def testHugeReplace(self):
|
|
|
|
oneLine = (string.ascii_letters + string.digits + "\n").encode('utf-8')
|
|
|
|
data = oneLine * 100000
|
|
|
|
insert = (string.digits + "\n").encode('utf-8')
|
|
|
|
self.ed.AddText(len(data), data)
|
|
|
|
start = timer()
|
|
|
|
for i in range(1000):
|
|
|
|
self.ed.TargetStart = i * len(insert)
|
|
|
|
self.ed.TargetEnd = self.ed.TargetStart + len(oneLine)
|
|
|
|
self.ed.ReplaceTarget(len(insert), insert)
|
|
|
|
end = timer()
|
|
|
|
duration = end - start
|
|
|
|
print("%6.3f testHugeReplace" % duration)
|
|
|
|
self.xite.DoEvents()
|
|
|
|
self.assert_(self.ed.Length > 0)
|
|
|
|
|
|
|
|
def testUTF8CaseSearches(self):
|
|
|
|
self.ed.SetCodePage(65001)
|
|
|
|
oneLine = "Fold Margin=折りたたみ表示用の余白(&F)\n".encode('utf-8')
|
|
|
|
manyLines = oneLine * 100000
|
|
|
|
manyLines = manyLines + "φ\n".encode('utf-8')
|
|
|
|
self.ed.AddText(len(manyLines), manyLines)
|
|
|
|
searchString = "φ".encode('utf-8')
|
|
|
|
start = timer()
|
|
|
|
for i in range(10):
|
|
|
|
self.ed.TargetStart = 0
|
|
|
|
self.ed.TargetEnd = self.ed.Length-1
|
|
|
|
self.ed.SearchFlags = self.ed.SCFIND_MATCHCASE
|
|
|
|
pos = self.ed.SearchInTarget(len(searchString), searchString)
|
|
|
|
self.assert_(pos > 0)
|
|
|
|
end = timer()
|
|
|
|
duration = end - start
|
|
|
|
print("%6.3f testUTF8CaseSearches" % duration)
|
|
|
|
self.xite.DoEvents()
|
|
|
|
|
|
|
|
def testUTF8Searches(self):
|
|
|
|
self.ed.SetCodePage(65001)
|
|
|
|
oneLine = "Fold Margin=折りたたみ表示用の余白(&F)\n".encode('utf-8')
|
|
|
|
manyLines = oneLine * 100000
|
|
|
|
manyLines = manyLines + "φ\n".encode('utf-8')
|
|
|
|
self.ed.AddText(len(manyLines), manyLines)
|
|
|
|
searchString = "φ".encode('utf-8')
|
|
|
|
start = timer()
|
|
|
|
for i in range(10):
|
|
|
|
self.ed.TargetStart = 0
|
|
|
|
self.ed.TargetEnd = self.ed.Length-1
|
|
|
|
self.ed.SearchFlags = 0
|
|
|
|
pos = self.ed.SearchInTarget(len(searchString), searchString)
|
|
|
|
self.assert_(pos > 0)
|
|
|
|
end = timer()
|
|
|
|
duration = end - start
|
|
|
|
print("%6.3f testUTF8Searches" % duration)
|
|
|
|
self.xite.DoEvents()
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
Xite.main("performanceTests")
|