mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-25 18:38:00 +03:00 
			
		
		
		
	Analysis: ======== When "Profiling" is enabled, server collects the resource usage of each statement that gets executed in current session. Profiling doesn't support nested statements. In order to ensure this behavior when profiling is enabled for a statement, there should not be any other active query which is being profiled. This active query information is stored in 'current' variable. When a nested query arrives it finds 'current' being not NULL and server aborts. When 'init_connect' and 'init_slave' system variables are set they contain a set of statements to be executed. "execute_init_command" is the function call which invokes "dispatch_command" for each statement provided in 'init_connect', 'init_slave' system variables. "execute_init_command" invokes "start_new_query" and it passes the statement list to "dispatch_command". This "dispatch_command" intern invokes "start_new_query" which leads to nesting of queries. Hence '!current' assert is triggered. Fix: === Remove profiling from "execute_init_command" as it will be done within "dispatch_command" execution.
		
			
				
	
	
		
			43 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			43 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| # ==== Purpose ====
 | |
| #
 | |
| # Test verifies that "init_connect" and "init_slave" system variables work
 | |
| # fine when "profiling=on".
 | |
| #
 | |
| # ==== Implementation ====
 | |
| #
 | |
| # Steps:
 | |
| #    0 - Create regular user without super privilege so that "init_connect"
 | |
| #        variable is effective.
 | |
| #    1 - Enable profiling.
 | |
| #    2 - Start a new connection which will try to execute the statements
 | |
| #        specified in "init_connect". No assert should be reported.
 | |
| #    3 - Execute SHOW PROFILES to verify that statements specified in
 | |
| #        "init_connect" are displayed as part of profiling.
 | |
| #
 | |
| # ==== References ====
 | |
| #
 | |
| # MDEV-22706: Assertion `!current' failed in PROFILING::start_new_query
 | |
| #
 | |
| --source include/not_embedded.inc
 | |
| --source include/have_profiling.inc
 | |
| 
 | |
| SET @saved_profiling=@@GLOBAL.profiling;
 | |
| SET @saved_init_connect=@@GLOBAL.init_connect;
 | |
| SET GLOBAL init_connect="set @a=2;set @b=3";
 | |
| SET GLOBAL profiling=on;
 | |
| 
 | |
| create user mysqltest1@localhost;
 | |
| connect (con1,localhost,mysqltest1,,);
 | |
| connection con1;
 | |
| SELECT @a, @b;
 | |
| --replace_column 2 #
 | |
| SHOW PROFILES;
 | |
| 
 | |
| #========== Clean up ===========
 | |
| connection default;
 | |
| disconnect con1;
 | |
| DROP USER mysqltest1@localhost;
 | |
| 
 | |
| SET GLOBAL profiling=@saved_profiling;
 | |
| SET GLOBAL init_connect=@saved_init_connect;
 |