blob: e53789f8f42aefe7401ce108cbce71400748b884 [file] [log] [blame]
-- C94001C.ADA
-- Grant of Unlimited Rights
--
-- Under contracts F33600-87-D-0337, F33600-84-D-0280, MDA903-79-C-0687,
-- F08630-91-C-0015, and DCA100-97-D-0025, the U.S. Government obtained
-- unlimited rights in the software and documentation contained herein.
-- Unlimited rights are defined in DFAR 252.227-7013(a)(19). By making
-- this public release, the Government intends to confer upon all
-- recipients unlimited rights equal to those held by the Government.
-- These rights include rights to use, duplicate, release or disclose the
-- released technical data and computer software in whole or in part, in
-- any manner and for any purpose whatsoever, and to have or permit others
-- to do so.
--
-- DISCLAIMER
--
-- ALL MATERIALS OR INFORMATION HEREIN RELEASED, MADE AVAILABLE OR
-- DISCLOSED ARE AS IS. THE GOVERNMENT MAKES NO EXPRESS OR IMPLIED
-- WARRANTY AS TO ANY MATTER WHATSOEVER, INCLUDING THE CONDITIONS OF THE
-- SOFTWARE, DOCUMENTATION OR OTHER INFORMATION RELEASED, MADE AVAILABLE
-- OR DISCLOSED, OR THE OWNERSHIP, MERCHANTABILITY, OR FITNESS FOR A
-- PARTICULAR PURPOSE OF SAID MATERIAL.
--*
-- CHECK THAT A UNIT WITH INDIRECT DEPENDENT TASKS CREATED BY OBJECT
-- DECLARATIONS IS NOT TERMINATED UNTIL ALL INDIRECT DEPENDENT TASKS
-- BECOME TERMINATED.
-- SUBTESTS ARE:
-- (A, B) A BLOCK CONTAINING A SIMPLE TASK OBJECT, IN A BLOCK.
-- (C, D) A FUNCTION CONTAINING AN ARRAY OF TASK OBJECT, IN A
-- FUNCTION.
-- (E, F) A TASK CONTAINING AN ARRAY OF RECORD OF TASK OBJECT,
-- IN A TASK BODY.
-- CASES (B, D, F) EXIT BY RAISING AN EXCEPTION.
-- THIS TEST CONTAINS SHARED VARIABLES AND RACE CONDITIONS.
-- TBN 8/25/86
-- PWN 01/31/95 REMOVED PRAGMA PRIORITY FOR ADA 9X.
with Impdef;
WITH REPORT; USE REPORT;
WITH SYSTEM; USE SYSTEM;
PROCEDURE C94001C IS
MY_EXCEPTION : EXCEPTION;
GLOBAL : INTEGER;
TASK TYPE TT IS
ENTRY E (I : INTEGER);
END TT;
TASK BODY TT IS
LOCAL : INTEGER;
BEGIN
ACCEPT E (I : INTEGER) DO
LOCAL := I;
END E;
DELAY 30.0 * Impdef.One_Second; -- SINCE THE PARENT UNIT HAS HIGHER PRIORITY
-- AT THIS POINT, IT WILL RECEIVE CONTROL AND
-- TERMINATE IF THE ERROR IS PRESENT.
GLOBAL := LOCAL;
END TT;
BEGIN
TEST ("C94001C", "CHECK THAT A UNIT WITH INDIRECT DEPENDENT " &
"TASKS CREATED BY OBJECT DECLARATIONS IS NOT " &
"TERMINATED UNTIL ALL INDIRECT DEPENDENT TASKS " &
"BECOME TERMINATED");
--------------------------------------------------
GLOBAL := IDENT_INT (0);
BEGIN -- (A)
DECLARE
T : TT;
BEGIN
T.E (IDENT_INT(1));
END;
END; -- (A)
IF GLOBAL /= 1 THEN
FAILED ("DEPENDENT TASK NOT TERMINATED BEFORE " &
"BLOCK EXIT - 1");
END IF;
--------------------------------------------------
BEGIN -- (B)
GLOBAL := IDENT_INT (0);
BEGIN
DECLARE
T : TT;
BEGIN
T.E (IDENT_INT(2));
RAISE MY_EXCEPTION;
END;
END;
FAILED ("MY_EXCEPTION WAS NOT RAISED - 2");
EXCEPTION
WHEN MY_EXCEPTION =>
IF GLOBAL /= 2 THEN
FAILED ("DEPENDENT TASK NOT TERMINATED BEFORE " &
"BLOCK EXIT - 2");
END IF;
WHEN OTHERS =>
FAILED ("UNEXPECTED EXCEPTION - 2");
END; -- (B)
--------------------------------------------------
GLOBAL := IDENT_INT (0);
DECLARE -- (C)
OBJ_INT : INTEGER;
FUNCTION F1 RETURN INTEGER IS
I : INTEGER;
FUNCTION F2 RETURN INTEGER IS
A : ARRAY (1..1) OF TT;
BEGIN
A(1).E (IDENT_INT(3));
RETURN 0;
END F2;
BEGIN
I := F2;
RETURN (0);
END F1;
BEGIN -- (C)
OBJ_INT := F1;
IF GLOBAL /= 3 THEN
FAILED ("DEPENDENT TASK NOT TERMINATED BEFORE " &
"FUNCTION EXIT - 3");
END IF;
END; -- (C)
--------------------------------------------------
DECLARE -- (D)
OBJ_INT : INTEGER;
FUNCTION F1 RETURN INTEGER IS
I : INTEGER;
FUNCTION F2 RETURN INTEGER IS
A : ARRAY (1..1) OF TT;
BEGIN
A(1).E (IDENT_INT(4));
IF EQUAL (3, 3) THEN
RAISE MY_EXCEPTION;
END IF;
RETURN 0;
END F2;
BEGIN
I := F2;
RETURN (0);
END F1;
BEGIN -- (D)
GLOBAL := IDENT_INT (0);
OBJ_INT := F1;
FAILED ("MY_EXCEPTION WAS NOT RAISED - 4");
EXCEPTION
WHEN MY_EXCEPTION =>
IF GLOBAL /= 4 THEN
FAILED ("DEPENDENT TASK NOT TERMINATED BEFORE " &
"FUNCTION EXIT - 4");
END IF;
WHEN OTHERS =>
FAILED ("UNEXPECTED EXCEPTION - 4");
END; -- (D)
--------------------------------------------------
GLOBAL := IDENT_INT (0);
DECLARE -- (E)
DELAY_COUNT : INTEGER := 0;
TASK OUT_TSK;
TASK BODY OUT_TSK IS
TASK TSK IS
ENTRY ENT;
END TSK;
TASK BODY TSK IS
TYPE RT IS
RECORD
T : TT;
END RECORD;
AR : ARRAY (1..1) OF RT;
BEGIN
AR(1).T.E (IDENT_INT(5));
END TSK;
BEGIN
NULL;
END OUT_TSK;
BEGIN -- (E)
WHILE NOT(OUT_TSK'TERMINATED) AND DELAY_COUNT < 60 LOOP
DELAY 1.0 * Impdef.One_Second;
DELAY_COUNT := DELAY_COUNT + 1;
END LOOP;
IF DELAY_COUNT = 60 THEN
FAILED ("OUT_TSK HAS NOT TERMINATED - 5");
ELSIF GLOBAL /= 5 THEN
FAILED ("DEPENDENT TASK NOT TERMINATED BEFORE " &
"BLOCK EXIT - 5");
END IF;
END; -- (E)
--------------------------------------------------
GLOBAL := IDENT_INT (0);
DECLARE
DELAY_COUNT : INTEGER := 0;
TASK OUT_TSK;
TASK BODY OUT_TSK IS
TASK TSK IS
ENTRY ENT;
END TSK;
TASK BODY TSK IS
TYPE RT IS
RECORD
T : TT;
END RECORD;
AR : ARRAY (1..1) OF RT;
BEGIN
AR(1).T.E (IDENT_INT(6));
RAISE MY_EXCEPTION;
END TSK;
BEGIN
RAISE MY_EXCEPTION;
END OUT_TSK;
BEGIN
WHILE NOT(OUT_TSK'TERMINATED) AND DELAY_COUNT < 60 LOOP
DELAY 1.0 * Impdef.One_Second;
DELAY_COUNT := DELAY_COUNT + 1;
END LOOP;
IF DELAY_COUNT = 60 THEN
FAILED ("OUT_TSK HAS NOT TERMINATED - 6");
ELSIF GLOBAL /= 6 THEN
FAILED ("DEPENDENT TASK NOT TERMINATED BEFORE " &
"BLOCK EXIT - 6");
END IF;
END;
RESULT;
END C94001C;