https://gcc.gnu.org/bugzilla/show_bug.cgi?id=116701

--- Comment #8 from GCC Commits <cvs-commit at gcc dot gnu.org> ---
The master branch has been updated by Hans-Peter Nilsson <h...@gcc.gnu.org>:

https://gcc.gnu.org/g:14cd10815a39cc131662d4b6759ff6712ddd0b6d

commit r15-3880-g14cd10815a39cc131662d4b6759ff6712ddd0b6d
Author: Hans-Peter Nilsson <h...@axis.com>
Date:   Mon Sep 23 18:44:11 2024 +0200

    gfortran testsuite: Remove unit-files in files having open-statements,
PR116701

    PR testsuite/116701 shows that left-behind files from
    unnamed gfortran open statements (named unit.N, where N =
    unit number) can interfere with the result of a subsequent
    run.  While that's unlikely to happen for a "real" fortran
    target or a test with a deleting close-statement, test-cases
    should not rely on previous test-cases passing and not
    execute along different execution paths depending on earlier
    runs, even if the difference is benevolent.

    Most but not all fortran test-cases go through
    gfortran-dg-runtest (gfortran.dg) or fortran-torture-execute
    (gfortran.fortran-torture).  However, the exceptions, with
    more complex framework and call-chains, either don't run or
    don't have open-statements, so a more complex solution
    doesn't seem worthwhile.  If test-cases with open-statements
    are added later to those parts of the test-suite, calls to
    fortran-delete-unit-files at the right spot may be added or
    worst case, "manual" cleanup-calls added, like:
    ! { dg-final { remote_file target delete "fort.10" } }
    Put the new proc in fortran-modules.exp since that's where other
    common fortran-testsuite dejagnu-library functions are located.

            PR testsuite/116701
            * lib/fortran-modules.exp (fortran-delete-unit-files): New proc.
            * lib/gfortran-dg.exp (gfortran-dg-runtest): Call
            fortran-delete-unit-files after executing test.
            * lib/fortran-torture.exp (fortran-torture-execute): Ditto.

Reply via email to