mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-24 01:29:19 +03:00 
			
		
		
		
	Fix handling of pgbench's hash when no argument is provided
Depending on the platform used, this can cause a crash in the worst case, or an unhelpful error message, so fail gracefully. Author: Fabien Coelho Discussion: https://postgr.es/m/alpine.DEB.2.21.1807262302550.29874@lancre Backpatch: 11-, where hash() has been added in pgbench.
This commit is contained in:
		| @@ -467,7 +467,7 @@ make_func(yyscan_t yyscanner, int fnumber, PgBenchExprList *args) | ||||
|  | ||||
| 		/* hash functions with optional seed argument */ | ||||
| 		case PGBENCH_NARGS_HASH: | ||||
| 			if (len > 2) | ||||
| 			if (len < 1 || len > 2) | ||||
| 				expr_yyerror_more(yyscanner, "unexpected number of arguments", | ||||
| 								  PGBENCH_FUNCTIONS[fnumber].fname); | ||||
|  | ||||
|   | ||||
| @@ -270,6 +270,26 @@ my @script_tests = ( | ||||
| 		'endif syntax error', | ||||
| 		[qr{unexpected argument in command "endif"}], | ||||
| 		{ 'endif-bad.sql' => "\\if 0\n\\endif BAD\n" } | ||||
| 	], | ||||
| 	[ | ||||
| 		'not enough arguments for least', | ||||
| 		[qr{at least one argument expected \(least\)}], | ||||
| 		{ 'bad-least.sql' => "\\set i least()\n" } | ||||
| 	], | ||||
| 	[ | ||||
| 		'not enough arguments for greatest', | ||||
| 		[qr{at least one argument expected \(greatest\)}], | ||||
| 		{ 'bad-greatest.sql' => "\\set i greatest()\n" } | ||||
| 	], | ||||
| 	[ | ||||
| 		'not enough arguments for hash', | ||||
| 		[qr{unexpected number of arguments \(hash\)}], | ||||
| 		{ 'bad-hash-1.sql' => "\\set i hash()\n" } | ||||
| 	], | ||||
| 	[ | ||||
| 		'too many arguments for hash', | ||||
| 		[qr{unexpected number of arguments \(hash\)}], | ||||
| 		{ 'bad-hash-2.sql' => "\\set i hash(1,2,3)\n" } | ||||
| 	],); | ||||
|  | ||||
| for my $t (@script_tests) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user