mariadb/mysql-test/suite/innodb/t/compression_providers_unloaded.test
Kartik Soneji bf8b699f64 MDEV-12933 sort out the compression library chaos
bzip2/lz4/lzma/lzo/snappy compression is now provided via *services*

they're almost like normal services, but in include/providers/
and they're supposed to provide exactly the same interface
as original compression libraries (but not everything,
only enough of if for the code to compile).

the services are implemented via dummy functions that return
corresponding error values (LZMA_PROG_ERROR, LZO_E_INTERNAL_ERROR, etc).

the actual compression libraries are linked into corresponding
provider plugins. Providers are daemon plugins that when loaded
replace service pointers to point to actual compression functions.

That is, run-time dependency on compression libraries is now on plugins,
and the server doesn't need any compression libraries to run, but
will automatically support the compression when a plugin is loaded.

InnoDB and Mroonga use compression plugins now. RocksDB doesn't,
because it comes with standalone utility binaries that cannot
load plugins.
2021-10-27 15:55:14 +02:00

13 lines
395 B
Text

let $alg = $MTR_COMBINATIONS;
--echo #
--echo # Testing unloaded compression provider: $alg
--echo #
--echo # Innodb_have_$alg reflects that the provider is not loaded
eval SHOW GLOBAL STATUS WHERE Variable_name = "Innodb_have_$alg";
--echo # Innodb_compression_algorithm cannot be set to $alg
error ER_WRONG_VALUE_FOR_VAR;
eval SET GLOBAL Innodb_compression_algorithm = $alg;
show warnings;