6
0
mirror of https://github.com/FirebirdSQL/firebird-qa.git synced 2025-01-23 05:53:06 +01:00
firebird-qa/tests/functional/gtcs/test_external_file_03_d.py

86 lines
2.1 KiB
Python

#coding:utf-8
"""
ID: gtcs.external-file-03
FBTEST: functional.gtcs.external_file_03_d
TITLE: Test for external table with field of SMALLINT datatype
DESCRIPTION:
Original test see in:
https://github.com/FirebirdSQL/fbtcs/blob/master/GTCS/tests/EXT_REL_0_3_D.script
"""
import pytest
from firebird.qa import *
db = db_factory()
act = python_act('db', substitutions=[('[ \t]+', ' ')])
expected_stderr = """
Statement failed, SQLSTATE = 22003
arithmetic exception, numeric overflow, or string truncation
-numeric value is out of range
Statement failed, SQLSTATE = 22003
arithmetic exception, numeric overflow, or string truncation
-numeric value is out of range
"""
expected_stdout = """
F01 -32768
F01 -1
F01 0
F01 1
F01 32767
Records affected: 5
"""
@pytest.mark.skip('FIXME: Not IMPLEMENTED')
@pytest.mark.version('>=3.0')
def test_1(act: Action):
pytest.fail("Not IMPLEMENTED")
# test_script_1
#---
#
# import os
# import sys
# import subprocess
# import time
#
# tmp_file = os.path.join(context['temp_directory'],'tmp_ext_03_d.tmp')
# if os.path.isfile( tmp_file):
# os.remove( tmp_file )
#
# this_fdb = db_conn.database_name
#
# sql_cmd='''
# connect 'localhost:%(this_fdb)s' user '%(user_name)s' password '%(user_password)s';
# create table ext_table external file '%(tmp_file)s' (f01 smallint);
# commit;
# insert into ext_table (f01) values ( 32767);
# insert into ext_table (f01) values (-32768);
# insert into ext_table (f01) values (1);
# insert into ext_table (f01) values (-1);
# insert into ext_table (f01) values (0);
# insert into ext_table (f01) values ( 32768);
# insert into ext_table (f01) values ( -32769);
# commit;
# set list on;
# set count on;
# select * from ext_table order by f01;
# ''' % dict(globals(), **locals())
#
# runProgram('isql', [ '-q' ], sql_cmd)
#
# f_sql_chk = open( os.path.join(context['temp_directory'],'tmp_ext_03_d.sql'), 'w')
# f_sql_chk.write(sql_cmd)
# f_sql_chk.close()
#
# time.sleep(1)
#
# os.remove(f_sql_chk.name)
# os.remove( tmp_file )
#
#---