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_4067_test.py
2021-11-18 20:15:37 +01:00

84 lines
2.1 KiB
Python

#coding:utf-8
#
# id: bugs.core_4067
# title: Problem with "CREATE DATABASE ... COLLATION ..." and 1 dialect
# decription:
#
# tracker_id: CORE-4067
# min_versions: ['2.5.0']
# versions: 2.5
# qmid: None
import pytest
from pathlib import Path
from firebird.qa import db_factory, python_act, Action, temp_file
from firebird.driver import create_database, driver_config, DatabaseConfig
# version: 2.5
# resources: None
substitutions_1 = []
init_script_1 = """"""
db_1 = db_factory(sql_dialect=3, init=init_script_1)
# test_script_1
#---
# import os
# os.environ["ISC_USER"] = user_name
# os.environ["ISC_PASSWORD"] = user_password
#
# db_conn.close()
#
# tmpfdb_1=os.path.join(context['temp_directory'],'tmp_4067_1.fdb')
#
# sql_chk='''
# set sql dialect 1;
# create database 'localhost:%(tmpfdb_1)s' page_size 4096 default character set win1251 collation win1251;
# set list on;
# select mon$sql_dialect as x from mon$database;
# ''' % locals()
#
# f_list=[tmpfdb_1]
#
# # Cleanup BEFORE running script:
# ################
#
# for i in range(len(f_list)):
# if os.path.isfile(f_list[i]):
# os.remove(f_list[i])
#
# runProgram('isql',['-q'], sql_chk)
#
# # Final cleanup:
# ################
#
# for i in range(len(f_list)):
# if os.path.isfile(f_list[i]):
# os.remove(f_list[i])
#
#
#---
act_1 = python_act('db_1', substitutions=substitutions_1)
expected_stdout_1 = """
X 1
"""
temp_db_1 = temp_file('tmp_4067_1.fdb')
@pytest.mark.version('>=2.5')
def test_1(act_1: Action, temp_db_1: Path):
test_script = f"""
set sql dialect 1;
create database 'localhost:{str(temp_db_1)}' page_size 4096 default character set win1251 collation win1251;
set list on;
select mon$sql_dialect as x from mon$database;
"""
act_1.expected_stdout = expected_stdout_1
act_1.isql(switches=['-user', act_1.db.user, '-password', act_1.db.password],
input=test_script, connect_db=False)
assert act_1.clean_stdout == act_1.clean_expected_stdout