1. 17 Jun, 2021 28 commits
    • Otto Kekäläinen's avatar
      MDEV-20392: Skip ABI check if 'diff' is not found · b7d87bf0
      Otto Kekäläinen authored
      Not all environments have 'diff' installed. Most notably CentOS 8
      does not have diff out-of-the-box. Thus users running 'cmake .' and
      'make' would fail to build MariaDB, and they would think the error
      was in ABI incompatibilities due to the error message emitted by CMake
      when in reality simply 'diff' was missing.
      
      This fixes it and makes the developer experience better by simply skipping
      the diffing if 'diff' is not found.
      
      ## Proof
      
      Running in a clean CentOS 8 container.
      
      ### Before
      
      ```
      $ cmake .
      ...
      -- Looking for cpuid.h
      -- Looking for cpuid.h - found
      -- Looking for x86intrin.h
      -- Looking for x86intrin.h - found
      -- Looking for event.h
      -- Looking for event.h - not found
      -- Configuring done
      -- Generating done
      -- Build files have been written to: /build
      
      $ make
      Scanning dependencies of target abi_check
      CMake Error at cmake/do_abi_check.cmake:82 (MESSAGE):
        ABI check found difference between /build/include/mysql/plugin_audit.h.pp
        and /build/abi_check.out
      
      make[2]: *** [CMakeFiles/abi_check.dir/build.make:57: CMakeFiles/abi_check] Error 1
      make[1]: *** [CMakeFiles/Makefile2:168: CMakeFiles/abi_check.dir/all] Error 2
      make: *** [Makefile:163: all] Error 2
      
      $ yum install -y diffutils
      ...
      Installed:
        diffutils-3.6-6.el8.x86_64
      Complete!
      
      $ make
      [  0%] Built target abi_check
      Scanning dependencies of target INFO_BIN
      [  0%] Built target INFO_BIN
      Scanning dependencies of target INFO_SRC
      [  0%] Built target INFO_SRC
      Scanning dependencies of target wsrep_api_v26
      [  0%] Building C object wsrep-lib/wsrep-API/CMakeFiles/wsrep_api_v26.dir/v26/wsrep_dummy.c.o
      [  0%] Building C object wsrep-lib/wsrep-API/CMakeFiles/wsrep_api_v26.dir/v26/wsrep_gtid.c.o
      [  0%] Building C object wsrep-lib/wsrep-API/CMakeFiles/wsrep_api_v26.dir/v26/wsrep_loader.c.o
      [  0%] Building C object wsrep-lib/wsrep-API/CMakeFiles/wsrep_api_v26.dir/v26/wsrep_uuid.c.o
      [  0%] Linking C static library libwsrep_api_v26.a
      [  0%] Built target wsrep_api_v26
      ```
      
      ### After
      
      ```
      $ make
      Command 'diff' not found. ABI check for /build/server/include/mysql/plugin_audit.h skipped.
      Command 'diff' not found. ABI check for /build/server/include/mysql/plugin_ftparser.h skipped.
      Command 'diff' not found. ABI check for /build/server/include/mysql.h skipped.
      Command 'diff' not found. ABI check for /build/server/include/mysql/psi/psi_abi_v1.h skipped.
      Command 'diff' not found. ABI check for /build/server/include/mysql/psi/psi_abi_v2.h skipped.
      Command 'diff' not found. ABI check for /build/server/include/mysql/client_plugin.h skipped.
      Command 'diff' not found. ABI check for /build/server/include/mysql/plugin_auth.h skipped.
      Command 'diff' not found. ABI check for /build/server/include/mysql/plugin_password_validation.h skipped.
      Command 'diff' not found. ABI check for /build/server/include/mysql/plugin_encryption.h skipped.
      Command 'diff' not found. ABI check for /build/server/include/mysql/plugin_data_type.h skipped.
      Command 'diff' not found. ABI check for /build/server/include/mysql/plugin_function.h skipped.
      [  0%] Built target abi_check
      [  0%] Built target INFO_SRC
      [  0%] Built target INFO_BIN
      [  0%] Built target wsrep_api_v26
      [  0%] Building CXX object wsrep-lib/src/CMakeFiles/wsrep-lib.dir/server_state.cpp.o
      ```
      
      If diff is installed, those warnings are simply not shown. Builds pass
      without the need to install 'diff'.
      b7d87bf0
    • Sergei Golubchik's avatar
      update C/C · 59cf1a8a
      Sergei Golubchik authored
      59cf1a8a
    • Dmitry Shulga's avatar
      MDEV-16708: fixed failure of the test sys_vars.sql_select_limit_func · 44db6ffc
      Dmitry Shulga authored
      This test failed in case it was run in PS mode and for embedded server
      
      The reason of test failure was that the following fields
        affected_row, server_status, insert_id
      of the structure MYSQL_STMT weren't update on calling
      mysql_stmt_next_result() in case combination of binary protocol
      and embedded server used.
      44db6ffc
    • Sergei Golubchik's avatar
      MDEV-16708: correct server side cursor detection in embedded · 3d752f0a
      Sergei Golubchik authored
      fixes a bunch of tests failures in --ps --embed
      
      also, don't use cli_advanced_command().
      3d752f0a
    • Sergei Golubchik's avatar
    • Sergei Golubchik's avatar
      MDEV-16708: spurious ER_NEED_REPREPARE for gtid_slave_pos and event_scheduler · aedf3143
      Sergei Golubchik authored
      do not try to detect metadata change (and reprepare) for
      internal short-lived TABLE_LIST objects that couldn't have
      possibly lived long enough to see prepare and cache the metadata.
      aedf3143
    • Dmitry Shulga's avatar
      MDEV-16708: more fixes to test cases · 510662e8
      Dmitry Shulga authored
      510662e8
    • Dmitry Shulga's avatar
    • Dmitry Shulga's avatar
    • Dmitry Shulga's avatar
      MDEV-16708: fixed incorrect issuing the error · 994e3f40
      Dmitry Shulga authored
       ' Access denied; you need (at least one of) the SUPER privilege(s) for this operation
      on executing SET system_variable=.... in PS mode
      994e3f40
    • Dmitry Shulga's avatar
    • Dmitry Shulga's avatar
    • Dmitry Shulga's avatar
      MDEV-16708: Fixed ths issue with handling of ERR packet received by mysqltest · fc71746a
      Dmitry Shulga authored
      on response to COM_STMT_EXECUTE
      
      The test cases like the following one
        delimiter |;
        CREATE PROCEDURE SP001()
        BEGIN
          DECLARE C1 CURSOR FOR SELECT 1;
      
          OPEN C1;
      
          SELECT 1;
          CLOSE C1;
          CLOSE C1;
        END|
        delimiter ;|
        --error 1326
        call SP001();
      
      are failed since processing of ERR packet was missed by mysqltest
      in case it is run with --ps-protocol
      
      Additionally, the test sp-error was changed to don't run multi-statements
      since they are not supported by PS protocol
      fc71746a
    • Dmitry Shulga's avatar
      MDEV-16708: Unsupported commands for prepared statements · a7209842
      Dmitry Shulga authored
      Added the directive --disable_ps_protocol before running tests
      that checking correct handling of ER_STACK_OVERRUN_NEED_MORE.
      These tests rely on estimation of stack consumption that differ
      in case statements run in regular and in ps mode.
      a7209842
    • Dmitry Shulga's avatar
      MDEV-16708: disabled the test main.sp to be executed with ps-protocol · a3a80420
      Dmitry Shulga authored
      This test has been disable by the reason that it contains multi-statements
      that not supported in PS mode. Unfortunately, some of these multi-statements
      can't be converted to a sequence of single-statements by the reason that
      multi-statementness is a requirement for tests (e.g. tests for
      the MySQL bugs #5307, #8762) therefore the whole test file will be
      skipped in case it is run with --ps-protocol
      a3a80420
    • Dmitry Shulga's avatar
      a00b51f6
    • Dmitry Shulga's avatar
      b33111ba
    • Dmitry Shulga's avatar
      MDEV-16708: Unsupported commands for prepared statements · 129098b7
      Dmitry Shulga authored
      Fixed the bug in handling queries where select list contains subqueries
      with items referencing to items in outer query
      129098b7
    • Dmitry Shulga's avatar
      MDEV-16708: Unsupported commands for prepared statements · 4decc03b
      Dmitry Shulga authored
      Fixed the test main.view
      4decc03b
    • Dmitry Shulga's avatar
      MDEV-25576: The statement EXPLAIN running as regular statement and as prepared... · 5478ca77
      Dmitry Shulga authored
      MDEV-25576: The statement EXPLAIN running as regular statement and as prepared statement produces different results for UPDATE with subquery
      
      10.6 cleanup
      5478ca77
    • Dmitry Shulga's avatar
      MDEV-16708: Unsupported commands for prepared statements · f536974b
      Dmitry Shulga authored
      Fixed failures of the tests main.compound, main.union
      f536974b
    • Dmitry Shulga's avatar
      MDEV-16708: Unsupported commands for prepared statements · 8754fce8
      Dmitry Shulga authored
      Fixed test failures caused by missing output of warnings that
      got on prepare phase
      8754fce8
    • Dmitry Shulga's avatar
      MDEV-16708: Unsupported commands for prepared statements · aeca826c
      Dmitry Shulga authored
      Write a log event to the general log before executing a statemment in PS mode
      This change fixes failure of the test main.log_tables when it is run in PS mode
      
      Updated the test main.events_logs_tests to query mysql.general_log
      for the command_type 'Query' and 'Execute' in order to have consistent
      test result both in case the test is run with --ps-protocol and without it
      aeca826c
    • Dmitry Shulga's avatar
      MDEV-16708: Unsupported commands for prepared statements · 7586eead
      Dmitry Shulga authored
      Disable running of the statements
      PREPARE FROM/EXECUTE/EXECUTE IMMEDIATE/DEALLOCATE
      in PS mode. Adjust tests main.ps, main.ps_1general
      7586eead
    • Dmitry Shulga's avatar
      MDEV-16708: Unsupported commands for prepared statements · 32740229
      Dmitry Shulga authored
      Extended a set of commands that can be executed via binary protocol
      by a user with expired password
      32740229
    • Dmitry Shulga's avatar
      MDEV-16708: Unsupported commands for prepared statements · d5836a62
      Dmitry Shulga authored
      Extended a set of commands that can be executed as prepared statements
      by a user with expired password
      d5836a62
    • Dmitry Shulga's avatar
      MDEV-16708: Unsupported commands for prepared statements · 9370c6e8
      Dmitry Shulga authored
      Withing this task the following changes were made:
      - Added sending of metadata info in prepare phase for the admin related
        command (check table, checksum table, repair, optimize, analyze).
      
      - Refactored implmentation of HELP command to support its execution in
        PS mode
      
      - Added support for execution of LOAD INTO and XA- related statements
        in PS mode
      
      - Modified mysqltest.cc to run statements in PS mode unconditionally
        in case the option --ps-protocol is set. Formerly, only those statements
        were executed using PS protocol that matched the hard-coded regular expression
      
      - Fixed the following issues:
          The statement
            explain select (select 2)
          executed in regular and PS mode produces different results:
      
          MariaDB [test]> prepare stmt from "explain select (select 2)";
          Query OK, 0 rows affected (0,000 sec)
          Statement prepared
          MariaDB [test]> execute stmt;
          +------+-------------+-------+------+---------------+------+---------+------+------+----------------+
          | id   | select_type | table | type | possible_keys | key  | key_len | ref  | rows | Extra          |
          +------+-------------+-------+------+---------------+------+---------+------+------+----------------+
          |    1 | PRIMARY     | NULL  | NULL | NULL          | NULL | NULL    | NULL | NULL | No tables used |
          |    2 | SUBQUERY    | NULL  | NULL | NULL          | NULL | NULL    | NULL | NULL | No tables used |
          +------+-------------+-------+------+---------------+------+---------+------+------+----------------+
          2 rows in set (0,000 sec)
          MariaDB [test]> explain select (select 2);
          +------+-------------+-------+------+---------------+------+---------+------+------+----------------+
          | id   | select_type | table | type | possible_keys | key  | key_len | ref  | rows | Extra          |
          +------+-------------+-------+------+---------------+------+---------+------+------+----------------+
          |    1 | SIMPLE      | NULL  | NULL | NULL          | NULL | NULL    | NULL | NULL | No tables used |
          +------+-------------+-------+------+---------------+------+---------+------+------+----------------+
          1 row in set, 1 warning (0,000 sec)
      
          In case the statement
            CREATE TABLE t1 SELECT * FROM (SELECT 1 AS a, (SELECT a+0)) a
          is run in PS mode it fails with the error
            ERROR 1054 (42S22): Unknown column 'a' in 'field list'.
      
      - Uniform handling of read-only variables both in case the SET var=val
        statement is executed as regular or prepared statememt.
      
      - Fixed assertion firing on handling LOAD DATA statement for temporary tables
      
      - Relaxed assert condition in the function lex_end_stage1() by adding
        the commands SQLCOM_ALTER_EVENT, SQLCOM_CREATE_PACKAGE,
        SQLCOM_CREATE_PACKAGE_BODY to a list of supported command
      
      - Removed raising of the error ER_UNSUPPORTED_PS in the function
        check_prepared_statement() for the ALTER VIEW command
      
      - Added initialization of the data memember st_select_lex_unit::last_procedure
        (assign NULL value) in the constructor
      
        Without this change the test case main.ctype_utf8 fails with the following
        report in case it is run with the optoin --ps-protocol.
          mysqltest: At line 2278: query 'VALUES (_latin1 0xDF) UNION VALUES(_utf8'a' COLLATE utf8_bin)' failed: 2013: Lost connection
      
      - The following bug reports were fixed:
            MDEV-24460: Multiple rows result set returned from stored
                        routine over prepared statement binary protocol is
                        handled incorrectly
            CONC-519: mariadb client library doesn't handle server_status and
                      warnign_count fields received in the packet
                      COM_STMT_EXECUTE_RESPONSE.
      
        Reasons for these bug reports have the same nature and caused by
        missing loop iteration on results sent by server in response to
        COM_STMT_EXECUTE packet.
      
        Enclosing of statements for processing of COM_STMT_EXECUTE response
        in the construct like
          do
          {
            ...
          } while (!mysql_stmt_next_result());
        fixes the above mentioned bug reports.
      9370c6e8
    • Marko Mäkelä's avatar
      MDEV-25854: Remove garbage tables after restoring a backup · f778a5d5
      Marko Mäkelä authored
      In commit 1c5ae991 (MDEV-25666)
      we had changed Mariabackup so that it would no longer skip files
      whose names start with #sql. This turned out to be wrong.
      Because operations on such named files are not protected by any
      locks in the server, it is not safe to copy them.
      
      Not copying the files may make the InnoDB data dictionary
      inconsistent with the file system. So, we must do something
      in InnoDB to adjust for that.
      
      If InnoDB is being started up without the redo log (ib_logfile0)
      or with a zero-length log file, we will assume that the server
      was restored from a backup, and adjust things as follows:
      
      dict_check_sys_tables(), fil_ibd_open(): Do not complain about
      missing #sql files if they would be dropped a little later.
      
      dict_stats_update_if_needed(): Never add #sql tables to
      the recomputing queue. This avoids a potential race condition when
      dropping the garbage tables.
      
      drop_garbage_tables_after_restore(): Try to drop any garbage tables.
      
      innodb_ddl_recovery_done(): Invoke drop_garbage_tables_after_restore()
      if srv_start_after_restore (a new flag) was set and we are not in
      read-only mode (innodb_read_only=ON or innodb_force_recovery>3).
      
      The tests and dbug_mariabackup_event() instrumentation
      were developed by Vladislav Vaintroub, who also reviewed this.
      f778a5d5
  2. 16 Jun, 2021 3 commits
    • Andrei Elkin's avatar
      MDEV-21117 post-push to cover a "custom" xid format · e95f78f4
      Andrei Elkin authored
      Due to wsrep uses its own xid format for its recovery,
      the xid hashing has to be refined.
      When a xid object is not in the server "mysql" format,
      the hash record made to contain the xid also in the full format.
      e95f78f4
    • Marko Mäkelä's avatar
      MDEV-25936 Crash during DDL that involves FULLTEXT INDEX · da65cb4d
      Marko Mäkelä authored
      In commit 1bd681c8 we introduced
      a work-around for the missing MDL protection when the internal
      tables of FULLTEXT INDEX are dropped during DDL operations.
      That work-around suffered from a race condition. A purge thread
      could have narrowly passed purge_sys.check_stop_FTS() and then
      (while holding dict_sys.mutex) acquire a table reference right
      after fts_lock_table() determined that no references were being
      held.
      
      fts_lock_table(): Protect the reference check with dict_sys.mutex.
      
      Thanks to Thirunarayanan Balathandayuthapani for repeating the
      failure and testing the fix.
      da65cb4d
    • Marko Mäkelä's avatar
      MDEV-25910: Aim to make all InnoDB DDL durable · 71964c76
      Marko Mäkelä authored
      Before any committed DDL operation returns control to the caller,
      we must ensure that it will have been durably committed before the
      ddl_log state may be changed, no matter if
      innodb_flush_log_at_trx_commit=0 is being used.
      
      Operations that would involve deleting files were already safe,
      because the durable write of the FILE_DELETE record that would precede
      the file deletion would also have made the commit durable.
      
      Furthermore, when we clean up ADD INDEX stubs that were left behind
      by a previous ha_innobase::commit_inplace_alter_table(commit=false)
      when MDL could not be acquired, we will use the same interface as
      for dropping indexes. This safety measure should be dead code,
      because ADD FULLTEXT INDEX is not supported online, and dropping indexes
      only involves file deletion for FULLTEXT INDEX.
      71964c76
  3. 15 Jun, 2021 3 commits
    • Marko Mäkelä's avatar
      MDEV-25910: Make ALTER TABLE...ALGORITHM=COPY durable again · e5b9dc15
      Marko Mäkelä authored
      ha_innobase::extra(HA_EXTRA_END_ALTER_COPY): Flush the redo log
      because the main transaction will not have written any log and
      thus will not initiate any log write either. But the DDL recovery
      layer expects that the operation will have been committed.
      e5b9dc15
    • Sergei Golubchik's avatar
      update C/C to 3.2.2-rc · e0647dc7
      Sergei Golubchik authored
      e0647dc7
    • Andrei Elkin's avatar
      MDEV-21117 post-push fixes · 79a2dbc8
      Andrei Elkin authored
      1. work around MDEV-25912 to not apply assert
         at wsrep running time;
      2. handle wsrep mode of the server recovery
      3. convert hton calls to static binlog_commit ones.
      4. satisfy MSAN complain on uninitialized std::pair
      79a2dbc8
  4. 14 Jun, 2021 6 commits