mirror of
https://github.com/zebrajr/postgres.git
synced 2025-12-07 12:20:31 +01:00
Change the exception syntax used in the tests to use the more current
except Exception as ex:
rather than the old
except Exception, ex:
Since support for Python <2.6 has been removed, all supported versions
now support the new style, and we can save one step in the Python 3
compatibility conversion.
Reviewed-by: Tom Lane <tgl@sss.pgh.pa.us>
Discussion: https://www.postgresql.org/message-id/flat/98b69261-298c-13d2-f34d-836fd9c29b21%402ndquadrant.com
43 lines
1.1 KiB
PL/PgSQL
43 lines
1.1 KiB
PL/PgSQL
--
|
|
-- Test named and nameless parameters
|
|
--
|
|
|
|
CREATE FUNCTION test_param_names0(integer, integer) RETURNS int AS $$
|
|
return args[0] + args[1]
|
|
$$ LANGUAGE plpythonu;
|
|
|
|
CREATE FUNCTION test_param_names1(a0 integer, a1 text) RETURNS boolean AS $$
|
|
assert a0 == args[0]
|
|
assert a1 == args[1]
|
|
return True
|
|
$$ LANGUAGE plpythonu;
|
|
|
|
CREATE FUNCTION test_param_names2(u users) RETURNS text AS $$
|
|
assert u == args[0]
|
|
if isinstance(u, dict):
|
|
# stringify dict the hard way because otherwise the order is implementation-dependent
|
|
u_keys = list(u.keys())
|
|
u_keys.sort()
|
|
s = '{' + ', '.join([repr(k) + ': ' + repr(u[k]) for k in u_keys]) + '}'
|
|
else:
|
|
s = str(u)
|
|
return s
|
|
$$ LANGUAGE plpythonu;
|
|
|
|
-- use deliberately wrong parameter names
|
|
CREATE FUNCTION test_param_names3(a0 integer) RETURNS boolean AS $$
|
|
try:
|
|
assert a1 == args[0]
|
|
return False
|
|
except NameError as e:
|
|
assert e.args[0].find("a1") > -1
|
|
return True
|
|
$$ LANGUAGE plpythonu;
|
|
|
|
|
|
SELECT test_param_names0(2,7);
|
|
SELECT test_param_names1(1,'text');
|
|
SELECT test_param_names2(users) from users;
|
|
SELECT test_param_names2(NULL);
|
|
SELECT test_param_names3(1);
|