Katherine Rasmussen 21dceb3ca6 [flang] Split up synchronization, event, and error stop stmt tests
Splitting up the tests for the synchronization statements,
event statements, and error stop statement allow for some of the
errors which are hidden by other errors, to be caught in the test.
This then reveals which invalid code does produce errors and which
does not produce errors.
2022-08-28 10:36:02 -07:00

90 lines
3.1 KiB
Fortran

! RUN: %python %S/test_errors.py %s %flang_fc1
! This test checks for semantic errors in event wait statements based on the
! statement specification in section 11.6.8 of the Fortran 2018 standard.
program test_event_wait
use iso_fortran_env, only : event_type
implicit none
! event_type variables must be coarrays
type(event_type) non_coarray
type(event_type) concert[*], occurrences(2)[*]
integer threshold, indexed(1), non_event[*], sync_status, co_indexed_integer[*], superfluous_stat, non_scalar(1)
character(len=128) error_message, non_scalar_char(1), co_indexed_character[*], superfluous_errmsg
logical invalid_type
!_______________________ standard-conforming statements ___________________________
event wait(concert)
event wait(occurrences(1))
event wait(concert, until_count=threshold)
event wait(concert, until_count=indexed(1))
event wait(concert, until_count=co_indexed_integer[1])
event wait(concert, stat=sync_status)
event wait(concert, until_count=threshold, stat=sync_status)
event wait(concert, errmsg=error_message)
event wait(concert, until_count=threshold, errmsg=error_message)
event wait(concert, stat=sync_status, errmsg=error_message)
event wait(concert, until_count=threshold, stat=sync_status, errmsg=error_message)
!____________________ non-standard-conforming statements __________________________
!_________________________ invalid event-variable ________________________________
! event-variable has an unknown expression
!ERROR: expected ')'
event wait(event=concert)
!_____________ invalid event-wait-spec-lists: invalid until-spec _________________
! Invalid until-spec keyword
!ERROR: expected ')'
event wait(concert, until_amount=threshold)
! Invalid until-spec: missing until-spec variable
!ERROR: expected ')'
event wait(concert, until_count)
! Invalid until-spec: missing 'until_count='
!ERROR: expected ')'
event wait(concert, threshold)
!_________________ invalid sync-stat-lists: invalid stat= ________________________
! Invalid stat-variable keyword
!ERROR: expected ')'
event wait(concert, status=sync_status)
! Invalid sync-stat-list: missing stat-variable
!ERROR: expected ')'
event wait(concert, stat)
! Invalid sync-stat-list: missing 'stat='
!ERROR: expected ')'
event wait(concert, sync_status)
!________________ invalid sync-stat-lists: invalid errmsg= _______________________
! Invalid errmsg-variable keyword
!ERROR: expected ')'
event wait(concert, errormsg=error_message)
! Invalid sync-stat-list: missing 'errmsg='
!ERROR: expected ')'
event wait(concert, error_message)
! Invalid sync-stat-list: missing errmsg-variable
!ERROR: expected ')'
event wait(concert, errmsg)
!______________ invalid event-variable: redundant event-variable _________________
!ERROR: expected ')'
event wait(concert, occurrences(1))
!ERROR: expected ')'
event wait(concert, occurrences(1), stat=sync_status, errmsg=error_message)
end program test_event_wait