mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-24 00:03:18 -04:00 
			
		
		
		
	pg_dump only selected components of ACCESS METHODs
dumpAccessMethod() didn't get the memo that we now have a bitfield for the components which should be dumped instead of a simple boolean. Correct that by checking if the relevant bit is set for each component being dumped out (and not dumping it out if it isn't set). This corrects an issue where CREATE ACCESS METHOD commands were being included in non-binary-upgrades when an extension included an access method (as the bloom extensions does). Also add a regression test to make sure that we only dump out the ACCESS METHOD commands, when they are part of an extension, when doing a binary upgrade. Pointed out by Thom Brown.
This commit is contained in:
		
							parent
							
								
									8359077124
								
							
						
					
					
						commit
						562f06f3f0
					
				| @ -12472,20 +12472,22 @@ dumpAccessMethod(Archive *fout, AccessMethodInfo *aminfo) | |||||||
| 	appendPQExpBuffer(labelq, "ACCESS METHOD %s", | 	appendPQExpBuffer(labelq, "ACCESS METHOD %s", | ||||||
| 					  qamname); | 					  qamname); | ||||||
| 
 | 
 | ||||||
| 	ArchiveEntry(fout, aminfo->dobj.catId, aminfo->dobj.dumpId, | 	if (aminfo->dobj.dump & DUMP_COMPONENT_DEFINITION) | ||||||
| 				 aminfo->dobj.name, | 		ArchiveEntry(fout, aminfo->dobj.catId, aminfo->dobj.dumpId, | ||||||
| 				 NULL, | 					 aminfo->dobj.name, | ||||||
| 				 NULL, | 					 NULL, | ||||||
| 				 "", | 					 NULL, | ||||||
| 				 false, "ACCESS METHOD", SECTION_PRE_DATA, | 					 "", | ||||||
| 				 q->data, delq->data, NULL, | 					 false, "ACCESS METHOD", SECTION_PRE_DATA, | ||||||
| 				 NULL, 0, | 					 q->data, delq->data, NULL, | ||||||
| 				 NULL, NULL); | 					 NULL, 0, | ||||||
|  | 					 NULL, NULL); | ||||||
| 
 | 
 | ||||||
| 	/* Dump Access Method Comments */ | 	/* Dump Access Method Comments */ | ||||||
| 	dumpComment(fout, labelq->data, | 	if (aminfo->dobj.dump & DUMP_COMPONENT_COMMENT) | ||||||
| 				NULL, "", | 		dumpComment(fout, labelq->data, | ||||||
| 				aminfo->dobj.catId, 0, aminfo->dobj.dumpId); | 					NULL, "", | ||||||
|  | 					aminfo->dobj.catId, 0, aminfo->dobj.dumpId); | ||||||
| 
 | 
 | ||||||
| 	pg_free(qamname); | 	pg_free(qamname); | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -317,6 +317,26 @@ my %tests = ( | |||||||
| 			section_post_data => 1, | 			section_post_data => 1, | ||||||
| 		}, | 		}, | ||||||
| 	}, | 	}, | ||||||
|  | 	'CREATE ACCESS METHOD regress_test_am' => { | ||||||
|  | 		regexp => qr/^ | ||||||
|  | 			\QCREATE ACCESS METHOD regress_test_am TYPE INDEX HANDLER bthandler;\E | ||||||
|  | 			$/xm, | ||||||
|  | 		like => { | ||||||
|  | 			binary_upgrade => 1, | ||||||
|  | 		}, | ||||||
|  | 		unlike => { | ||||||
|  | 			clean => 1, | ||||||
|  | 			clean_if_exists => 1, | ||||||
|  | 			createdb => 1, | ||||||
|  | 			defaults => 1, | ||||||
|  | 			no_privs => 1, | ||||||
|  | 			no_owner => 1, | ||||||
|  | 			pg_dumpall_globals => 1, | ||||||
|  | 			schema_only => 1, | ||||||
|  | 			section_pre_data => 1, | ||||||
|  | 			section_post_data => 1, | ||||||
|  | 		}, | ||||||
|  | 	}, | ||||||
| 	'COMMENT ON EXTENSION test_pg_dump' => { | 	'COMMENT ON EXTENSION test_pg_dump' => { | ||||||
| 		regexp => qr/^ | 		regexp => qr/^ | ||||||
| 			\QCOMMENT ON EXTENSION test_pg_dump \E | 			\QCOMMENT ON EXTENSION test_pg_dump \E | ||||||
|  | |||||||
| @ -13,3 +13,5 @@ GRANT SELECT(col1) ON regress_pg_dump_table TO public; | |||||||
| 
 | 
 | ||||||
| GRANT SELECT(col2) ON regress_pg_dump_table TO dump_test; | GRANT SELECT(col2) ON regress_pg_dump_table TO dump_test; | ||||||
| REVOKE SELECT(col2) ON regress_pg_dump_table FROM dump_test; | REVOKE SELECT(col2) ON regress_pg_dump_table FROM dump_test; | ||||||
|  | 
 | ||||||
|  | CREATE ACCESS METHOD regress_test_am TYPE INDEX HANDLER bthandler; | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user