diff options
| author | Neil <nyamatongwe@gmail.com> | 2021-09-02 14:25:24 +1000 | 
|---|---|---|
| committer | Neil <nyamatongwe@gmail.com> | 2021-09-02 14:25:24 +1000 | 
| commit | c9c7c193586c27faaaf7b33b529a47aa200dfdc8 (patch) | |
| tree | 8e1679eee2ce952c6b814c03b9ba7017e75ae0b7 /test/simpleTests.py | |
| parent | ed9b464d422a3c55d1a654bff02f5a39ace3d551 (diff) | |
| download | scintilla-mirror-c9c7c193586c27faaaf7b33b529a47aa200dfdc8.tar.gz | |
Bug [#2281] Fix crash with too many subexpressions in regular expression search
with SCFIND_CXX11REGEX.
Diffstat (limited to 'test/simpleTests.py')
| -rw-r--r-- | test/simpleTests.py | 22 | 
1 files changed, 22 insertions, 0 deletions
| diff --git a/test/simpleTests.py b/test/simpleTests.py index 0bf082438..5b5ae9c0b 100644 --- a/test/simpleTests.py +++ b/test/simpleTests.py @@ -1236,6 +1236,28 @@ class TestSearch(unittest.TestCase):  		self.assertEquals(10, self.ed.FindBytes(0, self.ed.Length, b"\t$", flags))  		self.assertEquals(0, self.ed.FindBytes(0, self.ed.Length, b"([a]).*\0", flags)) +	def testCxx11REFind(self): +		flags = self.ed.SCFIND_REGEXP | self.ed.SCFIND_CXX11REGEX +		self.assertEquals(-1, self.ed.FindBytes(0, self.ed.Length, b"b.g", 0)) +		self.assertEquals(2, self.ed.FindBytes(0, self.ed.Length, b"b.g", flags)) +		self.assertEquals(2, self.ed.FindBytes(0, self.ed.Length, rb"\bb.g\b", flags)) +		self.assertEquals(-1, self.ed.FindBytes(0, self.ed.Length, b"b[A-Z]g", +			flags | self.ed.SCFIND_MATCHCASE)) +		self.assertEquals(2, self.ed.FindBytes(0, self.ed.Length, b"b[a-z]g", flags)) +		self.assertEquals(6, self.ed.FindBytes(0, self.ed.Length, b"b[a-z]*t", flags)) +		self.assertEquals(0, self.ed.FindBytes(0, self.ed.Length, b"^a", flags)) +		self.assertEquals(10, self.ed.FindBytes(0, self.ed.Length, b"\t$", flags)) +		self.assertEquals(0, self.ed.FindBytes(0, self.ed.Length, b"([a]).*\0", flags)) + +	def testCxx11RETooMany(self): +		# For bug #2281 +		self.ed.InsertText(0, b"3ringsForTheElvenKing") +		flags = self.ed.SCFIND_REGEXP | self.ed.SCFIND_CXX11REGEX +		# Only MAXTAG (10) matches allocated, but doesn't modify a vulnerable address until 15 +		pattern = b"(.)" * 15 +		self.assertEquals(0, self.ed.FindBytes(0, self.ed.Length, pattern, flags)) +		self.assertEquals(0, self.ed.FindBytes(0, self.ed.Length, pattern, flags)) +  	def testPhilippeREFind(self):  		# Requires 1.,72  		flags = self.ed.SCFIND_REGEXP | 
