blob: d4bd2079cb2e61870d9d79fe2f91b108f88e6bac [file] [log] [blame]
-- C940012.A
--
-- 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 protected object can have discriminants
--
-- TEST DESCRIPTION:
-- Use a subset of the simulation of the freeway on-ramp described in
-- c940005. In this case an array of access types is built with pointers
-- to successive ramps. Each ramp has its Ramp_Number specified by
-- discriminant and this corresponds to the index in the array. The test
-- checks that the ramp numbers are assigned as expected then uses calls
-- to procedures within the objects (ramps) to verify external calls to
-- ensure the structures are valid. The external references within the
-- protected objects are made via the index into the array. Routines
-- which refer to the "previous" ramp and the "next" ramp are exercised.
-- (Note: The first and last ramps are assumed to be dummies and no
-- first/last condition code is included)
--
--
-- CHANGE HISTORY:
-- 06 Dec 94 SAIC ACVC 2.0
--
--!
with Report;
procedure C940012 is
type Ramp_Index is range 1..4;
type Ramp;
type a_Ramp is access Ramp;
Ramp_Array : array (Ramp_Index) of a_Ramp;
-- Weighted load given to each potential problem area and accumulated
type Load_Factor is range 0..8;
Clear_Level : constant Load_Factor := 0;
Moderate_Level : constant Load_Factor := 3;
--================================================================
-- Only the Routines that are used in this test are shown
--
protected type Ramp (Ramp_In : Ramp_Index) is
function Ramp_Number return Ramp_Index;
function Local_Overload return Load_Factor;
function Next_Ramp_Overload return Load_Factor;
procedure Set_Local_Overload(Sensor_Level : Load_Factor);
procedure Notify;
private
Next_Ramp_Alert : Boolean := false; -- Next Ramp is in trouble?
-- Current state of the various Sample Points
Local_State : Load_Factor := Clear_Level;
end Ramp;
--================================================================
protected body Ramp is
function Ramp_Number return Ramp_Index is
begin
return Ramp_In;
end Ramp_Number;
-- These Set/Clear routines are triggered by real-time sensors that
-- reflect traffic state
procedure Set_Local_Overload(Sensor_Level : Load_Factor) is
begin
if Local_State = Clear_Level then
-- Notify "previous" ramp to check this one for current state.
-- Subsequent changes in state will not send an alert
-- When the situation clears another routine performs the
-- all_clear notification. (not shown)
Ramp_Array(Ramp_In - 1).Notify; -- index to previous ramp
end if;
Local_State := Sensor_Level;
null; --::::: Start local meter if not already started
end;
function Local_Overload return Load_Factor is
begin
return Local_State;
end Local_Overload;
-- This is notification from the next ramp that it is in
-- overload. With this provision we only need to sample the next
-- ramp during adverse conditions.
procedure Notify is
begin
Next_Ramp_Alert := true;
end Notify;
function Next_Ramp_Overload return Load_Factor is
begin
if Next_Ramp_Alert then
-- Get next ramp's current state
return Ramp_Array(Ramp_In + 1).Local_Overload;
else
return Clear_Level;
end if;
end Next_Ramp_Overload;
end Ramp;
--================================================================
begin
Report.Test ("C940012", "Check that a protected object " &
"can have discriminants");
-- Build the ramps and populate the ramp array
for i in Ramp_Index loop
Ramp_Array(i) := new Ramp (i);
end loop;
-- Test driver. This is ALL test control code
-- Check the assignment of the index
for i in Ramp_Index loop
if Ramp_Array(i).Ramp_Number /= i then
Report.Failed ("Ramp_Number assignment incorrect");
end if;
end loop;
-- Simulate calls to the protected functions and procedures
-- external calls. (do not call the "dummy" end ramps)
-- Simple Call
if Ramp_Array(2).Next_Ramp_Overload /= Clear_level then
Report.Failed ("Primary call incorrect");
end if;
-- Call which results in an external procedure call via the array
-- index from within the protected object
Ramp_Array(3).Set_Local_Overload (Moderate_Level);
-- Call which results in an external function call via the array
-- index from within the protected object
if Ramp_Array(2).Next_Ramp_Overload /= Moderate_level then
Report.Failed ("Secondary call incorrect");
end if;
Report.Result;
end C940012;