2021-04-26 20:07:00 +02:00
|
|
|
#coding:utf-8
|
2022-01-21 18:49:26 +01:00
|
|
|
|
|
|
|
"""
|
|
|
|
ID: issue-2888
|
|
|
|
ISSUE: 2888
|
|
|
|
TITLE: External table data not visible to other sessions in Classic
|
|
|
|
DESCRIPTION:
|
|
|
|
In 2.1.2 SuperServer, any data written to external tables are visible to other sessions.
|
|
|
|
However in Classic, this data is not visible. It seems to be cached and written to file
|
|
|
|
eventually, when this happens it becomes visible.
|
|
|
|
NOTES:
|
|
|
|
THIS TEST WILL END WITH ERROR IF EXTERNAL TABLE ACCESS IS NOT ALLOWED, WHICH IS BY DEFAULT.
|
|
|
|
It's necessary to adjust firebird.conf.
|
|
|
|
JIRA: CORE-2475
|
|
|
|
"""
|
2021-04-26 20:07:00 +02:00
|
|
|
|
|
|
|
import pytest
|
2021-11-16 19:44:53 +01:00
|
|
|
from pathlib import Path
|
2022-01-21 18:49:26 +01:00
|
|
|
from firebird.qa import *
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2022-01-21 18:49:26 +01:00
|
|
|
db = db_factory()
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2022-01-21 18:49:26 +01:00
|
|
|
act = python_act('db')
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2021-11-16 19:44:53 +01:00
|
|
|
external_table = temp_file('EXT1.TBL')
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2021-11-16 19:44:53 +01:00
|
|
|
@pytest.mark.version('>=2.1.3')
|
2022-01-21 18:49:26 +01:00
|
|
|
def test_1(act: Action, external_table: Path):
|
2021-11-16 19:44:53 +01:00
|
|
|
# Create external table
|
2022-01-21 18:49:26 +01:00
|
|
|
act.isql(switches=[],
|
2021-11-16 19:44:53 +01:00
|
|
|
input=f"create table EXT1 external file '{str(external_table)}' (PK INTEGER); exit;")
|
|
|
|
# session A
|
2022-01-21 18:49:26 +01:00
|
|
|
with act.db.connect() as con:
|
2021-11-16 19:44:53 +01:00
|
|
|
c = con.cursor()
|
|
|
|
c.execute("insert into EXT1 (PK) values (1)")
|
|
|
|
con.commit()
|
|
|
|
# session B
|
2022-01-21 18:49:26 +01:00
|
|
|
with act.db.connect() as con:
|
2021-11-16 19:44:53 +01:00
|
|
|
c = con.cursor()
|
|
|
|
c.execute('select * from EXT1')
|
|
|
|
result = c.fetchall()
|
|
|
|
assert result == [(1, )]
|