mirror of
				https://github.com/python/cpython.git
				synced 2025-10-31 05:31:20 +00:00 
			
		
		
		
	
		
			
	
	
		
			116 lines
		
	
	
	
		
			4.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
		
		
			
		
	
	
			116 lines
		
	
	
	
		
			4.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
|   | #-*- coding: ISO-8859-1 -*- | |||
|  | # pysqlite2/test/hooks.py: tests for various SQLite-specific hooks | |||
|  | # | |||
|  | # Copyright (C) 2006 Gerhard H<>ring <gh@ghaering.de> | |||
|  | # | |||
|  | # This file is part of pysqlite. | |||
|  | # | |||
|  | # This software is provided 'as-is', without any express or implied | |||
|  | # warranty.  In no event will the authors be held liable for any damages | |||
|  | # arising from the use of this software. | |||
|  | # | |||
|  | # Permission is granted to anyone to use this software for any purpose, | |||
|  | # including commercial applications, and to alter it and redistribute it | |||
|  | # freely, subject to the following restrictions: | |||
|  | # | |||
|  | # 1. The origin of this software must not be misrepresented; you must not | |||
|  | #    claim that you wrote the original software. If you use this software | |||
|  | #    in a product, an acknowledgment in the product documentation would be | |||
|  | #    appreciated but is not required. | |||
|  | # 2. Altered source versions must be plainly marked as such, and must not be | |||
|  | #    misrepresented as being the original software. | |||
|  | # 3. This notice may not be removed or altered from any source distribution. | |||
|  | 
 | |||
|  | import os, unittest | |||
|  | import pysqlite2.dbapi2 as sqlite | |||
|  | 
 | |||
|  | class CollationTests(unittest.TestCase): | |||
|  |     def setUp(self): | |||
|  |         pass | |||
|  | 
 | |||
|  |     def tearDown(self): | |||
|  |         pass | |||
|  | 
 | |||
|  |     def CheckCreateCollationNotCallable(self): | |||
|  |         con = sqlite.connect(":memory:") | |||
|  |         try: | |||
|  |             con.create_collation("X", 42) | |||
|  |             self.fail("should have raised a TypeError") | |||
|  |         except TypeError, e: | |||
|  |             self.failUnlessEqual(e.args[0], "parameter must be callable") | |||
|  | 
 | |||
|  |     def CheckCreateCollationNotAscii(self): | |||
|  |         con = sqlite.connect(":memory:") | |||
|  |         try: | |||
|  |             con.create_collation("coll<EFBFBD>", cmp) | |||
|  |             self.fail("should have raised a ProgrammingError") | |||
|  |         except sqlite.ProgrammingError, e: | |||
|  |             pass | |||
|  | 
 | |||
|  |     def CheckCollationIsUsed(self): | |||
|  |         def mycoll(x, y): | |||
|  |             # reverse order | |||
|  |             return -cmp(x, y) | |||
|  | 
 | |||
|  |         con = sqlite.connect(":memory:") | |||
|  |         con.create_collation("mycoll", mycoll) | |||
|  |         sql = """
 | |||
|  |             select x from ( | |||
|  |             select 'a' as x | |||
|  |             union | |||
|  |             select 'b' as x | |||
|  |             union | |||
|  |             select 'c' as x | |||
|  |             ) order by x collate mycoll | |||
|  |             """
 | |||
|  |         result = con.execute(sql).fetchall() | |||
|  |         if result[0][0] != "c" or result[1][0] != "b" or result[2][0] != "a": | |||
|  |             self.fail("the expected order was not returned") | |||
|  | 
 | |||
|  |         con.create_collation("mycoll", None) | |||
|  |         try: | |||
|  |             result = con.execute(sql).fetchall() | |||
|  |             self.fail("should have raised an OperationalError") | |||
|  |         except sqlite.OperationalError, e: | |||
|  |             self.failUnlessEqual(e.args[0], "no such collation sequence: mycoll") | |||
|  | 
 | |||
|  |     def CheckCollationRegisterTwice(self): | |||
|  |         """
 | |||
|  |         Register two different collation functions under the same name. | |||
|  |         Verify that the last one is actually used. | |||
|  |         """
 | |||
|  |         con = sqlite.connect(":memory:") | |||
|  |         con.create_collation("mycoll", cmp) | |||
|  |         con.create_collation("mycoll", lambda x, y: -cmp(x, y)) | |||
|  |         result = con.execute("""
 | |||
|  |             select x from (select 'a' as x union select 'b' as x) order by x collate mycoll | |||
|  |             """).fetchall()
 | |||
|  |         if result[0][0] != 'b' or result[1][0] != 'a': | |||
|  |             self.fail("wrong collation function is used") | |||
|  | 
 | |||
|  |     def CheckDeregisterCollation(self): | |||
|  |         """
 | |||
|  |         Register a collation, then deregister it. Make sure an error is raised if we try | |||
|  |         to use it. | |||
|  |         """
 | |||
|  |         con = sqlite.connect(":memory:") | |||
|  |         con.create_collation("mycoll", cmp) | |||
|  |         con.create_collation("mycoll", None) | |||
|  |         try: | |||
|  |             con.execute("select 'a' as x union select 'b' as x order by x collate mycoll") | |||
|  |             self.fail("should have raised an OperationalError") | |||
|  |         except sqlite.OperationalError, e: | |||
|  |             if not e.args[0].startswith("no such collation sequence"): | |||
|  |                 self.fail("wrong OperationalError raised") | |||
|  | 
 | |||
|  | def suite(): | |||
|  |     collation_suite = unittest.makeSuite(CollationTests, "Check") | |||
|  |     return unittest.TestSuite((collation_suite,)) | |||
|  | 
 | |||
|  | def test(): | |||
|  |     runner = unittest.TextTestRunner() | |||
|  |     runner.run(suite()) | |||
|  | 
 | |||
|  | if __name__ == "__main__": | |||
|  |     test() |