Fix circular reference error for the multirange data types in the query tool. #6221
Add support for the multirange data types.pull/6269/head
parent
1f2f405057
commit
2a22cf077c
|
@ -1,5 +1,5 @@
|
|||
{### Additional where condition for get_types route for column node ###}
|
||||
typisdefined AND typtype IN ('b', 'c', 'd', 'e', 'r')
|
||||
typisdefined AND typtype IN ('b', 'c', 'd', 'e', 'r', 'm')
|
||||
AND NOT EXISTS (SELECT 1 FROM pg_catalog.pg_class WHERE relnamespace=typnamespace
|
||||
AND relname = typname AND relkind != 'c') AND
|
||||
(typname NOT LIKE '_%' OR NOT EXISTS (SELECT 1 FROM pg_catalog.pg_class WHERE
|
||||
|
|
|
@ -110,14 +110,22 @@ PSYCOPG_SUPPORTED_IPADDRESS_ARRAY_TYPES = (1041, 651)
|
|||
# OID reference psycopg/lib/extras.py
|
||||
PSYCOPG_SUPPORTED_IPADDRESS_ARRAY_TYPES = (2951, 2950)
|
||||
|
||||
# int4range, int8range, numrange, daterange tsrange, tstzrange[]
|
||||
# int4range, int8range, numrange, daterange tsrange, tstzrange
|
||||
# OID reference psycopg/lib/_range.py
|
||||
PSYCOPG_SUPPORTED_RANGE_TYPES = (3904, 3926, 3906, 3912, 3908, 3910)
|
||||
|
||||
# int4multirange, int8multirange, nummultirange, datemultirange tsmultirange,
|
||||
# tstzmultirange[]
|
||||
PSYCOPG_SUPPORTED_MULTIRANGE_TYPES = (4535, 4451, 4536, 4532, 4533, 4534)
|
||||
|
||||
# int4range[], int8range[], numrange[], daterange[] tsrange[], tstzrange[]
|
||||
# OID reference psycopg/lib/_range.py
|
||||
PSYCOPG_SUPPORTED_RANGE_ARRAY_TYPES = (3905, 3927, 3907, 3913, 3909, 3911)
|
||||
|
||||
# int4multirange[], int8multirange[], nummultirange[],
|
||||
# datemultirange[] tsmultirange[], tstzmultirange[]
|
||||
PSYCOPG_SUPPORTED_MULTIRANGE_ARRAY_TYPES = (6155, 6150, 6157, 6151, 6152, 6153)
|
||||
|
||||
|
||||
def register_global_typecasters():
|
||||
# This registers a unicode type caster for datatype 'RECORD'.
|
||||
|
@ -128,7 +136,7 @@ def register_global_typecasters():
|
|||
2287, TextLoaderpgAdmin)
|
||||
|
||||
for typ in TO_STRING_DATATYPES + TO_STRING_NUMERIC_DATATYPES +\
|
||||
PSYCOPG_SUPPORTED_RANGE_TYPES:
|
||||
PSYCOPG_SUPPORTED_RANGE_TYPES + PSYCOPG_SUPPORTED_MULTIRANGE_TYPES:
|
||||
psycopg.adapters.register_loader(typ,
|
||||
TextLoaderpgAdmin)
|
||||
|
||||
|
@ -176,7 +184,8 @@ def register_array_to_string_typecasters(connection=None):
|
|||
type_array = PSYCOPG_SUPPORTED_BUILTIN_ARRAY_DATATYPES +\
|
||||
PSYCOPG_SUPPORTED_JSON_ARRAY_TYPES +\
|
||||
PSYCOPG_SUPPORTED_IPADDRESS_ARRAY_TYPES +\
|
||||
PSYCOPG_SUPPORTED_RANGE_ARRAY_TYPES +\
|
||||
PSYCOPG_SUPPORTED_RANGE_ARRAY_TYPES + \
|
||||
PSYCOPG_SUPPORTED_MULTIRANGE_ARRAY_TYPES + \
|
||||
TO_ARRAY_OF_STRING_DATATYPES
|
||||
|
||||
for typ in type_array:
|
||||
|
|
|
@ -22,6 +22,18 @@
|
|||
"daterange[]": 90200,
|
||||
"tsrange[]": 90200,
|
||||
"tstzrange[]": 90200,
|
||||
"int4multirange": 140000,
|
||||
"int8multirange": 140000,
|
||||
"nummultirange": 140000,
|
||||
"datemultirange": 140000,
|
||||
"tsmultirange": 140000,
|
||||
"tstzmultirange": 140000,
|
||||
"int4multirange[]": 140000,
|
||||
"int8multirange[]": 140000,
|
||||
"nummultirange[]": 140000,
|
||||
"datemultirange[]": 140000,
|
||||
"tsmultirange[]": 140000,
|
||||
"tstzmultirange[]": 140000,
|
||||
"inet": 0,
|
||||
"inet[]": 0,
|
||||
"cidr": 0,
|
||||
|
@ -212,6 +224,40 @@
|
|||
"08:00:2b:01:02:03",
|
||||
"{08:00:2b:01:02:03,08:00:2b:01:02:03,08:00:2b:01:02:03,08:00:2b:01:02:03,08:00:2b:01:02:03,08:00:2b:01:02:03}"
|
||||
]
|
||||
}, {
|
||||
"datatype": [
|
||||
"int4multirange",
|
||||
"int8multirange",
|
||||
"nummultirange",
|
||||
"datemultirange",
|
||||
"tsmultirange",
|
||||
"int4multirange[]",
|
||||
"int8multirange[]",
|
||||
"nummultirange[]",
|
||||
"datemultirange[]"
|
||||
],
|
||||
"input": [
|
||||
"'{[1,4],[6,10]}'",
|
||||
"'{(2,2002), (3001,922337203685477580)}'",
|
||||
"'{(3,92233), (92234,922337203685.922337203685)}'",
|
||||
"'{(2010-01-01,2010-02-01], (2012-01-01,2015-02-01]}'",
|
||||
"'{[2010-01-01 14:00, 2010-04-01 15:00)}'",
|
||||
"'{\"{(1,2147483647)}\", \"{(2,2147483647)}\"}'",
|
||||
"'{\"{(2,9223372036854775807)}\", \"{(2,9223372036854775807)}\"}'",
|
||||
"'{\"{(3,922337203685.922337203685]}\", \"{(5,922337203685.922337203685]}\"}'",
|
||||
"'{\"{(2010-01-01, 2010-02-01]}\", \"{(2010-01-01, 2010-02-01]}\"}'"
|
||||
],
|
||||
"output": [
|
||||
"{[1,5),[6,11)}",
|
||||
"{[3,2002),[3002,922337203685477580)}",
|
||||
"{(3,92233),(92234,922337203685.922337203685)}",
|
||||
"{[2010-01-02,2010-02-02),[2012-01-02,2015-02-02)}",
|
||||
"{[\"2010-01-01 14:00:00\",\"2010-04-01 15:00:00\")}",
|
||||
"{\"{[2,2147483647)}\",\"{[3,2147483647)}\"}",
|
||||
"{\"{[3,9223372036854775807)}\",\"{[3,9223372036854775807)}\"}",
|
||||
"{\"{(3,922337203685.922337203685]}\",\"{(5,922337203685.922337203685]}\"}",
|
||||
"{\"{[2010-01-02,2010-02-02)}\",\"{[2010-01-02,2010-02-02)}\"}"
|
||||
]
|
||||
}
|
||||
]
|
||||
}
|
||||
|
|
|
@ -225,7 +225,8 @@ class PGDataypeFeatureTest(BaseFeatureTest):
|
|||
cnt += 1
|
||||
continue
|
||||
|
||||
if datatype in ('tstzrange', 'tstzrange[]'):
|
||||
if datatype in ('tstzrange', 'tstzrange[]', 'tstzmultirange',
|
||||
'tstzmultirange[]'):
|
||||
expected_output = expected_output.format(
|
||||
**dict([('tz', self.timezone_hh_mm)]))
|
||||
try:
|
||||
|
@ -256,7 +257,8 @@ class PGDataypeFeatureTest(BaseFeatureTest):
|
|||
else:
|
||||
dataformatter = '{}'
|
||||
|
||||
if datatype in ('tstzrange', 'tstzrange[]'):
|
||||
if datatype in ('tstzrange', 'tstzrange[]', 'tstzmultirange',
|
||||
'tstzmultirange[]'):
|
||||
inputdata = inputdata.format(
|
||||
**dict([('tz', self.timezone_hh_mm)]))
|
||||
if first:
|
||||
|
|
|
@ -70,6 +70,7 @@ class BaseFeatureTest(BaseTestGenerator):
|
|||
self.after()
|
||||
|
||||
def any_step_failed(self):
|
||||
if hasattr(self._outcome, 'errors'):
|
||||
for step in self._outcome.errors:
|
||||
if step[1] is not None:
|
||||
return True
|
||||
|
|
Loading…
Reference in New Issue