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

169 lines
5.5 KiB
Python

#coding:utf-8
#
# id: bugs.core_4319
# title: Engine crashes when trace config contains line "connection_id=NN" and we attempt to connect to non-existent database/alias
# decription:
# Test receives version of FB (2.5 or 3.0) and prepares text file that will serve as TRACE config.
# This text file will contain trivial content appropriate to FB version with 'connection_id=NNN' key.
#
# Than we make async start of trace session using FBTRACEMGR utility and after small pause (~1 sec)
# run ISQL with attempt to make connect to non-existent alias.
#
# Confirmed crash on WI-T3.0.0.30566 (Alpha 1). Note: utility fbsvcmgr can not start when trace config
# contains connection_id: standard Windows crash report appears with such data:
# ...
# AppName: fbsvcmgr.exe AppVer: 3.0.0.30566 ModName: msvcr100.dll
# ModVer: 10.0.30319.1 Offset: 0008ae6e
# ...
#
# tracker_id: CORE-4319
# min_versions: ['2.5.3']
# versions: 2.5.3
# qmid: None
import pytest
from firebird.qa import db_factory, isql_act, Action
# version: 2.5.3
# resources: None
substitutions_1 = [('TRACE SESSION ID.*', 'TRACE SESSION ID')]
init_script_1 = """"""
db_1 = db_factory(sql_dialect=3, init=init_script_1)
# test_script_1
#---
# import os
# import time
# import subprocess
# from subprocess import Popen
#
# os.environ["ISC_USER"] = user_name
# os.environ["ISC_PASSWORD"] = user_password
#
# # Obtain engine version, 2.5 or 3.0, for make trace config in appropriate format:
# engine=str(db_conn.engine_version)
# db_conn.close()
#
# #-----------------------------------
#
# def flush_and_close(file_handle):
# # https://docs.python.org/2/library/os.html#os.fsync
# # If you're starting with a Python file object f,
# # first do f.flush(), and
# # then do os.fsync(f.fileno()), to ensure that all internal buffers associated with f are written to disk.
# global os
#
# file_handle.flush()
# os.fsync(file_handle.fileno())
#
# file_handle.close()
#
# #--------------------------------------------
#
# def cleanup( f_names_list ):
# global os
# for i in range(len( f_names_list )):
# if os.path.isfile( f_names_list[i]):
# os.remove( f_names_list[i] )
# if os.path.isfile( f_names_list[i]):
# print('ERROR: can not remove file ' + f_names_list[i])
#
# #--------------------------------------------
#
#
# txt25 = '''# Trace config, format for 2.5. Generated auto, do not edit!
# <database %[\\\\\\\\/]bugs.core_4319.fdb>
# enabled true
# log_errors true
# time_threshold 0
# connection_id 1234
# log_connections true
# </database>
# '''
#
# # NOTES ABOUT TRACE CONFIG FOR 3.0:
# # 1) Header contains `database` clause in different format vs FB 2.5: its data must be enclosed with '{' '}'
# # 2) Name and value must be separated by EQUALITY sign ('=') in FB-3 trace.conf, otherwise we get runtime error:
# # element "<. . .>" have no attribute value set
#
# txt30 = '''# Trace config, format for 3.0. Generated auto, do not edit!
# database=%[\\\\\\\\/]bugs.core_4319.fdb
# {
# enabled = true
# log_errors = true
# time_threshold = 0
# connection_id = 1234
# log_connections = true
# }
# '''
#
# f_trccfg=open( os.path.join(context['temp_directory'],'tmp_trace_4319.cfg'), 'w')
# if engine.startswith('2.5'):
# f_trccfg.write(txt25)
# else:
# f_trccfg.write(txt30)
# flush_and_close( f_trccfg )
#
# #####################################################
# # Starting trace session in new child process (async.):
# # Execute a child program in a new process, redirecting STDERR to the same target as of STDOUT:
#
# f_trclog=open( os.path.join(context['temp_directory'],'tmp_trace_4319.log'), 'w')
# p_trace=Popen([ context['fbtracemgr_path'],
# "-se", "localhost:service_mgr",
# "-sta", "-c", f_trccfg.name],
# stdout=f_trclog, stderr=subprocess.STDOUT)
#
# # Wait! Trace session is initialized not instantly!
# time.sleep(1)
#
#
# f_sqltxt=open( os.path.join(context['temp_directory'],'tmp_connect_4319.sql'), 'w')
# f_sqltxt.write("connect 'localhost:some_non_existent' user 'SYSDBA' password 'masterkey'; show database; show version;")
# flush_and_close( f_sqltxt )
#
# f_sqllog=open( os.path.join(context['temp_directory'],'tmp_connect_4319.log'), 'w')
# p_isql = subprocess.call([ context['isql_path'], dsn, "-i", f_sqltxt.name ],
# stdout=f_sqllog, stderr=subprocess.STDOUT)
# flush_and_close( f_sqllog )
#
# # Terminate child process of launched trace session:
#
# time.sleep(1)
#
# p_trace.terminate()
# flush_and_close( f_trclog )
#
# with open( f_trclog.name,'r') as f:
# for line in f:
# print(line.upper())
#
# with open( f_sqllog.name,'r') as f:
# for line in f:
# if 'SQLSTATE = 08001' in line:
# print(line.upper())
#
# # CLEANUP
# ##########
# time.sleep(1)
# cleanup( [i.name for i in (f_sqltxt, f_sqllog, f_trccfg, f_trclog)] )
#
#
#---
#act_1 = python_act('db_1', test_script_1, substitutions=substitutions_1)
expected_stdout_1 = """
TRACE SESSION ID STARTED
STATEMENT FAILED, SQLSTATE = 08001
"""
@pytest.mark.version('>=2.5.3')
@pytest.mark.xfail
def test_1(db_1):
pytest.fail("Test not IMPLEMENTED")