mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-24 07:13:33 +03:00 
			
		
		
		
	allow select into outfile from I_S tables
  it is enough to add FILE_ACL for I_S tables only to 'check_table_access' function
  as we use 'any_db' for 'check_access' function in places where FILE_ACL is required
mysql-test/t/outfile.test:
  Fix for bug#13202 SELECT * INTO OUTFILE ... FROM information_schema.schemata now fails
    test case
		
	
		
			
				
	
	
		
			86 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			86 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| disable_query_log;
 | |
| -- source include/test_outfile.inc
 | |
| eval set @tmpdir="$MYSQL_TEST_DIR/var/tmp";
 | |
| enable_query_log;
 | |
| -- source include/have_outfile.inc
 | |
| 
 | |
| #
 | |
| # test of into outfile|dumpfile
 | |
| #
 | |
| 
 | |
| --disable_warnings
 | |
| drop table if exists t1;
 | |
| --enable_warnings
 | |
| 
 | |
| create table t1 (`a` blob);
 | |
| insert into t1 values("hello world"),("Hello mars"),(NULL);
 | |
| disable_query_log;
 | |
| eval select * into outfile "$MYSQL_TEST_DIR/var/tmp/outfile-test.1" from t1;
 | |
| enable_query_log;
 | |
| select load_file(concat(@tmpdir,"/outfile-test.1"));
 | |
| disable_query_log;
 | |
| eval select * into dumpfile "$MYSQL_TEST_DIR/var/tmp/outfile-test.2" from t1 limit 1;
 | |
| enable_query_log;
 | |
| select load_file(concat(@tmpdir,"/outfile-test.2"));
 | |
| disable_query_log;
 | |
| eval select * into dumpfile "$MYSQL_TEST_DIR/var/tmp/outfile-test.3" from t1 where a is null;
 | |
| enable_query_log;
 | |
| select load_file(concat(@tmpdir,"/outfile-test.3"));
 | |
| 
 | |
| # the following should give errors
 | |
| 
 | |
| #disabled as error message has variable path
 | |
| #disable_query_log;
 | |
| #--error 1086
 | |
| #eval select * into outfile "$MYSQL_TEST_DIR/var/tmp/outfile-test.1" from t1;
 | |
| #--error 1086
 | |
| #eval select * into dumpfile "$MYSQL_TEST_DIR/var/tmp/outfile-test.2" from t1;
 | |
| #--error 1086
 | |
| #eval select * into dumpfile "$MYSQL_TEST_DIR/var/tmp/outfile-test.3" from t1;
 | |
| #enable_query_log;
 | |
| --error 13,2
 | |
| select load_file(concat(@tmpdir,"/outfile-test.not-exist"));
 | |
| --exec rm $MYSQL_TEST_DIR/var/tmp/outfile-test.1
 | |
| --exec rm $MYSQL_TEST_DIR/var/tmp/outfile-test.2
 | |
| --exec rm $MYSQL_TEST_DIR/var/tmp/outfile-test.3
 | |
| drop table t1;
 | |
| 
 | |
| # Bug#8191
 | |
| disable_query_log;
 | |
| eval select 1 into outfile "$MYSQL_TEST_DIR/var/tmp/outfile-test.4";
 | |
| enable_query_log;
 | |
| select load_file(concat(@tmpdir,"/outfile-test.4"));
 | |
| --exec rm $MYSQL_TEST_DIR/var/tmp/outfile-test.4
 | |
| 
 | |
| #
 | |
| # Bug #5382: 'explain select into outfile' crashes the server
 | |
| #
 | |
| 
 | |
| CREATE TABLE t1 (a INT);
 | |
| EXPLAIN 
 | |
|   SELECT *
 | |
|   INTO OUTFILE '/tmp/t1.txt'
 | |
|   FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"' LINES TERMINATED BY '\r\n'
 | |
|   FROM t1;
 | |
| DROP TABLE t1;
 | |
| 
 | |
| # End of 4.1 tests
 | |
| 
 | |
| #
 | |
| # Bug#13202  SELECT * INTO OUTFILE ... FROM information_schema.schemata now fails
 | |
| #
 | |
| disable_query_log;
 | |
| eval SELECT * INTO OUTFILE "$MYSQL_TEST_DIR/var/tmp/outfile-test.4"
 | |
| FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"'
 | |
| FROM information_schema.schemata LIMIT 0, 5;
 | |
| # enable_query_log;
 | |
| --exec rm $MYSQL_TEST_DIR/var/tmp/outfile-test.4
 | |
| 
 | |
| use information_schema;
 | |
| # disable_query_log;
 | |
| eval SELECT * INTO OUTFILE "$MYSQL_TEST_DIR/var/tmp/outfile-test.4"
 | |
| FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"'
 | |
| FROM schemata LIMIT 0, 5;
 | |
| enable_query_log;
 | |
| --exec rm $MYSQL_TEST_DIR/var/tmp/outfile-test.4
 |