From 5eebb8d954adf9d600b1a157682539db1e8a3ada Mon Sep 17 00:00:00 2001 From: Andres Freund Date: Tue, 3 Jun 2014 12:19:18 +0200 Subject: [PATCH] Use unaligned output in another regression test query to reduce diff noise. Use the unaligned/no rowcount output mode in a regression tests that shows all built-in leakproof functions. Currently a new leakproof function will often change the alignment of all existing functions, making it hard to see the actual difference and creating unnecessary patch conflicts. Noticed while looking over a patch introducing new leakproof functions. --- .../regress/expected/create_function_3.out | 466 +++++++++--------- src/test/regress/sql/create_function_3.sql | 9 + 2 files changed, 243 insertions(+), 232 deletions(-) diff --git a/src/test/regress/expected/create_function_3.out b/src/test/regress/expected/create_function_3.out index 486ae7adf7..a4b2d99c95 100644 --- a/src/test/regress/expected/create_function_3.out +++ b/src/test/regress/expected/create_function_3.out @@ -149,242 +149,244 @@ CREATE FUNCTION functext_E_3(int) RETURNS bool LANGUAGE 'sql' LEAKPROOF AS 'SELECT $1 < 200'; -- failed ERROR: only superuser can define a leakproof function RESET SESSION AUTHORIZATION; +--- -- list of built-in leakproof functions +--- +-- temporarily disable fancy output, so catalog changes create less diff noise +\a\t SELECT proname, prorettype::regtype, proargtypes::regtype[] FROM pg_proc JOIN pg_namespace ON pronamespace = pg_namespace.oid WHERE nspname = 'pg_catalog' AND proleakproof ORDER BY proname; - proname | prorettype | proargtypes -----------------+------------+--------------------------------------------------------------------- - abstimeeq | boolean | [0:1]={abstime,abstime} - abstimege | boolean | [0:1]={abstime,abstime} - abstimegt | boolean | [0:1]={abstime,abstime} - abstimele | boolean | [0:1]={abstime,abstime} - abstimelt | boolean | [0:1]={abstime,abstime} - abstimene | boolean | [0:1]={abstime,abstime} - biteq | boolean | [0:1]={bit,bit} - bitge | boolean | [0:1]={bit,bit} - bitgt | boolean | [0:1]={bit,bit} - bitle | boolean | [0:1]={bit,bit} - bitlt | boolean | [0:1]={bit,bit} - bitne | boolean | [0:1]={bit,bit} - booleq | boolean | [0:1]={boolean,boolean} - boolge | boolean | [0:1]={boolean,boolean} - boolgt | boolean | [0:1]={boolean,boolean} - boolle | boolean | [0:1]={boolean,boolean} - boollt | boolean | [0:1]={boolean,boolean} - boolne | boolean | [0:1]={boolean,boolean} - bpchareq | boolean | [0:1]={character,character} - bpcharne | boolean | [0:1]={character,character} - byteaeq | boolean | [0:1]={bytea,bytea} - byteage | boolean | [0:1]={bytea,bytea} - byteagt | boolean | [0:1]={bytea,bytea} - byteale | boolean | [0:1]={bytea,bytea} - bytealt | boolean | [0:1]={bytea,bytea} - byteane | boolean | [0:1]={bytea,bytea} - cash_eq | boolean | [0:1]={money,money} - cash_ge | boolean | [0:1]={money,money} - cash_gt | boolean | [0:1]={money,money} - cash_le | boolean | [0:1]={money,money} - cash_lt | boolean | [0:1]={money,money} - cash_ne | boolean | [0:1]={money,money} - chareq | boolean | [0:1]={"\"char\"","\"char\""} - charge | boolean | [0:1]={"\"char\"","\"char\""} - chargt | boolean | [0:1]={"\"char\"","\"char\""} - charle | boolean | [0:1]={"\"char\"","\"char\""} - charlt | boolean | [0:1]={"\"char\"","\"char\""} - charne | boolean | [0:1]={"\"char\"","\"char\""} - cideq | boolean | [0:1]={cid,cid} - circle_eq | boolean | [0:1]={circle,circle} - circle_ge | boolean | [0:1]={circle,circle} - circle_gt | boolean | [0:1]={circle,circle} - circle_le | boolean | [0:1]={circle,circle} - circle_lt | boolean | [0:1]={circle,circle} - circle_ne | boolean | [0:1]={circle,circle} - date_eq | boolean | [0:1]={date,date} - date_ge | boolean | [0:1]={date,date} - date_gt | boolean | [0:1]={date,date} - date_le | boolean | [0:1]={date,date} - date_lt | boolean | [0:1]={date,date} - date_ne | boolean | [0:1]={date,date} - float48eq | boolean | [0:1]={real,"double precision"} - float48ge | boolean | [0:1]={real,"double precision"} - float48gt | boolean | [0:1]={real,"double precision"} - float48le | boolean | [0:1]={real,"double precision"} - float48lt | boolean | [0:1]={real,"double precision"} - float48ne | boolean | [0:1]={real,"double precision"} - float4eq | boolean | [0:1]={real,real} - float4ge | boolean | [0:1]={real,real} - float4gt | boolean | [0:1]={real,real} - float4le | boolean | [0:1]={real,real} - float4lt | boolean | [0:1]={real,real} - float4ne | boolean | [0:1]={real,real} - float84eq | boolean | [0:1]={"double precision",real} - float84ge | boolean | [0:1]={"double precision",real} - float84gt | boolean | [0:1]={"double precision",real} - float84le | boolean | [0:1]={"double precision",real} - float84lt | boolean | [0:1]={"double precision",real} - float84ne | boolean | [0:1]={"double precision",real} - float8eq | boolean | [0:1]={"double precision","double precision"} - float8ge | boolean | [0:1]={"double precision","double precision"} - float8gt | boolean | [0:1]={"double precision","double precision"} - float8le | boolean | [0:1]={"double precision","double precision"} - float8lt | boolean | [0:1]={"double precision","double precision"} - float8ne | boolean | [0:1]={"double precision","double precision"} - int24eq | boolean | [0:1]={smallint,integer} - int24ge | boolean | [0:1]={smallint,integer} - int24gt | boolean | [0:1]={smallint,integer} - int24le | boolean | [0:1]={smallint,integer} - int24lt | boolean | [0:1]={smallint,integer} - int24ne | boolean | [0:1]={smallint,integer} - int28eq | boolean | [0:1]={smallint,bigint} - int28ge | boolean | [0:1]={smallint,bigint} - int28gt | boolean | [0:1]={smallint,bigint} - int28le | boolean | [0:1]={smallint,bigint} - int28lt | boolean | [0:1]={smallint,bigint} - int28ne | boolean | [0:1]={smallint,bigint} - int2eq | boolean | [0:1]={smallint,smallint} - int2ge | boolean | [0:1]={smallint,smallint} - int2gt | boolean | [0:1]={smallint,smallint} - int2le | boolean | [0:1]={smallint,smallint} - int2lt | boolean | [0:1]={smallint,smallint} - int2ne | boolean | [0:1]={smallint,smallint} - int42eq | boolean | [0:1]={integer,smallint} - int42ge | boolean | [0:1]={integer,smallint} - int42gt | boolean | [0:1]={integer,smallint} - int42le | boolean | [0:1]={integer,smallint} - int42lt | boolean | [0:1]={integer,smallint} - int42ne | boolean | [0:1]={integer,smallint} - int48eq | boolean | [0:1]={integer,bigint} - int48ge | boolean | [0:1]={integer,bigint} - int48gt | boolean | [0:1]={integer,bigint} - int48le | boolean | [0:1]={integer,bigint} - int48lt | boolean | [0:1]={integer,bigint} - int48ne | boolean | [0:1]={integer,bigint} - int4eq | boolean | [0:1]={integer,integer} - int4ge | boolean | [0:1]={integer,integer} - int4gt | boolean | [0:1]={integer,integer} - int4le | boolean | [0:1]={integer,integer} - int4lt | boolean | [0:1]={integer,integer} - int4ne | boolean | [0:1]={integer,integer} - int82eq | boolean | [0:1]={bigint,smallint} - int82ge | boolean | [0:1]={bigint,smallint} - int82gt | boolean | [0:1]={bigint,smallint} - int82le | boolean | [0:1]={bigint,smallint} - int82lt | boolean | [0:1]={bigint,smallint} - int82ne | boolean | [0:1]={bigint,smallint} - int84eq | boolean | [0:1]={bigint,integer} - int84ge | boolean | [0:1]={bigint,integer} - int84gt | boolean | [0:1]={bigint,integer} - int84le | boolean | [0:1]={bigint,integer} - int84lt | boolean | [0:1]={bigint,integer} - int84ne | boolean | [0:1]={bigint,integer} - int8eq | boolean | [0:1]={bigint,bigint} - int8ge | boolean | [0:1]={bigint,bigint} - int8gt | boolean | [0:1]={bigint,bigint} - int8le | boolean | [0:1]={bigint,bigint} - int8lt | boolean | [0:1]={bigint,bigint} - int8ne | boolean | [0:1]={bigint,bigint} - interval_eq | boolean | [0:1]={interval,interval} - interval_ge | boolean | [0:1]={interval,interval} - interval_gt | boolean | [0:1]={interval,interval} - interval_le | boolean | [0:1]={interval,interval} - interval_lt | boolean | [0:1]={interval,interval} - interval_ne | boolean | [0:1]={interval,interval} - lseg_eq | boolean | [0:1]={lseg,lseg} - lseg_ge | boolean | [0:1]={lseg,lseg} - lseg_gt | boolean | [0:1]={lseg,lseg} - lseg_le | boolean | [0:1]={lseg,lseg} - lseg_lt | boolean | [0:1]={lseg,lseg} - lseg_ne | boolean | [0:1]={lseg,lseg} - macaddr_eq | boolean | [0:1]={macaddr,macaddr} - macaddr_ge | boolean | [0:1]={macaddr,macaddr} - macaddr_gt | boolean | [0:1]={macaddr,macaddr} - macaddr_le | boolean | [0:1]={macaddr,macaddr} - macaddr_lt | boolean | [0:1]={macaddr,macaddr} - macaddr_ne | boolean | [0:1]={macaddr,macaddr} - nameeq | boolean | [0:1]={name,name} - namege | boolean | [0:1]={name,name} - namegt | boolean | [0:1]={name,name} - namele | boolean | [0:1]={name,name} - namelt | boolean | [0:1]={name,name} - namene | boolean | [0:1]={name,name} - network_eq | boolean | [0:1]={inet,inet} - network_ge | boolean | [0:1]={inet,inet} - network_gt | boolean | [0:1]={inet,inet} - network_le | boolean | [0:1]={inet,inet} - network_lt | boolean | [0:1]={inet,inet} - network_ne | boolean | [0:1]={inet,inet} - oideq | boolean | [0:1]={oid,oid} - oidge | boolean | [0:1]={oid,oid} - oidgt | boolean | [0:1]={oid,oid} - oidle | boolean | [0:1]={oid,oid} - oidlt | boolean | [0:1]={oid,oid} - oidne | boolean | [0:1]={oid,oid} - reltimeeq | boolean | [0:1]={reltime,reltime} - reltimege | boolean | [0:1]={reltime,reltime} - reltimegt | boolean | [0:1]={reltime,reltime} - reltimele | boolean | [0:1]={reltime,reltime} - reltimelt | boolean | [0:1]={reltime,reltime} - reltimene | boolean | [0:1]={reltime,reltime} - texteq | boolean | [0:1]={text,text} - textne | boolean | [0:1]={text,text} - tideq | boolean | [0:1]={tid,tid} - tidge | boolean | [0:1]={tid,tid} - tidgt | boolean | [0:1]={tid,tid} - tidle | boolean | [0:1]={tid,tid} - tidlt | boolean | [0:1]={tid,tid} - tidne | boolean | [0:1]={tid,tid} - time_eq | boolean | [0:1]={"time without time zone","time without time zone"} - time_ge | boolean | [0:1]={"time without time zone","time without time zone"} - time_gt | boolean | [0:1]={"time without time zone","time without time zone"} - time_le | boolean | [0:1]={"time without time zone","time without time zone"} - time_lt | boolean | [0:1]={"time without time zone","time without time zone"} - time_ne | boolean | [0:1]={"time without time zone","time without time zone"} - timestamp_eq | boolean | [0:1]={"timestamp without time zone","timestamp without time zone"} - timestamp_ge | boolean | [0:1]={"timestamp without time zone","timestamp without time zone"} - timestamp_gt | boolean | [0:1]={"timestamp without time zone","timestamp without time zone"} - timestamp_le | boolean | [0:1]={"timestamp without time zone","timestamp without time zone"} - timestamp_lt | boolean | [0:1]={"timestamp without time zone","timestamp without time zone"} - timestamp_ne | boolean | [0:1]={"timestamp without time zone","timestamp without time zone"} - timestamptz_eq | boolean | [0:1]={"timestamp with time zone","timestamp with time zone"} - timestamptz_ge | boolean | [0:1]={"timestamp with time zone","timestamp with time zone"} - timestamptz_gt | boolean | [0:1]={"timestamp with time zone","timestamp with time zone"} - timestamptz_le | boolean | [0:1]={"timestamp with time zone","timestamp with time zone"} - timestamptz_lt | boolean | [0:1]={"timestamp with time zone","timestamp with time zone"} - timestamptz_ne | boolean | [0:1]={"timestamp with time zone","timestamp with time zone"} - timetz_eq | boolean | [0:1]={"time with time zone","time with time zone"} - timetz_ge | boolean | [0:1]={"time with time zone","time with time zone"} - timetz_gt | boolean | [0:1]={"time with time zone","time with time zone"} - timetz_le | boolean | [0:1]={"time with time zone","time with time zone"} - timetz_lt | boolean | [0:1]={"time with time zone","time with time zone"} - timetz_ne | boolean | [0:1]={"time with time zone","time with time zone"} - tintervaleq | boolean | [0:1]={tinterval,tinterval} - tintervalge | boolean | [0:1]={tinterval,tinterval} - tintervalgt | boolean | [0:1]={tinterval,tinterval} - tintervalle | boolean | [0:1]={tinterval,tinterval} - tintervalleneq | boolean | [0:1]={tinterval,reltime} - tintervallenge | boolean | [0:1]={tinterval,reltime} - tintervallengt | boolean | [0:1]={tinterval,reltime} - tintervallenle | boolean | [0:1]={tinterval,reltime} - tintervallenlt | boolean | [0:1]={tinterval,reltime} - tintervallenne | boolean | [0:1]={tinterval,reltime} - tintervallt | boolean | [0:1]={tinterval,tinterval} - tintervalne | boolean | [0:1]={tinterval,tinterval} - uuid_eq | boolean | [0:1]={uuid,uuid} - uuid_ge | boolean | [0:1]={uuid,uuid} - uuid_gt | boolean | [0:1]={uuid,uuid} - uuid_le | boolean | [0:1]={uuid,uuid} - uuid_lt | boolean | [0:1]={uuid,uuid} - uuid_ne | boolean | [0:1]={uuid,uuid} - varbiteq | boolean | [0:1]={"bit varying","bit varying"} - varbitge | boolean | [0:1]={"bit varying","bit varying"} - varbitgt | boolean | [0:1]={"bit varying","bit varying"} - varbitle | boolean | [0:1]={"bit varying","bit varying"} - varbitlt | boolean | [0:1]={"bit varying","bit varying"} - varbitne | boolean | [0:1]={"bit varying","bit varying"} - xideq | boolean | [0:1]={xid,xid} -(228 rows) - +abstimeeq|boolean|[0:1]={abstime,abstime} +abstimege|boolean|[0:1]={abstime,abstime} +abstimegt|boolean|[0:1]={abstime,abstime} +abstimele|boolean|[0:1]={abstime,abstime} +abstimelt|boolean|[0:1]={abstime,abstime} +abstimene|boolean|[0:1]={abstime,abstime} +biteq|boolean|[0:1]={bit,bit} +bitge|boolean|[0:1]={bit,bit} +bitgt|boolean|[0:1]={bit,bit} +bitle|boolean|[0:1]={bit,bit} +bitlt|boolean|[0:1]={bit,bit} +bitne|boolean|[0:1]={bit,bit} +booleq|boolean|[0:1]={boolean,boolean} +boolge|boolean|[0:1]={boolean,boolean} +boolgt|boolean|[0:1]={boolean,boolean} +boolle|boolean|[0:1]={boolean,boolean} +boollt|boolean|[0:1]={boolean,boolean} +boolne|boolean|[0:1]={boolean,boolean} +bpchareq|boolean|[0:1]={character,character} +bpcharne|boolean|[0:1]={character,character} +byteaeq|boolean|[0:1]={bytea,bytea} +byteage|boolean|[0:1]={bytea,bytea} +byteagt|boolean|[0:1]={bytea,bytea} +byteale|boolean|[0:1]={bytea,bytea} +bytealt|boolean|[0:1]={bytea,bytea} +byteane|boolean|[0:1]={bytea,bytea} +cash_eq|boolean|[0:1]={money,money} +cash_ge|boolean|[0:1]={money,money} +cash_gt|boolean|[0:1]={money,money} +cash_le|boolean|[0:1]={money,money} +cash_lt|boolean|[0:1]={money,money} +cash_ne|boolean|[0:1]={money,money} +chareq|boolean|[0:1]={"\"char\"","\"char\""} +charge|boolean|[0:1]={"\"char\"","\"char\""} +chargt|boolean|[0:1]={"\"char\"","\"char\""} +charle|boolean|[0:1]={"\"char\"","\"char\""} +charlt|boolean|[0:1]={"\"char\"","\"char\""} +charne|boolean|[0:1]={"\"char\"","\"char\""} +cideq|boolean|[0:1]={cid,cid} +circle_eq|boolean|[0:1]={circle,circle} +circle_ge|boolean|[0:1]={circle,circle} +circle_gt|boolean|[0:1]={circle,circle} +circle_le|boolean|[0:1]={circle,circle} +circle_lt|boolean|[0:1]={circle,circle} +circle_ne|boolean|[0:1]={circle,circle} +date_eq|boolean|[0:1]={date,date} +date_ge|boolean|[0:1]={date,date} +date_gt|boolean|[0:1]={date,date} +date_le|boolean|[0:1]={date,date} +date_lt|boolean|[0:1]={date,date} +date_ne|boolean|[0:1]={date,date} +float48eq|boolean|[0:1]={real,"double precision"} +float48ge|boolean|[0:1]={real,"double precision"} +float48gt|boolean|[0:1]={real,"double precision"} +float48le|boolean|[0:1]={real,"double precision"} +float48lt|boolean|[0:1]={real,"double precision"} +float48ne|boolean|[0:1]={real,"double precision"} +float4eq|boolean|[0:1]={real,real} +float4ge|boolean|[0:1]={real,real} +float4gt|boolean|[0:1]={real,real} +float4le|boolean|[0:1]={real,real} +float4lt|boolean|[0:1]={real,real} +float4ne|boolean|[0:1]={real,real} +float84eq|boolean|[0:1]={"double precision",real} +float84ge|boolean|[0:1]={"double precision",real} +float84gt|boolean|[0:1]={"double precision",real} +float84le|boolean|[0:1]={"double precision",real} +float84lt|boolean|[0:1]={"double precision",real} +float84ne|boolean|[0:1]={"double precision",real} +float8eq|boolean|[0:1]={"double precision","double precision"} +float8ge|boolean|[0:1]={"double precision","double precision"} +float8gt|boolean|[0:1]={"double precision","double precision"} +float8le|boolean|[0:1]={"double precision","double precision"} +float8lt|boolean|[0:1]={"double precision","double precision"} +float8ne|boolean|[0:1]={"double precision","double precision"} +int24eq|boolean|[0:1]={smallint,integer} +int24ge|boolean|[0:1]={smallint,integer} +int24gt|boolean|[0:1]={smallint,integer} +int24le|boolean|[0:1]={smallint,integer} +int24lt|boolean|[0:1]={smallint,integer} +int24ne|boolean|[0:1]={smallint,integer} +int28eq|boolean|[0:1]={smallint,bigint} +int28ge|boolean|[0:1]={smallint,bigint} +int28gt|boolean|[0:1]={smallint,bigint} +int28le|boolean|[0:1]={smallint,bigint} +int28lt|boolean|[0:1]={smallint,bigint} +int28ne|boolean|[0:1]={smallint,bigint} +int2eq|boolean|[0:1]={smallint,smallint} +int2ge|boolean|[0:1]={smallint,smallint} +int2gt|boolean|[0:1]={smallint,smallint} +int2le|boolean|[0:1]={smallint,smallint} +int2lt|boolean|[0:1]={smallint,smallint} +int2ne|boolean|[0:1]={smallint,smallint} +int42eq|boolean|[0:1]={integer,smallint} +int42ge|boolean|[0:1]={integer,smallint} +int42gt|boolean|[0:1]={integer,smallint} +int42le|boolean|[0:1]={integer,smallint} +int42lt|boolean|[0:1]={integer,smallint} +int42ne|boolean|[0:1]={integer,smallint} +int48eq|boolean|[0:1]={integer,bigint} +int48ge|boolean|[0:1]={integer,bigint} +int48gt|boolean|[0:1]={integer,bigint} +int48le|boolean|[0:1]={integer,bigint} +int48lt|boolean|[0:1]={integer,bigint} +int48ne|boolean|[0:1]={integer,bigint} +int4eq|boolean|[0:1]={integer,integer} +int4ge|boolean|[0:1]={integer,integer} +int4gt|boolean|[0:1]={integer,integer} +int4le|boolean|[0:1]={integer,integer} +int4lt|boolean|[0:1]={integer,integer} +int4ne|boolean|[0:1]={integer,integer} +int82eq|boolean|[0:1]={bigint,smallint} +int82ge|boolean|[0:1]={bigint,smallint} +int82gt|boolean|[0:1]={bigint,smallint} +int82le|boolean|[0:1]={bigint,smallint} +int82lt|boolean|[0:1]={bigint,smallint} +int82ne|boolean|[0:1]={bigint,smallint} +int84eq|boolean|[0:1]={bigint,integer} +int84ge|boolean|[0:1]={bigint,integer} +int84gt|boolean|[0:1]={bigint,integer} +int84le|boolean|[0:1]={bigint,integer} +int84lt|boolean|[0:1]={bigint,integer} +int84ne|boolean|[0:1]={bigint,integer} +int8eq|boolean|[0:1]={bigint,bigint} +int8ge|boolean|[0:1]={bigint,bigint} +int8gt|boolean|[0:1]={bigint,bigint} +int8le|boolean|[0:1]={bigint,bigint} +int8lt|boolean|[0:1]={bigint,bigint} +int8ne|boolean|[0:1]={bigint,bigint} +interval_eq|boolean|[0:1]={interval,interval} +interval_ge|boolean|[0:1]={interval,interval} +interval_gt|boolean|[0:1]={interval,interval} +interval_le|boolean|[0:1]={interval,interval} +interval_lt|boolean|[0:1]={interval,interval} +interval_ne|boolean|[0:1]={interval,interval} +lseg_eq|boolean|[0:1]={lseg,lseg} +lseg_ge|boolean|[0:1]={lseg,lseg} +lseg_gt|boolean|[0:1]={lseg,lseg} +lseg_le|boolean|[0:1]={lseg,lseg} +lseg_lt|boolean|[0:1]={lseg,lseg} +lseg_ne|boolean|[0:1]={lseg,lseg} +macaddr_eq|boolean|[0:1]={macaddr,macaddr} +macaddr_ge|boolean|[0:1]={macaddr,macaddr} +macaddr_gt|boolean|[0:1]={macaddr,macaddr} +macaddr_le|boolean|[0:1]={macaddr,macaddr} +macaddr_lt|boolean|[0:1]={macaddr,macaddr} +macaddr_ne|boolean|[0:1]={macaddr,macaddr} +nameeq|boolean|[0:1]={name,name} +namege|boolean|[0:1]={name,name} +namegt|boolean|[0:1]={name,name} +namele|boolean|[0:1]={name,name} +namelt|boolean|[0:1]={name,name} +namene|boolean|[0:1]={name,name} +network_eq|boolean|[0:1]={inet,inet} +network_ge|boolean|[0:1]={inet,inet} +network_gt|boolean|[0:1]={inet,inet} +network_le|boolean|[0:1]={inet,inet} +network_lt|boolean|[0:1]={inet,inet} +network_ne|boolean|[0:1]={inet,inet} +oideq|boolean|[0:1]={oid,oid} +oidge|boolean|[0:1]={oid,oid} +oidgt|boolean|[0:1]={oid,oid} +oidle|boolean|[0:1]={oid,oid} +oidlt|boolean|[0:1]={oid,oid} +oidne|boolean|[0:1]={oid,oid} +reltimeeq|boolean|[0:1]={reltime,reltime} +reltimege|boolean|[0:1]={reltime,reltime} +reltimegt|boolean|[0:1]={reltime,reltime} +reltimele|boolean|[0:1]={reltime,reltime} +reltimelt|boolean|[0:1]={reltime,reltime} +reltimene|boolean|[0:1]={reltime,reltime} +texteq|boolean|[0:1]={text,text} +textne|boolean|[0:1]={text,text} +tideq|boolean|[0:1]={tid,tid} +tidge|boolean|[0:1]={tid,tid} +tidgt|boolean|[0:1]={tid,tid} +tidle|boolean|[0:1]={tid,tid} +tidlt|boolean|[0:1]={tid,tid} +tidne|boolean|[0:1]={tid,tid} +time_eq|boolean|[0:1]={"time without time zone","time without time zone"} +time_ge|boolean|[0:1]={"time without time zone","time without time zone"} +time_gt|boolean|[0:1]={"time without time zone","time without time zone"} +time_le|boolean|[0:1]={"time without time zone","time without time zone"} +time_lt|boolean|[0:1]={"time without time zone","time without time zone"} +time_ne|boolean|[0:1]={"time without time zone","time without time zone"} +timestamp_eq|boolean|[0:1]={"timestamp without time zone","timestamp without time zone"} +timestamp_ge|boolean|[0:1]={"timestamp without time zone","timestamp without time zone"} +timestamp_gt|boolean|[0:1]={"timestamp without time zone","timestamp without time zone"} +timestamp_le|boolean|[0:1]={"timestamp without time zone","timestamp without time zone"} +timestamp_lt|boolean|[0:1]={"timestamp without time zone","timestamp without time zone"} +timestamp_ne|boolean|[0:1]={"timestamp without time zone","timestamp without time zone"} +timestamptz_eq|boolean|[0:1]={"timestamp with time zone","timestamp with time zone"} +timestamptz_ge|boolean|[0:1]={"timestamp with time zone","timestamp with time zone"} +timestamptz_gt|boolean|[0:1]={"timestamp with time zone","timestamp with time zone"} +timestamptz_le|boolean|[0:1]={"timestamp with time zone","timestamp with time zone"} +timestamptz_lt|boolean|[0:1]={"timestamp with time zone","timestamp with time zone"} +timestamptz_ne|boolean|[0:1]={"timestamp with time zone","timestamp with time zone"} +timetz_eq|boolean|[0:1]={"time with time zone","time with time zone"} +timetz_ge|boolean|[0:1]={"time with time zone","time with time zone"} +timetz_gt|boolean|[0:1]={"time with time zone","time with time zone"} +timetz_le|boolean|[0:1]={"time with time zone","time with time zone"} +timetz_lt|boolean|[0:1]={"time with time zone","time with time zone"} +timetz_ne|boolean|[0:1]={"time with time zone","time with time zone"} +tintervaleq|boolean|[0:1]={tinterval,tinterval} +tintervalge|boolean|[0:1]={tinterval,tinterval} +tintervalgt|boolean|[0:1]={tinterval,tinterval} +tintervalle|boolean|[0:1]={tinterval,tinterval} +tintervalleneq|boolean|[0:1]={tinterval,reltime} +tintervallenge|boolean|[0:1]={tinterval,reltime} +tintervallengt|boolean|[0:1]={tinterval,reltime} +tintervallenle|boolean|[0:1]={tinterval,reltime} +tintervallenlt|boolean|[0:1]={tinterval,reltime} +tintervallenne|boolean|[0:1]={tinterval,reltime} +tintervallt|boolean|[0:1]={tinterval,tinterval} +tintervalne|boolean|[0:1]={tinterval,tinterval} +uuid_eq|boolean|[0:1]={uuid,uuid} +uuid_ge|boolean|[0:1]={uuid,uuid} +uuid_gt|boolean|[0:1]={uuid,uuid} +uuid_le|boolean|[0:1]={uuid,uuid} +uuid_lt|boolean|[0:1]={uuid,uuid} +uuid_ne|boolean|[0:1]={uuid,uuid} +varbiteq|boolean|[0:1]={"bit varying","bit varying"} +varbitge|boolean|[0:1]={"bit varying","bit varying"} +varbitgt|boolean|[0:1]={"bit varying","bit varying"} +varbitle|boolean|[0:1]={"bit varying","bit varying"} +varbitlt|boolean|[0:1]={"bit varying","bit varying"} +varbitne|boolean|[0:1]={"bit varying","bit varying"} +xideq|boolean|[0:1]={xid,xid} +-- restore normal output mode +\a\t -- -- CALLED ON NULL INPUT | RETURNS NULL ON NULL INPUT | STRICT -- diff --git a/src/test/regress/sql/create_function_3.sql b/src/test/regress/sql/create_function_3.sql index 54b25e62dd..e78a2ba2b9 100644 --- a/src/test/regress/sql/create_function_3.sql +++ b/src/test/regress/sql/create_function_3.sql @@ -107,11 +107,20 @@ CREATE FUNCTION functext_E_3(int) RETURNS bool LANGUAGE 'sql' RESET SESSION AUTHORIZATION; +--- -- list of built-in leakproof functions +--- + +-- temporarily disable fancy output, so catalog changes create less diff noise +\a\t + SELECT proname, prorettype::regtype, proargtypes::regtype[] FROM pg_proc JOIN pg_namespace ON pronamespace = pg_namespace.oid WHERE nspname = 'pg_catalog' AND proleakproof ORDER BY proname; +-- restore normal output mode +\a\t + -- -- CALLED ON NULL INPUT | RETURNS NULL ON NULL INPUT | STRICT --