polardbxengine/mysql-test/include/compare_digests.inc

69 lines
2.3 KiB
SQL

# This include file checks that the function statement_digest() and
# performance_schema produce the same digests.
#
# - $compare_digests_fn is the function called.
#
# - $compare_digests_query - is what the function is called with.
#
# - $compare_digests_pfs_query is executed and its digest picked up from
# performance_schema.
#
# - $compare_digests_pfs_column is the column that is compared with the result
# of the function.
#
# Only single quotes may be used in the queries.
--disable_query_log
SELECT enabled INTO @original_setting
FROM performance_schema.setup_consumers
WHERE NAME = 'statements_digest';
UPDATE performance_schema.setup_consumers
SET enabled = 'NO'
WHERE NAME = 'statements_digest';
# We inactivate statement digests in performance_schema before calling
# statement_digest(), as the function should work anyway.
eval SET @the_digest =
$compare_digests_fn( "$compare_digests_query" );
--enable_query_log
--disable_query_log
UPDATE performance_schema.setup_consumers
SET enabled = 'YES'
WHERE NAME = 'statements_digest';
eval SET @ps_protocol = $PS_PROTOCOL;
--enable_query_log
--eval $compare_digests_pfs_query
# We do the conversion to 'utf8' (in fact UTF-8 mb3) here for the few cases
# when the SQL text is UTF-8 mb4. For all other cases, this conversion
# doesn't change anything as long as we use UTF-8.
#
# We're doing a little trick if the test runs under --ps-protocol. In this
# case the digests won't match up, obviously, since the queries aren't parsed
# normally and hence aren't in performance_schema. In this case we just answer
# 'YES'. Even if we don't get any useful result, it is still necessary to run
# the tests to check for assertions.
eval
SELECT digest_text, IF( @the_digest = $compare_digests_pfs_column, 'YES', 'NO' )
AS digest_is_correct
FROM performance_schema.events_statements_history
WHERE sql_text = convert( "$compare_digests_pfs_query" USING utf8 )
UNION
SELECT statement_digest_text( "$compare_digests_pfs_query" ), 'YES'
FROM (SELECT 1) a1 JOIN (SELECT @ps_protocol) a2;
--disable_query_log
UPDATE performance_schema.setup_consumers
SET enabled = @original_setting
WHERE NAME = 'statements_digest';
--enable_query_log
--let $compare_digests_fn=
--let $compare_digests_query=
--let $compare_digests_pfs_query=
--let $compare_digests_pfs_column=