6
0
mirror of https://github.com/FirebirdSQL/firebird-qa.git synced 2025-01-22 21:43:06 +01:00
firebird-qa/tests/bugs/gh_6740_test.py

50 lines
1.5 KiB
Python
Raw Normal View History

#coding:utf-8
2022-01-27 20:08:36 +01:00
"""
ID: issue-6740
ISSUE: 6740
TITLE: Allow parenthesized query expression for standard-compliance
DESCRIPTION:
Queries which do not use `WITH` clause now can be enclosed in parenthesis,
but this leads to reduced number of max parts of UNIONed query, from 255 to 128.
2022-01-27 20:08:36 +01:00
JIRA: CORE-6511
FBTEST: bugs.gh_6740
NOTES:
[30.06.2022] pzotov
Error message in case when NUM_OF_UNIONED_PARTS >= 129 can obfuscate:
"Too many Contexts of Relation/Procedure/Views. Maximum allowed is 256"
Max limit of unioned-parts is 128, it was explained by Adriano in the ticket.
Checked on 5.0.0.509.
2022-01-27 20:08:36 +01:00
"""
import pytest
2022-01-27 20:08:36 +01:00
from firebird.qa import *
2022-01-27 20:08:36 +01:00
db = db_factory()
act = python_act('db')
NUM_OF_UNIONED_PARTS = 128
unioned_query = '('
for i in range(0,NUM_OF_UNIONED_PARTS):
unioned_query = ''.join( (unioned_query, 'select %d ' % (i+1) + ('as i ' if i==0 else '') + 'from rdb$database') )
if i < NUM_OF_UNIONED_PARTS-1:
unioned_query = ''.join( (unioned_query, ' union all (') )
unioned_query = ''.join( (unioned_query, ')' * NUM_OF_UNIONED_PARTS) )
expected_stdout = "8256"
2022-01-27 20:08:36 +01:00
@pytest.mark.version('>=5.0')
def test_1(act: Action, capsys):
with act.db.connect() as con:
cur = con.cursor()
cur.execute(unioned_query)
print( sum([x[0] for x in cur.fetchall()]) )
act.expected_stdout = expected_stdout
act.stdout = capsys.readouterr().out
assert act.clean_stdout == act.clean_expected_stdout