blob: 1b6108fe5723fb02b2b9b7d05a41b51e98476795 [file] [log] [blame]
-- C94002G.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.
--*
-- OBJECTIVE:
-- CHECK THAT A NON-MASTER UNIT, WHICH ALLOCATES TASKS OF A GLOBAL
-- ACCESS TYPE, MUST TERMINATE WITHOUT WAITING FOR THE ALLOCATED
-- TASKS TO TERMINATE IF AN EXCEPTION IS RAISED BUT NOT HANDLED IN
-- THE NON-MASTER UNIT.
-- SUBTESTS ARE:
-- (A) A SIMPLE TASK ALLOCATOR, IN A BLOCK.
-- (B) A RECORD OF TASK ALLOCATOR, IN A SUBPROGRAM.
-- (C) A RECORD OF ARRAY OF TASK ALLOCATOR, IN A TASK BODY, NOT
-- DURING RENDEZVOUS.
-- (D) A LIMITED PRIVATE TASK ALLOCATOR, IN A TASK BODY, DURING
-- RENDEZVOUS.
-- HISTORY:
-- TBN 01/20/86 CREATED ORIGINAL TEST.
-- JRK 05/01/86 IMPROVED ERROR RECOVERY. FIXED EXCEPTION
-- HANDLING. ADDED CASE (D).
-- BCB 09/24/87 ADDED A RETURN STATEMENT TO THE HANDLER FOR OTHERS
-- IN FUNCTION F, CASE B.
-- PWN 09/11/94 REMOVED PRAGMA PRIORITY FOR ADA 9X.
with Impdef;
WITH REPORT; USE REPORT;
WITH SYSTEM; USE SYSTEM;
PROCEDURE C94002G IS
MY_EXCEPTION : EXCEPTION;
TASK TYPE TT IS
ENTRY E;
END TT;
TASK BODY TT IS
BEGIN
ACCEPT E;
ACCEPT E;
END TT;
BEGIN
TEST ("C94002G", "CHECK THAT A NON-MASTER UNIT, WHICH ALLOCATES " &
"TASKS OF A GLOBAL ACCESS TYPE, MUST TERMINATE " &
"WITHOUT WAITING FOR THE ALLOCATED TASKS TO " &
"TERMINATE IF AN EXCEPTION IS RAISED BUT NOT " &
"HANDLED IN THE NON-MASTER UNIT");
--------------------------------------------------
DECLARE -- (A)
TYPE A_T IS ACCESS TT;
A1 : A_T;
BEGIN -- (A)
DECLARE
A2 : A_T;
BEGIN
A2 := NEW TT;
A2.ALL.E;
A1 := A2;
RAISE MY_EXCEPTION;
FAILED ("MY_EXCEPTION WAS NOT RAISED IN (A)");
END;
ABORT A1.ALL;
EXCEPTION
WHEN MY_EXCEPTION =>
IF A1.ALL'TERMINATED THEN
FAILED ("ALLOCATED TASK PREMATURELY TERMINATED - " &
"(A)");
ELSE A1.ALL.E;
END IF;
WHEN OTHERS =>
FAILED ("UNEXPECTED EXCEPTION IN (A)");
IF A1 /= NULL THEN
ABORT A1.ALL;
END IF;
END; -- (A)
--------------------------------------------------
DECLARE -- (B)
I : INTEGER;
FUNCTION F RETURN INTEGER IS
TYPE RT IS
RECORD
T : TT;
END RECORD;
TYPE ART IS ACCESS RT;
AR1 : ART;
PROCEDURE P IS
AR2 : ART;
BEGIN
AR2 := NEW RT;
AR2.T.E;
AR1 := AR2;
RAISE MY_EXCEPTION;
FAILED ("MY_EXCEPTION WAS NOT RAISED IN (B)");
END P;
BEGIN
P;
ABORT AR1.T;
RETURN 0;
EXCEPTION
WHEN MY_EXCEPTION =>
IF AR1.T'TERMINATED THEN
FAILED ("ALLOCATED TASK PREMATURELY " &
"TERMINATED - (B)");
ELSE AR1.T.E;
END IF;
RETURN 0;
WHEN OTHERS =>
FAILED ("UNEXPECTED EXCEPTION IN (B)");
IF AR1 /= NULL THEN
ABORT AR1.T;
END IF;
RETURN 0;
END F;
BEGIN -- (B)
I := F;
END; -- (B)
--------------------------------------------------
DECLARE -- (C)
LOOP_COUNT : INTEGER := 0;
CUT_OFF : CONSTANT := 60; -- DELAY.
TASK TSK IS
ENTRY ENT;
END TSK;
TASK BODY TSK IS
LOOP_COUNT1 : INTEGER := 0;
CUT_OFF1 : CONSTANT := 60; -- DELAY.
TYPE RAT;
TYPE ARAT IS ACCESS RAT;
TYPE ARR IS ARRAY (1..1) OF TT;
TYPE RAT IS
RECORD
A : ARAT;
T : ARR;
END RECORD;
ARA1 : ARAT;
TASK TSK1 IS
ENTRY ENT1 (ARA : OUT ARAT);
END TSK1;
TASK BODY TSK1 IS
ARA2 : ARAT;
BEGIN
ARA2 := NEW RAT; -- INITIATE TASK ARA2.T(1).
ARA2.T(1).E;
ACCEPT ENT1 (ARA : OUT ARAT) DO
ARA := ARA2;
END ENT1;
RAISE MY_EXCEPTION; -- NOT PROPOGATED.
FAILED ("MY_EXCEPTION WAS NOT RAISED IN (C)");
END TSK1;
BEGIN
TSK1.ENT1 (ARA1); -- ARA1.T BECOMES ALIAS FOR ARA2.T.
WHILE NOT TSK1'TERMINATED AND LOOP_COUNT1 < CUT_OFF1 LOOP
DELAY 1.0 * Impdef.One_Second;
LOOP_COUNT1 := LOOP_COUNT1 + 1;
END LOOP;
IF LOOP_COUNT1 >= CUT_OFF1 THEN
FAILED ("DEPENDENT TASK TSK1 NOT TERMINATED " &
"WITHIN ONE MINUTE - (C)");
END IF;
IF ARA1.T(1)'TERMINATED THEN
FAILED ("ALLOCATED TASK PREMATURELY TERMINATED " &
"- (C)");
ELSE ARA1.T(1).E;
END IF;
END TSK;
BEGIN -- (C)
WHILE NOT TSK'TERMINATED AND LOOP_COUNT < CUT_OFF LOOP
DELAY 2.0 * Impdef.One_Second;
LOOP_COUNT := LOOP_COUNT + 1;
END LOOP;
IF LOOP_COUNT >= CUT_OFF THEN
FAILED ("DEPENDENT TASK TSK NOT TERMINATED WITHIN " &
"TWO MINUTES - (C)");
END IF;
END; -- (C)
--------------------------------------------------
DECLARE -- (D)
LOOP_COUNT : INTEGER := 0;
CUT_OFF : CONSTANT := 60; -- DELAY.
TASK TSK IS
ENTRY ENT;
END TSK;
TASK BODY TSK IS
LOOP_COUNT1 : INTEGER := 0;
CUT_OFF1 : CONSTANT := 60; -- DELAY.
PACKAGE PKG IS
TYPE LPT IS LIMITED PRIVATE;
PROCEDURE CALL (X : LPT);
PROCEDURE KILL (X : LPT);
FUNCTION TERMINATED (X : LPT) RETURN BOOLEAN;
PRIVATE
TYPE LPT IS NEW TT;
END PKG;
USE PKG;
TYPE ALPT IS ACCESS LPT;
ALP1 : ALPT;
PACKAGE BODY PKG IS
PROCEDURE CALL (X : LPT) IS
BEGIN
X.E;
END CALL;
PROCEDURE KILL (X : LPT) IS
BEGIN
ABORT X;
END KILL;
FUNCTION TERMINATED (X : LPT) RETURN BOOLEAN IS
BEGIN
RETURN X'TERMINATED;
END TERMINATED;
END PKG;
TASK TSK1 IS
ENTRY ENT1 (ALP : OUT ALPT);
ENTRY DIE;
END TSK1;
TASK BODY TSK1 IS
ALP2 : ALPT;
BEGIN
ALP2 := NEW LPT; -- INITIATE TASK ALP2.ALL.
CALL (ALP2.ALL);
ACCEPT ENT1 (ALP : OUT ALPT) DO
ALP := ALP2;
END ENT1;
ACCEPT DIE DO
RAISE MY_EXCEPTION; -- PROPOGATED.
FAILED ("MY_EXCEPTION WAS NOT RAISED IN (D)");
END DIE;
END TSK1;
BEGIN
TSK1.ENT1 (ALP1); -- ALP1.ALL BECOMES ALIAS FOR ALP2.ALL.
TSK1.DIE;
FAILED ("MY_EXCEPTION WAS NOT PROPOGATED TO CALLING " &
"TASK - (D)");
KILL (ALP1.ALL);
ABORT TSK1;
EXCEPTION
WHEN MY_EXCEPTION =>
WHILE NOT TSK1'TERMINATED AND
LOOP_COUNT1 < CUT_OFF1 LOOP
DELAY 1.0 * Impdef.One_Second;
LOOP_COUNT1 := LOOP_COUNT1 + 1;
END LOOP;
IF LOOP_COUNT1 >= CUT_OFF1 THEN
FAILED ("DEPENDENT TASK TSK1 NOT TERMINATED " &
"WITHIN ONE MINUTE - (D)");
END IF;
IF TERMINATED (ALP1.ALL) THEN
FAILED ("ALLOCATED TASK PREMATURELY " &
"TERMINATED - (D)");
ELSE CALL (ALP1.ALL);
END IF;
WHEN OTHERS =>
FAILED ("UNEXPECTED EXCEPTION IN (D)");
IF ALP1 /= NULL THEN
KILL (ALP1.ALL);
END IF;
ABORT TSK1;
END TSK;
BEGIN -- (D)
WHILE NOT TSK'TERMINATED AND LOOP_COUNT < CUT_OFF LOOP
DELAY 2.0 * Impdef.One_Second;
LOOP_COUNT := LOOP_COUNT + 1;
END LOOP;
IF LOOP_COUNT >= CUT_OFF THEN
FAILED ("DEPENDENT TASK TSK NOT TERMINATED WITHIN " &
"TWO MINUTES - (D)");
END IF;
END; -- (D)
--------------------------------------------------
RESULT;
END C94002G;