6
0
mirror of https://github.com/FirebirdSQL/firebird-qa.git synced 2025-01-22 13:33:07 +01:00
firebird-qa/tests/bugs/core_5750_test.py

145 lines
5.0 KiB
Python
Raw Permalink Normal View History

2021-04-26 20:07:00 +02:00
#coding:utf-8
2022-01-26 21:10:46 +01:00
"""
ID: issue-6013
ISSUE: 6013
TITLE: Date-time parsing is very weak
DESCRIPTION:
Parser changed in:
https://github.com/FirebirdSQL/firebird/commit/ff37d445ce844f991242b1e2c1f96b80a5d1636d
See also:
- CORE-6427 - Whitespace as date separator causes conversion error.
- CORE-6429 - Timezone offset in timestamp/time literal and CAST should follow SQL standard syntax only.
2022-01-26 21:10:46 +01:00
JIRA: CORE-5750
FBTEST: bugs.core_5750
NOTES:
[03.06.2023] pzotov
If source string contains binary characters (e.g. '2001') then it will not be converted to date,
but content of error message depends on FB version:
* on FB 4.x and FB 5.x prior 5.0.0.1058 it will look without changes, i.e. "2001";
* on 5.0.0.1058 it will look like this: conversion error from string "2029\x01\x19";
* on 5.0.0.1066 it will look like this: conversion error from string "2029#x01#x19";
Error text became differ after 30-may-2023:
https://github.com/FirebirdSQL/firebird/commit/fa6f9196f9015d0cf8c1cb84ff6312934855e9e9
("Fixed #7599: Conversion of text with '\0' to DECFLOAT without errors")
Expected STDERR was adjusted to current output after discuss with Alex.
[17.06.2023] pzotov
Since 16.06.2023: output for FB 4.x became identical to FB 5.x, see commit
https://github.com/FirebirdSQL/firebird/commit/6a1311f1eee2f1a3a2710b0daf900f32aac95d1a
Checked on 5.0.0.1066, 4.0.3.2948; 4.0.3.2953 (17.06.2023)
2022-01-26 21:10:46 +01:00
"""
2021-04-26 20:07:00 +02:00
2022-01-26 21:10:46 +01:00
import pytest
from firebird.qa import *
2021-04-26 20:07:00 +02:00
2022-01-26 21:10:46 +01:00
db = db_factory()
2021-04-26 20:07:00 +02:00
BINARY_DATA_SUFFIX = ''
test_script = f"""
2021-04-26 20:07:00 +02:00
set heading off;
--set echo on;
-- All these must fail:
select timestamp '2018-01-01 10 20 30' from rdb$database;
select timestamp '2018-01-01 10,20,30 40' from rdb$database;
select timestamp '31.05.2017 1:2:3.4567' from rdb$database;
select timestamp '31/05/2017 2:3:4.5678' from rdb$database;
------------------------------------------------------------
-- Date components separator may be a single one (first and second occurence): dash, slash or dot.
select date '2018-01-31' from rdb$database;
select date '2018/01/31' from rdb$database;
select date '2018.01.31' from rdb$database;
select date '2001{BINARY_DATA_SUFFIX}' from rdb$database;
2021-04-26 20:07:00 +02:00
select date '2018,01,31' from rdb$database;
select date '2018/01.31' from rdb$database;
select date '2018 01 31' from rdb$database;
-- Time components (hours to minutes to seconds) separator may be colon.
select time '10:29:39' from rdb$database;
select time '10/29/39' from rdb$database;
select time '10.29.39' from rdb$database;
select time '10-29-39' from rdb$database;
select time '10 29 39' from rdb$database;
-- Seconds to fractions separator may be dot.
select time '7:3:1.' from rdb$database;
select time '7:3:2.1238' from rdb$database;
select time '7:3:3,1238' from rdb$database;
-- There could *NOT* be any separator (other than spaces) between date and time.
select timestamp '2018-01-01T01:02:03.4567' from rdb$database;
select timestamp '31.05.2017 11:22:33.4455' from rdb$database;
select timestamp '31.05.2017
22:33:44.5577' from rdb$database;
2021-12-22 20:23:11 +01:00
"""
2021-04-26 20:07:00 +02:00
2022-01-26 21:10:46 +01:00
act = isql_act('db', test_script)
expected_stdout = """
2017-05-31 01:02:03.4567
2018-01-31
2018-01-31
2018-01-31
2018-01-31
10:29:39.0000
07:03:01.0000
07:03:02.1238
2017-05-31 11:22:33.4455
2021-12-22 20:23:11 +01:00
"""
2022-01-26 21:10:46 +01:00
@pytest.mark.version('>=4.0')
def test_1(act: Action):
2021-04-26 20:07:00 +02:00
BINARY_DATA_OUTPUT = '#x01#x19'
2021-04-26 20:07:00 +02:00
expected_stderr = f"""
Statement failed, SQLSTATE = 22009
Invalid time zone region: 20 30
2021-04-26 20:07:00 +02:00
Statement failed, SQLSTATE = 22009
Invalid time zone region: ,20,30 40
2021-04-26 20:07:00 +02:00
Statement failed, SQLSTATE = 22018
conversion error from string "31/05/2017 2:3:4.5678"
2021-04-26 20:07:00 +02:00
Statement failed, SQLSTATE = 22018
conversion error from string "2001{BINARY_DATA_OUTPUT}"
2021-04-26 20:07:00 +02:00
Statement failed, SQLSTATE = 22018
conversion error from string "2018,01,31"
2021-04-26 20:07:00 +02:00
Statement failed, SQLSTATE = 22018
conversion error from string "2018/01.31"
2021-04-26 20:07:00 +02:00
Statement failed, SQLSTATE = 22009
Invalid time zone region: /29/39
2021-04-26 20:07:00 +02:00
Statement failed, SQLSTATE = 22009
Invalid time zone region: .39
2021-04-26 20:07:00 +02:00
Statement failed, SQLSTATE = 22009
Invalid time zone offset: -29-39 - must use format +/-hours:minutes and be between -14:00 and +14:00
2021-04-26 20:07:00 +02:00
Statement failed, SQLSTATE = 22009
Invalid time zone region: 29 39
2021-04-26 20:07:00 +02:00
Statement failed, SQLSTATE = 22009
Invalid time zone region: ,1238
Statement failed, SQLSTATE = 22009
Invalid time zone region: T01:02:03.4567
Statement failed, SQLSTATE = 22009
Invalid time zone region:
22:33:44.5577
"""
2021-04-26 20:07:00 +02:00
2022-01-26 21:10:46 +01:00
act.expected_stdout = expected_stdout
act.expected_stderr = expected_stderr
act.execute()
assert (act.clean_stderr == act.clean_expected_stderr and
act.clean_stdout == act.clean_expected_stdout)