mirror of
https://github.com/postgres/postgres.git
synced 2025-04-21 12:05:57 +03:00
This removes md5() function calls from these test suites: - bloom - test_decoding - isolation - recovery - subscription This covers all remaining test suites where md5() calls were just used to generate some random data and can be replaced by appropriately adapted sha256() calls. This will eventually allow these tests to pass in OpenSSL FIPS mode (which does not allow MD5 use). See also 208bf364a9. Unlike for the main regression tests, I didn't write a fipshash() wrapper here, because that would have been too repetitive and wouldn't really save much here. In some cases it was easier to remove one layer of indirection by changing column types from text to bytea. Reviewed-by: Daniel Gustafsson <daniel@yesql.se> Discussion: https://www.postgresql.org/message-id/flat/f9b480b5-e473-d2d1-223a-4b9db30a229a@eisentraut.org
44 lines
1.8 KiB
Ruby
44 lines
1.8 KiB
Ruby
# Test decoding of in-progress transaction containing dml and a concurrent
|
|
# transaction with ddl operation. The transaction containing ddl operation
|
|
# should not get streamed as it doesn't have any changes.
|
|
|
|
setup
|
|
{
|
|
SELECT 'init' FROM pg_create_logical_replication_slot('isolation_slot', 'test_decoding');
|
|
|
|
-- consume DDL
|
|
SELECT data FROM pg_logical_slot_get_changes('isolation_slot', NULL, NULL, 'include-xids', '0', 'skip-empty-xacts', '1');
|
|
CREATE OR REPLACE FUNCTION large_val() RETURNS bytea LANGUAGE SQL AS $$ select string_agg(sha256(g::text::bytea), '') from generate_series(1, 83000) g $$;
|
|
}
|
|
|
|
teardown
|
|
{
|
|
DROP TABLE IF EXISTS stream_test;
|
|
DROP TABLE IF EXISTS stream_test1;
|
|
SELECT 'stop' FROM pg_drop_replication_slot('isolation_slot');
|
|
}
|
|
|
|
session "s0"
|
|
setup { SET synchronous_commit=on; }
|
|
step "s0_begin" { BEGIN; }
|
|
step "s0_ddl" {CREATE TABLE stream_test1(data bytea);}
|
|
|
|
session "s2"
|
|
setup { SET synchronous_commit=on; }
|
|
step "s2_ddl" {CREATE TABLE stream_test2(data bytea);}
|
|
|
|
# The transaction commit for s1_ddl will add the INTERNAL_SNAPSHOT change to
|
|
# the currently running s0_ddl and we want to test that s0_ddl should not get
|
|
# streamed when user asked to skip-empty-xacts. Similarly, the
|
|
# INTERNAL_SNAPSHOT change added by s2_ddl should not change the results for
|
|
# what gets streamed.
|
|
session "s1"
|
|
setup { SET synchronous_commit=on; }
|
|
step "s1_ddl" { CREATE TABLE stream_test(data bytea); }
|
|
step "s1_begin" { BEGIN; }
|
|
step "s1_toast_insert" {INSERT INTO stream_test SELECT large_val();}
|
|
step "s1_commit" { COMMIT; }
|
|
step "s1_get_stream_changes" { SELECT data FROM pg_logical_slot_get_changes('isolation_slot', NULL,NULL, 'include-xids', '0', 'skip-empty-xacts', '1', 'stream-changes', '1');}
|
|
|
|
permutation "s0_begin" "s0_ddl" "s1_ddl" "s1_begin" "s1_toast_insert" "s2_ddl" "s1_commit" "s1_get_stream_changes"
|