#coding:utf-8 """ ID: derived-table-07 TITLE: Outer reference inside derived table to other relations in from clause is not allowed DESCRIPTION: FBTEST: functional.arno.derived_tables.07 """ import pytest from firebird.qa import * init_script = """CREATE TABLE Table_10 ( ID INTEGER NOT NULL, DESCRIPTION VARCHAR(10) ); COMMIT; INSERT INTO Table_10 (ID, DESCRIPTION) VALUES (0, NULL); INSERT INTO Table_10 (ID, DESCRIPTION) VALUES (1, 'one'); INSERT INTO Table_10 (ID, DESCRIPTION) VALUES (2, 'two'); INSERT INTO Table_10 (ID, DESCRIPTION) VALUES (3, 'three'); INSERT INTO Table_10 (ID, DESCRIPTION) VALUES (4, 'four'); INSERT INTO Table_10 (ID, DESCRIPTION) VALUES (5, 'five'); INSERT INTO Table_10 (ID, DESCRIPTION) VALUES (6, 'six'); INSERT INTO Table_10 (ID, DESCRIPTION) VALUES (7, 'seven'); INSERT INTO Table_10 (ID, DESCRIPTION) VALUES (8, 'eight'); INSERT INTO Table_10 (ID, DESCRIPTION) VALUES (9, 'nine'); COMMIT; """ db = db_factory(init=init_script) test_script = """SELECT dt.* FROM Table_10 t10 LEFT JOIN (SELECT * FROM Table_10 t2 WHERE t2.ID = t10.ID) dt ON (1 = 1);""" act = isql_act('db', test_script, substitutions=[('column.*', '')]) expected_stderr = """Statement failed, SQLSTATE = 42S22 Dynamic SQL Error -SQL error code = -206 -Column unknown -T10.ID -At line 5, column 58 """ @pytest.mark.version('>=3') def test_1(act: Action): act.expected_stderr = expected_stderr act.execute() assert act.clean_stderr == act.clean_expected_stderr