mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-31 15:50:51 +03:00 
			
		
		
		
	On startup, if the InnoDB doublewrite buffer can be used to recover a corrupted page, raising an ERROR about a recoverable error seems inappropriate. Issue Note instead, and adjust tests accordingly. Also, correctly validate the tablespace ID in the files.
		
			
				
	
	
		
			80 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			80 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| --source include/innodb_page_size.inc
 | |
| --source include/not_embedded.inc
 | |
| 
 | |
| let datadir= `select @@datadir`;
 | |
| let page_size= `select @@innodb_page_size`;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-15333 MariaDB (still) slow start
 | |
| --echo #
 | |
| 
 | |
| # Ensure that on normal startup, no data files are read.
 | |
| # Note: just like in MySQL, all .ibd files will still be
 | |
| # opened at least once.
 | |
| 
 | |
| --echo # FIXME: Unlike MySQL, maybe MariaDB should not read the .ibd files
 | |
| --echo # of tables with .isl file or DATA DIRECTORY attribute.
 | |
| call mtr.add_suppression("\\[ERROR\\] InnoDB: Invalid flags 0x7a207879 in .*td\\.ibd");
 | |
| --echo # FIXME: This is much more noisy than MariaDB 10.1!
 | |
| call mtr.add_suppression("\\[ERROR\\] InnoDB: Operating system error number .* in a file operation\\.");
 | |
| call mtr.add_suppression("\\[ERROR\\] InnoDB: The error means the system cannot find the path specified\\.");
 | |
| call mtr.add_suppression("\\[ERROR\\] InnoDB: If you are installing InnoDB, remember that you must create directories yourself, InnoDB does not create them\\.");
 | |
| call mtr.add_suppression("\\[Warning\\] InnoDB: Ignoring tablespace for `test`\\.`td` because it could not be opened\\.");
 | |
| 
 | |
| CREATE TABLE tr(a INT)ENGINE=InnoDB ROW_FORMAT=REDUNDANT;
 | |
| CREATE TABLE tc(a INT)ENGINE=InnoDB ROW_FORMAT=COMPACT
 | |
| PAGE_COMPRESSED=1 PAGE_COMPRESSION_LEVEL=9;
 | |
| --replace_result $MYSQL_TMP_DIR MYSQL_TMP_DIR
 | |
| eval CREATE TABLE td(a INT)ENGINE=InnoDB ROW_FORMAT=DYNAMIC
 | |
| STATS_PERSISTENT=0 DATA DIRECTORY='$MYSQL_TMP_DIR';
 | |
| 
 | |
| --source include/shutdown_mysqld.inc
 | |
| 
 | |
| --move_file $datadir/test/tr.ibd $datadir/test/tr0.ibd
 | |
| --move_file $datadir/test/tc.ibd $datadir/test/tc0.ibd
 | |
| --move_file $MYSQL_TMP_DIR/test/td.ibd $datadir/test/td0.ibd
 | |
| # TODO: test that MariaDB does not even attempt to open the files
 | |
| #--mkdir $datadir/test/tr.ibd
 | |
| #--mkdir $datadir/test/tc.ibd
 | |
| #--mkdir $MYSQL_TMP_DIR/test/td.ibd
 | |
| 
 | |
| perl;
 | |
| die unless open OUT, ">", "$ENV{datadir}/test/tr.ibd";
 | |
| print OUT "foo " x $ENV{page_size};
 | |
| close OUT or die;
 | |
| die unless open OUT, ">", "$ENV{datadir}/test/tc.ibd";
 | |
| print OUT "bar " x $ENV{page_size};
 | |
| close OUT or die;
 | |
| die unless open OUT, ">", "$ENV{MYSQL_TMP_DIR}/test/td.ibd";
 | |
| print OUT "xyz " x $ENV{page_size};
 | |
| close OUT or die;
 | |
| EOF
 | |
| 
 | |
| --let $restart_parameters= --skip-innodb-buffer-pool-load-at-startup
 | |
| --source include/start_mysqld.inc
 | |
| --let $restart_parameters=
 | |
| 
 | |
| SELECT COUNT(*) FROM INFORMATION_SCHEMA.ENGINES
 | |
| WHERE engine = 'innodb'
 | |
| AND support IN ('YES', 'DEFAULT', 'ENABLED');
 | |
| 
 | |
| --source include/shutdown_mysqld.inc
 | |
| 
 | |
| # TODO: test that MariaDB does not even attempt to open the files
 | |
| #--rmdir $datadir/test/tr.ibd
 | |
| #--rmdir $datadir/test/tc.ibd
 | |
| #--rmdir $MYSQL_TMP_DIR/test/td.ibd
 | |
| --remove_file $datadir/test/tr.ibd
 | |
| --remove_file $datadir/test/tc.ibd
 | |
| --remove_file $MYSQL_TMP_DIR/test/td.ibd
 | |
| 
 | |
| --move_file $datadir/test/tr0.ibd $datadir/test/tr.ibd
 | |
| --move_file $datadir/test/tc0.ibd $datadir/test/tc.ibd
 | |
| --move_file $datadir/test/td0.ibd $MYSQL_TMP_DIR/test/td.ibd
 | |
| 
 | |
| --source include/start_mysqld.inc
 | |
| SELECT * FROM tr;
 | |
| SELECT * FROM tc;
 | |
| SELECT * FROM td;
 | |
| DROP TABLE tr,tc,td;
 |