mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-25 18:38:00 +03:00 
			
		
		
		
	This imports and adapts a number of MySQL 5.7 test cases that are applicable to MariaDB. Some tests for old bug fixes are not that relevant because the code has been refactored since then (especially starting with MariaDB Server 10.6), and the tests would not reproduce the original bug if the fix was reverted. In the test innodb_fts.opt, there are many duplicate MATCH ranks, which would make the results nondeterministic. The test was stabilized by changing some LIMIT clauses or by adding sorted_result in those cases where the purpose of a test was to show that no sorting took place in the server. In the test innodb_fts.phrase, MySQL 5.7 would generate FTS_DOC_ID that are 1 larger than in MariaDB. In innodb_fts.index_table the difference is 2. This is because in MariaDB, fts_get_next_doc_id() post-increments cache->next_doc_id, while MySQL 5.7 pre-increments it. Reviewed by: Thirunarayanan Balathandayuthapani
		
			
				
	
	
		
			46 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			46 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| # This is to test create GIS index with algorithm=inplace.
 | |
| 
 | |
| --source include/have_innodb.inc
 | |
| --source include/have_debug.inc
 | |
| --source include/have_sequence.inc
 | |
| --source include/no_valgrind_without_big.inc
 | |
| 
 | |
| # Create table with geometry column
 | |
| CREATE TABLE t1 (c1 INT, c2 GEOMETRY NOT NULL, c3 GEOMETRY NOT NULL) ENGINE=INNODB;
 | |
| CREATE TEMPORARY TABLE t LIKE t1;
 | |
| 
 | |
| # Insert enough values
 | |
| INSERT INTO t VALUES
 | |
| (1, Point(1,1), ST_GeomFromText('POLYGON (( 0 -1, 0  1, 2  1, 2 -1, 0 -1))')),
 | |
| (2, Point(2,2), ST_GeomFromText('POLYGON (( 0 -3, 0 -1, 2 -1, 2 -3, 0 -3))')),
 | |
| (3, Point(3,3), ST_GeomFromText('POLYGON (( 1 0, 1 2, 3 2, 3 0, 1 0))')),
 | |
| (4, Point(4,4), ST_GeomFromText('POLYGON (( -3 0, -3 2, -1 2, -1 0, -3 0))')),
 | |
| (5, Point(5,5), ST_GeomFromText('POLYGON (( 0 0, 0 1, 1 1, 1 0, 0 0))')),
 | |
| (6, Point(6,6), ST_GeomFromText('POLYGON (( 2 0, 2 2, 4 2, 4 0, 2 0))')),
 | |
| (7, Point(7,7), ST_GeomFromText('POLYGON (( 0 3, 0 5, 2 5, 2 3, 0 3))')),
 | |
| (8, Point(8,8), ST_GeomFromText('POLYGON (( 0 1, 0 3, 2 3, 2 1, 0 1))')),
 | |
| (9, Point(9,9), ST_GeomFromText('POLYGON (( 0 0, 0 3, 3 3, 3 0, 0 0))'));
 | |
| 
 | |
| INSERT INTO t1 SELECT t.* FROM t, seq_1_to_512;
 | |
| DROP TEMPORARY TABLE t;
 | |
| 
 | |
| # create spatial index
 | |
| CREATE SPATIAL INDEX idx ON t1(c2);
 | |
| 
 | |
| SELECT COUNT(*) FROM t1;
 | |
| 
 | |
| SET @g1 = ST_GeomFromText('Polygon((0 0,0 100,100 100,100 0,0 0))');
 | |
| SELECT COUNT(*) FROM t1 WHERE MBRWithin(t1.c2, @g1);
 | |
| 
 | |
| SET @g1 = ST_GeomFromText('Polygon((10 10,10 800,800 800,800 10,10 10))');
 | |
| SELECT COUNT(*) FROM t1 WHERE MBRWithin(t1.c2, @g1);
 | |
| 
 | |
| ALTER TABLE t1 DROP INDEX idx, ADD SPATIAL INDEX idx3(c2);
 | |
| 
 | |
| SET debug_dbug='+d,row_merge_instrument_log_check_flush';
 | |
| ALTER TABLE t1  DROP INDEX idx3, ADD SPATIAL INDEX idx4(c2), ADD SPATIAL INDEX idx5(c3);
 | |
| ALTER TABLE t1 FORCE;
 | |
| 
 | |
| # Clean up.
 | |
| DROP TABLE t1;
 |