ffdebe56ed
git-svn-id: svn://svn.tuxfamily.org/svnroot/notepadplus/repository/trunk@1009 f5eea248-9336-0410-98b8-ebc06183d4e3
84 lines
2.4 KiB
Python
84 lines
2.4 KiB
Python
# -*- coding: utf-8 -*-
|
|
|
|
from __future__ import with_statement
|
|
|
|
import os, string, time, unittest
|
|
|
|
import XiteWin
|
|
|
|
class TestPerformance(unittest.TestCase):
|
|
|
|
def setUp(self):
|
|
self.xite = XiteWin.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 = time.time()
|
|
for i in range(1000):
|
|
self.ed.AddText(len(data), data)
|
|
self.assertEquals(self.ed.LineCount, i + 2)
|
|
end = time.time()
|
|
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 = time.time()
|
|
for i in range(1000):
|
|
self.ed.AddText(len(data), data)
|
|
self.assertEquals(self.ed.LineCount, i + 2)
|
|
end = time.time()
|
|
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 = time.time()
|
|
self.ed.AddText(len(data), data)
|
|
end = time.time()
|
|
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 = time.time()
|
|
for i in range(1000):
|
|
self.ed.InsertText(0, insert)
|
|
end = time.time()
|
|
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 = time.time()
|
|
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 = time.time()
|
|
duration = end - start
|
|
print("%6.3f testHugeReplace" % duration)
|
|
self.xite.DoEvents()
|
|
self.assert_(self.ed.Length > 0)
|
|
|
|
if __name__ == '__main__':
|
|
XiteWin.main("performanceTests")
|