mirror of
				https://github.com/postgres/postgres.git
				synced 2025-11-03 09:13:20 +03:00 
			
		
		
		
	Attempting to use this function with a raw page not coming from a GiST
index would cause a crash, as it was missing the same sanity checks as
gist_page_items_bytea().  This slightly refactors the code so as all the
basic validation checks for GiST pages are done in a single routine,
in the same fashion as the pageinspect functions for hash and BRIN.
This fixes an issue similar to 076f4d9.  A test is added to stress for
this case.  While on it, I have added a similar test for
brin_page_items() with a combination make of a valid GiST index and a
raw btree page.  This one was already protected, but it was not tested.
Reported-by: Egor Chindyaskin
Author: Dmitry Koval
Discussion: https://postgr.es/m/17815-fc4a2d3b74705703@postgresql.org
Backpatch-through: 14
		
	
		
			
				
	
	
		
			40 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			SQL
		
	
	
	
	
	
			
		
		
	
	
			40 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			SQL
		
	
	
	
	
	
CREATE TABLE test1 (a int, b text);
 | 
						|
INSERT INTO test1 VALUES (1, 'one');
 | 
						|
CREATE INDEX test1_a_idx ON test1 USING brin (a);
 | 
						|
 | 
						|
SELECT brin_page_type(get_raw_page('test1_a_idx', 0));
 | 
						|
SELECT brin_page_type(get_raw_page('test1_a_idx', 1));
 | 
						|
SELECT brin_page_type(get_raw_page('test1_a_idx', 2));
 | 
						|
 | 
						|
SELECT * FROM brin_metapage_info(get_raw_page('test1_a_idx', 0));
 | 
						|
SELECT * FROM brin_metapage_info(get_raw_page('test1_a_idx', 1));
 | 
						|
 | 
						|
SELECT * FROM brin_revmap_data(get_raw_page('test1_a_idx', 0)) LIMIT 5;
 | 
						|
SELECT * FROM brin_revmap_data(get_raw_page('test1_a_idx', 1)) LIMIT 5;
 | 
						|
 | 
						|
SELECT * FROM brin_page_items(get_raw_page('test1_a_idx', 2), 'test1_a_idx')
 | 
						|
    ORDER BY blknum, attnum LIMIT 5;
 | 
						|
 | 
						|
-- Mask DETAIL messages as these are not portable across architectures.
 | 
						|
\set VERBOSITY terse
 | 
						|
 | 
						|
-- Failures for non-BRIN index.
 | 
						|
CREATE INDEX test1_a_btree ON test1 (a);
 | 
						|
SELECT brin_page_items(get_raw_page('test1_a_btree', 0), 'test1_a_btree');
 | 
						|
SELECT brin_page_items(get_raw_page('test1_a_btree', 0), 'test1_a_idx');
 | 
						|
 | 
						|
-- Invalid special area size
 | 
						|
SELECT brin_page_type(get_raw_page('test1', 0));
 | 
						|
SELECT * FROM brin_metapage_info(get_raw_page('test1', 0));
 | 
						|
SELECT * FROM brin_revmap_data(get_raw_page('test1', 0));
 | 
						|
\set VERBOSITY default
 | 
						|
 | 
						|
-- Tests with all-zero pages.
 | 
						|
SHOW block_size \gset
 | 
						|
SELECT brin_page_type(decode(repeat('00', :block_size), 'hex'));
 | 
						|
SELECT brin_page_items(decode(repeat('00', :block_size), 'hex'), 'test1_a_idx');
 | 
						|
SELECT brin_metapage_info(decode(repeat('00', :block_size), 'hex'));
 | 
						|
SELECT brin_revmap_data(decode(repeat('00', :block_size), 'hex'));
 | 
						|
 | 
						|
DROP TABLE test1;
 |