2 @message |
assert
+ Initial script failed, check output:
+ Statement failed, SQLSTATE = 22021
+ unsuccessful metadata update
+ -ALTER CHARACTER SET "SYSTEM"."UTF8" failed
+ -COLLATION "SYSTEM"."CI_COLL" for CHARACTER SET "SYSTEM"."UTF8" is not defined
+ After line 16 in file /var/tmp/qa_2024/test_11668/gh_8061.tmp.sql
- 1000
- select c1.cust_no
- from customer c1
- where exists (
- select 1 from sales s1 where s1.cust_no = c1.cust_no and s1.qty_ordered > 10
- )
- Check unnesting of single EXISTS
- Select Expression
- ....-> Filter
- ........-> Hash Join (semi)
- ............-> Table "CUSTOMER" as "C1" Full Scan
- ............-> Record Buffer (record length: NN)
- ................-> Filter
- ....................-> Table "SALES" as "S1" Full Scan
- 2000
- select c2.cust_no
- from customer c2
- where c2.cust_no = any (
- select s2.cust_no
- from sales s2
- where s2.qty_ordered > 10
- )
- Check unnesting of ANY
- Select Expression
- ....-> Filter
- ........-> Hash Join (semi)
- ............-> Table "CUSTOMER" as "C2" Full Scan
- ............-> Record Buffer (record length: NN)
- ................-> Filter
- ....................-> Table "SALES" as "S2" Full Scan
- 3000
- select c3.cust_no
- from customer c3
- where exists (
- select s3.cust_no
- from sales s3
- where s3.cust_no = c3.cust_no and
- exists (
- select x.emp_no
- from employee x
- where
- x.emp_no = s3.sales_rep
- and (
- x.dept_no > 0
- or
- x.job_code > ''
- )
- )
- )
- Check unnesting of two nested EXISTS
- Select Expression
- ....-> Filter
- ........-> Hash Join (semi)
- ............-> Table "CUSTOMER" as "C3" Full Scan
- ............-> Record Buffer (record length: NN)
- ................-> Filter
- ....................-> Hash Join (semi)
- ........................-> Table "SALES" as "S3" Full Scan
- ........................-> Record Buffer (record length: NN)
- ............................-> Filter
- ................................-> Table "EMPLOYEE" as "X" Full Scan
- 4000
- select c4.cust_no
- from customer c4
- where c4.cust_no in
- (
- select s4.cust_no
- from sales s4
- where
- s4.paid > ''
- or
- s4.sales_rep in (
- select x.emp_no
- from employee x
- where
- x.dept_no > 0
- or
- x.job_code > ''
- )
- )
- Check unnesting of IN (NOTE: inner sub-query cannot be unnested due to OR condition present, but the outer sub-query *can*; see also bugs/gh_8265_test.py)
- Sub-query
- ....-> Filter
- ........-> Filter
- ............-> Table "EMPLOYEE" as "X" Access By ID
- ................-> Bitmap
- ....................-> Index "EMPLOYEE_PK" Unique Scan
- Select Expression
- ....-> Filter
- ........-> Hash Join (semi)
- ............-> Table "CUSTOMER" as "C4" Full Scan
- ............-> Record Buffer (record length: NN)
- ................-> Filter
- ....................-> Table "SALES" as "S4" Full Scan
LOG DETAILS:
2025-06-27 05:17:59.284
2025-06-27 05:17:59.290 act = <firebird.qa.plugin.Action object at [hex]>
2025-06-27 05:17:59.297 tmp_sql = PosixPath('/var/tmp/qa_2024/test_11668/gh_8061.tmp.sql')
2025-06-27 05:17:59.303 capsys = <_pytest.capture.CaptureFixture object at [hex]>
2025-06-27 05:17:59.308
2025-06-27 05:17:59.313 @pytest.mark.version('>=5.0.1')
2025-06-27 05:17:59.318 def test_1(act: Action, tmp_sql: Path, capsys):
2025-06-27 05:17:59.323 employee_data_sql = zipfile.Path(act.files_dir / 'standard_sample_databases.zip', at='sample-DB_-_firebird.sql')
2025-06-27 05:17:59.327 tmp_sql.write_bytes(employee_data_sql.read_bytes())
2025-06-27 05:17:59.332
2025-06-27 05:17:59.336 act.isql(switches = ['-q'], charset='utf8', input_file = tmp_sql, combine_output = True)
2025-06-27 05:17:59.341
2025-06-27 05:17:59.345 if act.return_code == 0:
2025-06-27 05:17:59.349
2025-06-27 05:17:59.354 srv_cfg = driver_config.register_server(name = f'srv_cfg_8061', config = '')
2025-06-27 05:17:59.358 db_cfg_name = f'db_cfg_8061'
2025-06-27 05:17:59.362 db_cfg_object = driver_config.register_database(name = db_cfg_name)
2025-06-27 05:17:59.366 db_cfg_object.server.value = srv_cfg.name
2025-06-27 05:17:59.371 db_cfg_object.database.value = str(act.db.db_path)
2025-06-27 05:17:59.375 if act.is_version('<6'):
2025-06-27 05:17:59.379 db_cfg_object.config.value = f"""
2025-06-27 05:17:59.384 SubQueryConversion = true
2025-06-27 05:17:59.388 """
2025-06-27 05:17:59.392
2025-06-27 05:17:59.397 with connect(db_cfg_name, user = act.db.user, password = act.db.password) as con:
2025-06-27 05:17:59.401 cur = con.cursor()
2025-06-27 05:17:59.407 for q_idx, q_tuple in query_map.items():
2025-06-27 05:17:59.414 test_sql, qry_comment = q_tuple[:2]
2025-06-27 05:17:59.423 ps = cur.prepare(test_sql)
2025-06-27 05:17:59.436 print(q_idx)
2025-06-27 05:17:59.443 print(test_sql)
2025-06-27 05:17:59.455 print(qry_comment)
2025-06-27 05:17:59.461 print( '\n'.join([replace_leading(s) for s in ps.detailed_plan.split('\n')]) )
2025-06-27 05:17:59.467 ps.free()
2025-06-27 05:17:59.474
2025-06-27 05:17:59.480 else:
2025-06-27 05:17:59.485 # If retcode !=0 then we can print the whole output of failed gbak:
2025-06-27 05:17:59.491 print('Initial script failed, check output:')
2025-06-27 05:17:59.499 for line in act.clean_stdout.splitlines():
2025-06-27 05:17:59.509 print(line)
2025-06-27 05:17:59.517 act.reset()
2025-06-27 05:17:59.523
2025-06-27 05:17:59.529 act.expected_stdout = f"""
2025-06-27 05:17:59.535 1000
2025-06-27 05:17:59.544 {query_map[1000][0]}
2025-06-27 05:17:59.553 {query_map[1000][1]}
2025-06-27 05:17:59.559 Select Expression
2025-06-27 05:17:59.566 ....-> Filter
2025-06-27 05:17:59.573 ........-> Hash Join (semi) (keys: 1, total key length: 4)
2025-06-27 05:17:59.580 ............-> Table "CUSTOMER" as "C1" Full Scan
2025-06-27 05:17:59.587 ............-> Record Buffer (record length: 33)
2025-06-27 05:17:59.593 ................-> Filter
2025-06-27 05:17:59.600 ....................-> Table "SALES" as "S1" Full Scan
2025-06-27 05:17:59.607
2025-06-27 05:17:59.613 2000
2025-06-27 05:17:59.620 {query_map[2000][0]}
2025-06-27 05:17:59.626 {query_map[2000][1]}
2025-06-27 05:17:59.636 Select Expression
2025-06-27 05:17:59.645 ....-> Filter
2025-06-27 05:17:59.653 ........-> Hash Join (semi) (keys: 1, total key length: 4)
2025-06-27 05:17:59.664 ............-> Table "CUSTOMER" as "C2" Full Scan
2025-06-27 05:17:59.673 ............-> Record Buffer (record length: 33)
2025-06-27 05:17:59.682 ................-> Filter
2025-06-27 05:17:59.691 ....................-> Table "SALES" as "S2" Full Scan
2025-06-27 05:17:59.698
2025-06-27 05:17:59.706 3000
2025-06-27 05:17:59.715 {query_map[3000][0]}
2025-06-27 05:17:59.720 {query_map[3000][1]}
2025-06-27 05:17:59.726 Select Expression
2025-06-27 05:17:59.736 ....-> Filter
2025-06-27 05:17:59.745 ........-> Hash Join (semi) (keys: 1, total key length: 4)
2025-06-27 05:17:59.757 ............-> Table "CUSTOMER" as "C3" Full Scan
2025-06-27 05:17:59.766 ............-> Record Buffer (record length: 58)
2025-06-27 05:17:59.772 ................-> Filter
2025-06-27 05:17:59.780 ....................-> Hash Join (semi) (keys: 1, total key length: 2)
2025-06-27 05:17:59.787 ........................-> Table "SALES" as "S3" Full Scan
2025-06-27 05:17:59.798 ........................-> Record Buffer (record length: 41)
2025-06-27 05:17:59.807 ............................-> Filter
2025-06-27 05:17:59.815 ................................-> Table "EMPLOYEE" as "X" Full Scan
2025-06-27 05:17:59.826
2025-06-27 05:17:59.835 4000
2025-06-27 05:17:59.842 {query_map[4000][0]}
2025-06-27 05:17:59.853 {query_map[4000][1]}
2025-06-27 05:17:59.863 Sub-query
2025-06-27 05:17:59.871 ....-> Filter
2025-06-27 05:17:59.879 ........-> Filter
2025-06-27 05:17:59.893 ............-> Table "EMPLOYEE" as "X" Access By ID
2025-06-27 05:17:59.903 ................-> Bitmap
2025-06-27 05:17:59.911 ....................-> Index "EMPLOYEE_PK" Unique Scan
2025-06-27 05:17:59.919 Select Expression
2025-06-27 05:17:59.929 ....-> Filter
2025-06-27 05:17:59.939 ........-> Hash Join (semi) (keys: 1, total key length: 4)
2025-06-27 05:17:59.946 ............-> Table "CUSTOMER" as "C4" Full Scan
2025-06-27 05:17:59.954 ............-> Record Buffer (record length: 33)
2025-06-27 05:17:59.966 ................-> Filter
2025-06-27 05:17:59.975 ....................-> Table "SALES" as "S4" Full Scan
2025-06-27 05:17:59.984
2025-06-27 05:17:59.991 """
2025-06-27 05:17:59.998 act.stdout = capsys.readouterr().out
2025-06-27 05:18:00.004 > assert act.clean_stdout == act.clean_expected_stdout
2025-06-27 05:18:00.010 E assert
2025-06-27 05:18:00.016 E + Initial script failed, check output:
2025-06-27 05:18:00.026 E + Statement failed, SQLSTATE = 22021
2025-06-27 05:18:00.038 E + unsuccessful metadata update
2025-06-27 05:18:00.047 E + -ALTER CHARACTER SET "SYSTEM"."UTF8" failed
2025-06-27 05:18:00.055 E + -COLLATION "SYSTEM"."CI_COLL" for CHARACTER SET "SYSTEM"."UTF8" is not defined
2025-06-27 05:18:00.062 E + After line 16 in file /var/tmp/qa_2024/test_11668/gh_8061.tmp.sql
2025-06-27 05:18:00.078 E - 1000
2025-06-27 05:18:00.091 E - select c1.cust_no
2025-06-27 05:18:00.097 E - from customer c1
2025-06-27 05:18:00.104 E - where exists (
2025-06-27 05:18:00.111 E - select 1 from sales s1 where s1.cust_no = c1.cust_no and s1.qty_ordered > 10
2025-06-27 05:18:00.116 E - )
2025-06-27 05:18:00.121 E - Check unnesting of single EXISTS
2025-06-27 05:18:00.126 E - Select Expression
2025-06-27 05:18:00.131 E - ....-> Filter
2025-06-27 05:18:00.136 E - ........-> Hash Join (semi)
2025-06-27 05:18:00.140 E - ............-> Table "CUSTOMER" as "C1" Full Scan
2025-06-27 05:18:00.145 E - ............-> Record Buffer (record length: NN)
2025-06-27 05:18:00.150 E - ................-> Filter
2025-06-27 05:18:00.155 E - ....................-> Table "SALES" as "S1" Full Scan
2025-06-27 05:18:00.161 E - 2000
2025-06-27 05:18:00.166 E - select c2.cust_no
2025-06-27 05:18:00.172 E - from customer c2
2025-06-27 05:18:00.178 E - where c2.cust_no = any (
2025-06-27 05:18:00.185 E - select s2.cust_no
2025-06-27 05:18:00.192 E - from sales s2
2025-06-27 05:18:00.199 E - where s2.qty_ordered > 10
2025-06-27 05:18:00.205 E - )
2025-06-27 05:18:00.211 E - Check unnesting of ANY
2025-06-27 05:18:00.219 E - Select Expression
2025-06-27 05:18:00.230 E - ....-> Filter
2025-06-27 05:18:00.238 E - ........-> Hash Join (semi)
2025-06-27 05:18:00.246 E - ............-> Table "CUSTOMER" as "C2" Full Scan
2025-06-27 05:18:00.251 E - ............-> Record Buffer (record length: NN)
2025-06-27 05:18:00.257 E - ................-> Filter
2025-06-27 05:18:00.262 E - ....................-> Table "SALES" as "S2" Full Scan
2025-06-27 05:18:00.268 E - 3000
2025-06-27 05:18:00.273 E - select c3.cust_no
2025-06-27 05:18:00.279 E - from customer c3
2025-06-27 05:18:00.286 E - where exists (
2025-06-27 05:18:00.291 E - select s3.cust_no
2025-06-27 05:18:00.296 E - from sales s3
2025-06-27 05:18:00.301 E - where s3.cust_no = c3.cust_no and
2025-06-27 05:18:00.306 E - exists (
2025-06-27 05:18:00.311 E - select x.emp_no
2025-06-27 05:18:00.316 E - from employee x
2025-06-27 05:18:00.320 E - where
2025-06-27 05:18:00.325 E - x.emp_no = s3.sales_rep
2025-06-27 05:18:00.329 E - and (
2025-06-27 05:18:00.334 E - x.dept_no > 0
2025-06-27 05:18:00.339 E - or
2025-06-27 05:18:00.343 E - x.job_code > ''
2025-06-27 05:18:00.348 E - )
2025-06-27 05:18:00.352 E - )
2025-06-27 05:18:00.357 E - )
2025-06-27 05:18:00.362 E - Check unnesting of two nested EXISTS
2025-06-27 05:18:00.366 E - Select Expression
2025-06-27 05:18:00.371 E - ....-> Filter
2025-06-27 05:18:00.375 E - ........-> Hash Join (semi)
2025-06-27 05:18:00.380 E - ............-> Table "CUSTOMER" as "C3" Full Scan
2025-06-27 05:18:00.385 E - ............-> Record Buffer (record length: NN)
2025-06-27 05:18:00.397 E - ................-> Filter
2025-06-27 05:18:00.403 E - ....................-> Hash Join (semi)
2025-06-27 05:18:00.409 E - ........................-> Table "SALES" as "S3" Full Scan
2025-06-27 05:18:00.415 E - ........................-> Record Buffer (record length: NN)
2025-06-27 05:18:00.421 E - ............................-> Filter
2025-06-27 05:18:00.427 E - ................................-> Table "EMPLOYEE" as "X" Full Scan
2025-06-27 05:18:00.435 E - 4000
2025-06-27 05:18:00.447 E - select c4.cust_no
2025-06-27 05:18:00.455 E - from customer c4
2025-06-27 05:18:00.461 E - where c4.cust_no in
2025-06-27 05:18:00.467 E - (
2025-06-27 05:18:00.472 E - select s4.cust_no
2025-06-27 05:18:00.479 E - from sales s4
2025-06-27 05:18:00.487 E - where
2025-06-27 05:18:00.498 E - s4.paid > ''
2025-06-27 05:18:00.505 E - or
2025-06-27 05:18:00.511 E - s4.sales_rep in (
2025-06-27 05:18:00.517 E - select x.emp_no
2025-06-27 05:18:00.521 E - from employee x
2025-06-27 05:18:00.530 E - where
2025-06-27 05:18:00.539 E - x.dept_no > 0
2025-06-27 05:18:00.547 E - or
2025-06-27 05:18:00.553 E - x.job_code > ''
2025-06-27 05:18:00.559 E - )
2025-06-27 05:18:00.563 E - )
2025-06-27 05:18:00.568 E - Check unnesting of IN (NOTE: inner sub-query cannot be unnested due to OR condition present, but the outer sub-query *can*; see also bugs/gh_8265_test.py)
2025-06-27 05:18:00.573 E - Sub-query
2025-06-27 05:18:00.579 E - ....-> Filter
2025-06-27 05:18:00.585 E - ........-> Filter
2025-06-27 05:18:00.591 E - ............-> Table "EMPLOYEE" as "X" Access By ID
2025-06-27 05:18:00.598 E - ................-> Bitmap
2025-06-27 05:18:00.607 E - ....................-> Index "EMPLOYEE_PK" Unique Scan
2025-06-27 05:18:00.617 E - Select Expression
2025-06-27 05:18:00.629 E - ....-> Filter
2025-06-27 05:18:00.638 E - ........-> Hash Join (semi)
2025-06-27 05:18:00.649 E - ............-> Table "CUSTOMER" as "C4" Full Scan
2025-06-27 05:18:00.659 E - ............-> Record Buffer (record length: NN)
2025-06-27 05:18:00.667 E - ................-> Filter
2025-06-27 05:18:00.674 E - ....................-> Table "SALES" as "S4" Full Scan
2025-06-27 05:18:00.683
2025-06-27 05:18:00.693 tests/bugs/gh_8061_test.py:232: AssertionError
2025-06-27 05:18:00.701 ---------------------------- Captured stdout setup -----------------------------
2025-06-27 05:18:00.708 Creating db: localhost:/var/tmp/qa_2024/test_11668/test.fdb [page_size=None, sql_dialect=None, charset='NONE', user=SYSDBA, password=masterkey]
|
3 #text |
act = <firebird.qa.plugin.Action pytest object at [hex]>
tmp_sql = PosixPath('/var/tmp/qa_2024/test_11668/gh_8061.tmp.sql')
capsys = <_pytest.capture.CaptureFixture pytest object at [hex]>
@pytest.mark.version('>=5.0.1')
def test_1(act: Action, tmp_sql: Path, capsys):
employee_data_sql = zipfile.Path(act.files_dir / 'standard_sample_databases.zip', at='sample-DB_-_firebird.sql')
tmp_sql.write_bytes(employee_data_sql.read_bytes())
act.isql(switches = ['-q'], charset='utf8', input_file = tmp_sql, combine_output = True)
if act.return_code == 0:
srv_cfg = driver_config.register_server(name = f'srv_cfg_8061', config = '')
db_cfg_name = f'db_cfg_8061'
db_cfg_object = driver_config.register_database(name = db_cfg_name)
db_cfg_object.server.value = srv_cfg.name
db_cfg_object.database.value = str(act.db.db_path)
if act.is_version('<6'):
db_cfg_object.config.value = f"""
SubQueryConversion = true
"""
with connect(db_cfg_name, user = act.db.user, password = act.db.password) as con:
cur = con.cursor()
for q_idx, q_tuple in query_map.items():
test_sql, qry_comment = q_tuple[:2]
ps = cur.prepare(test_sql)
print(q_idx)
print(test_sql)
print(qry_comment)
print( '\n'.join([replace_leading(s) for s in ps.detailed_plan.split('\n')]) )
ps.free()
else:
# If retcode !=0 then we can print the whole output of failed gbak:
print('Initial script failed, check output:')
for line in act.clean_stdout.splitlines():
print(line)
act.reset()
act.expected_stdout = f"""
1000
{query_map[1000][0]}
{query_map[1000][1]}
Select Expression
....-> Filter
........-> Hash Join (semi) (keys: 1, total key length: 4)
............-> Table "CUSTOMER" as "C1" Full Scan
............-> Record Buffer (record length: 33)
................-> Filter
....................-> Table "SALES" as "S1" Full Scan
2000
{query_map[2000][0]}
{query_map[2000][1]}
Select Expression
....-> Filter
........-> Hash Join (semi) (keys: 1, total key length: 4)
............-> Table "CUSTOMER" as "C2" Full Scan
............-> Record Buffer (record length: 33)
................-> Filter
....................-> Table "SALES" as "S2" Full Scan
3000
{query_map[3000][0]}
{query_map[3000][1]}
Select Expression
....-> Filter
........-> Hash Join (semi) (keys: 1, total key length: 4)
............-> Table "CUSTOMER" as "C3" Full Scan
............-> Record Buffer (record length: 58)
................-> Filter
....................-> Hash Join (semi) (keys: 1, total key length: 2)
........................-> Table "SALES" as "S3" Full Scan
........................-> Record Buffer (record length: 41)
............................-> Filter
................................-> Table "EMPLOYEE" as "X" Full Scan
4000
{query_map[4000][0]}
{query_map[4000][1]}
Sub-query
....-> Filter
........-> Filter
............-> Table "EMPLOYEE" as "X" Access By ID
................-> Bitmap
....................-> Index "EMPLOYEE_PK" Unique Scan
Select Expression
....-> Filter
........-> Hash Join (semi) (keys: 1, total key length: 4)
............-> Table "CUSTOMER" as "C4" Full Scan
............-> Record Buffer (record length: 33)
................-> Filter
....................-> Table "SALES" as "S4" Full Scan
"""
act.stdout = capsys.readouterr().out
> assert act.clean_stdout == act.clean_expected_stdout
E assert
E + Initial script failed, check output:
E + Statement failed, SQLSTATE = 22021
E + unsuccessful metadata update
E + -ALTER CHARACTER SET "SYSTEM"."UTF8" failed
E + -COLLATION "SYSTEM"."CI_COLL" for CHARACTER SET "SYSTEM"."UTF8" is not defined
E + After line 16 in file /var/tmp/qa_2024/test_11668/gh_8061.tmp.sql
E - 1000
E - select c1.cust_no
E - from customer c1
E - where exists (
E - select 1 from sales s1 where s1.cust_no = c1.cust_no and s1.qty_ordered > 10
E - )
E - Check unnesting of single EXISTS
E - Select Expression
E - ....-> Filter
E - ........-> Hash Join (semi)
E - ............-> Table "CUSTOMER" as "C1" Full Scan
E - ............-> Record Buffer (record length: NN)
E - ................-> Filter
E - ....................-> Table "SALES" as "S1" Full Scan
E - 2000
E - select c2.cust_no
E - from customer c2
E - where c2.cust_no = any (
E - select s2.cust_no
E - from sales s2
E - where s2.qty_ordered > 10
E - )
E - Check unnesting of ANY
E - Select Expression
E - ....-> Filter
E - ........-> Hash Join (semi)
E - ............-> Table "CUSTOMER" as "C2" Full Scan
E - ............-> Record Buffer (record length: NN)
E - ................-> Filter
E - ....................-> Table "SALES" as "S2" Full Scan
E - 3000
E - select c3.cust_no
E - from customer c3
E - where exists (
E - select s3.cust_no
E - from sales s3
E - where s3.cust_no = c3.cust_no and
E - exists (
E - select x.emp_no
E - from employee x
E - where
E - x.emp_no = s3.sales_rep
E - and (
E - x.dept_no > 0
E - or
E - x.job_code > ''
E - )
E - )
E - )
E - Check unnesting of two nested EXISTS
E - Select Expression
E - ....-> Filter
E - ........-> Hash Join (semi)
E - ............-> Table "CUSTOMER" as "C3" Full Scan
E - ............-> Record Buffer (record length: NN)
E - ................-> Filter
E - ....................-> Hash Join (semi)
E - ........................-> Table "SALES" as "S3" Full Scan
E - ........................-> Record Buffer (record length: NN)
E - ............................-> Filter
E - ................................-> Table "EMPLOYEE" as "X" Full Scan
E - 4000
E - select c4.cust_no
E - from customer c4
E - where c4.cust_no in
E - (
E - select s4.cust_no
E - from sales s4
E - where
E - s4.paid > ''
E - or
E - s4.sales_rep in (
E - select x.emp_no
E - from employee x
E - where
E - x.dept_no > 0
E - or
E - x.job_code > ''
E - )
E - )
E - Check unnesting of IN (NOTE: inner sub-query cannot be unnested due to OR condition present, but the outer sub-query *can*; see also bugs/gh_8265_test.py)
E - Sub-query
E - ....-> Filter
E - ........-> Filter
E - ............-> Table "EMPLOYEE" as "X" Access By ID
E - ................-> Bitmap
E - ....................-> Index "EMPLOYEE_PK" Unique Scan
E - Select Expression
E - ....-> Filter
E - ........-> Hash Join (semi)
E - ............-> Table "CUSTOMER" as "C4" Full Scan
E - ............-> Record Buffer (record length: NN)
E - ................-> Filter
E - ....................-> Table "SALES" as "S4" Full Scan
tests/bugs/gh_8061_test.py:232: AssertionError
|