Project

General

Profile

« Previous | Next » 

Revision 2468

sql.py: Create temp items as permanent in autocommit mode rather than in debug mode so that temp items are only permanent if actually committing result. This ensures that the generated SQL in test mode matches what would actually get run in regular commit mode, and the SQL is only altered to make the temp items visible if actually debugging (autocommit mode).

View differences:

lib/sql.py
423 423
        kw_args['recover'] = True
424 424
        kw_args.setdefault('log_ignore_excs', (DuplicateTableException,))
425 425
        
426
        temp = not db.debug # tables are created as permanent in debug mode
426
        temp = not db.autocommit # tables are permanent in autocommit mode
427 427
        # "temporary tables cannot specify a schema name", so remove schema
428 428
        if temp: into.schema = None
429 429
        
......
563 563
        while True:
564 564
            try:
565 565
                func_schema = None
566
                if not db.debug: func_schema = 'pg_temp'
566
                if not db.autocommit: func_schema = 'pg_temp'
567 567
                function = sql_gen.Table(function_name, func_schema).to_str(db)
568 568
                
569 569
                function_query = '''\

Also available in: Unified diff