mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-31 15:50:51 +03:00 
			
		
		
		
	Bug#37167 funcs_1: Many tests fail if the embedded server is used.
   Bug#37164 funcs_1: Some tests fail if an optional character set is missing.
+ some cleanup within the testsuite related to the fixes above
+ some adjustments to open bugs on Mac OS X
Details:
- Remove the initial loading of data from tests if these data
  are not somewhere retrieved
- Remove any use of columns with attribute unicode
  (-> UCS2 is no more needed) from tests where unicode
  properties are not checked or somehow required
- Create a separate branch of the Character maximum length test
  (CML). If UCS2 is available than this test gets applied to
  every available type of string column with attribute unicode
  This prevents any loss of coverage by the points above.
- Disable the execution of is_tables_ndb which gives wrong
  results because of a bug. Correct the exepected results of
  this test.
- In case of tests failing when applied to the embedded server
    1) Create a variant of this test for the embedded server
  or
    2) Skip the test in case of embedded server
  depending on purpose and complexity of test.
- Skip the tests which could suffer from
  Bug 28309 First insert violates unique constraint - was "memory" table empty ?
  Bug 37380 Test funcs_1.is_columns_myisam_embedded fails on OS X
  (both bugs Mac OS X, embedded server, MySQL 5.0 only)
- Minor improvements like remove typos
		
	
		
			
				
	
	
		
			56 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| # suite/funcs_1/datadict/tables.inc
 | |
| #
 | |
| # Auxiliary script to be sourced by
 | |
| #    is_tables_<engine>.test
 | |
| #
 | |
| # The variable $engine_type has to be assigned before sourcing ths script.
 | |
| #
 | |
| # Author:
 | |
| # 2008-06-04 mleich Create this script based on older scripts and new code.
 | |
| #
 | |
| 
 | |
| # Just have some tables within different databases.
 | |
| --disable_warnings
 | |
| DROP DATABASE IF EXISTS test1;
 | |
| DROP DATABASE IF EXISTS test2;
 | |
| --enable_warnings
 | |
| CREATE DATABASE test1;
 | |
| CREATE DATABASE test2;
 | |
| 
 | |
| --replace_result $engine_type <engine_to_be_used>
 | |
| eval CREATE TABLE test1.t1  (f1 VARCHAR(20)) ENGINE = $engine_type;
 | |
| --replace_result $engine_type <engine_to_be_used>
 | |
| eval CREATE TABLE test1.t2  (f1 VARCHAR(20)) ENGINE = $engine_type;
 | |
| --replace_result $engine_type <engine_to_be_used>
 | |
| eval CREATE TABLE test2.t1 (f1 VARCHAR(20)) ENGINE = $engine_type;
 | |
| 
 | |
| --source suite/funcs_1/datadict/tables2.inc
 | |
| SHOW TABLES FROM test1;
 | |
| SHOW TABLES FROM test2;
 | |
| 
 | |
| # Create a low privileged user.
 | |
| # Note: The database db_datadict is just a "home" for the low privileged user
 | |
| #       and not in the focus of testing.
 | |
| --error 0,ER_CANNOT_USER
 | |
| DROP   USER testuser1@localhost;
 | |
| CREATE USER testuser1@localhost;
 | |
| GRANT SELECT ON test1.* TO testuser1@localhost;
 | |
| 
 | |
| --echo # Establish connection testuser1 (user=testuser1)
 | |
| --replace_result $MASTER_MYPORT MYSQL_PORT $MASTER_MYSOCK MYSQL_SOCK
 | |
| connect (testuser1,localhost,testuser1,,test1);
 | |
| --source suite/funcs_1/datadict/tables2.inc
 | |
| SHOW TABLES FROM test1;
 | |
| # The lowprivileged user testuser1 will get here an error.
 | |
| --disable_abort_on_error
 | |
| SHOW TABLES FROM test2;
 | |
| --enable_abort_on_error
 | |
| 
 | |
| --echo # Switch to connection default and close connection testuser1
 | |
| connection default;
 | |
| disconnect testuser1;
 | |
| DROP USER testuser1@localhost;
 | |
| 
 | |
| DROP DATABASE test1;
 | |
| DROP DATABASE test2;
 |