1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95
|
------------------------------------------------------------------------------
-- Ada Web Server --
-- --
-- Copyright (C) 2008-2012, AdaCore --
-- --
-- This is free software; you can redistribute it and/or modify it --
-- under terms of the GNU General Public License as published by the --
-- Free Software Foundation; either version 3, or (at your option) any --
-- later version. This software is distributed in the hope that it will --
-- be useful, but WITHOUT ANY WARRANTY; without even the implied warranty --
-- of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU --
-- General Public License for more details. --
-- --
-- You should have received a copy of the GNU General Public License --
-- distributed with this software; see file COPYING3. If not, go --
-- to http://www.gnu.org/licenses for a complete copy of the license. --
------------------------------------------------------------------------------
with Ada.Calendar;
with Ada.Exceptions;
with Ada.Text_IO;
with AWS.Client;
with R_Hello_Timeout_Demo.Client;
with R_Hello_Timeout_Demo.Server;
procedure Test_SOAP_Timeout is
use Ada;
use Ada.Exceptions;
use AWS;
procedure Start_Time;
-- Record starting time
procedure Stop_Time;
-- Record ending time
procedure Check_Duration (D : Duration; Message : String);
-- Check that duration is about D seconds
Start, Stop : Calendar.Time;
--------------------
-- Check_Duration --
--------------------
procedure Check_Duration (D : Duration; Message : String) is
use type Calendar.Time;
Elaps : constant Duration := Stop - Start - D;
begin
if abs (Elaps) < 1.0 then
Text_IO.Put_Line ("OK:" & Message);
else
Text_IO.Put_Line ("NOK:" & Message & ", " & Duration'Image (Elaps));
end if;
end Check_Duration;
----------------
-- Start_Time --
----------------
procedure Start_Time is
begin
Start := Calendar.Clock;
end Start_Time;
---------------
-- Stop_Time --
---------------
procedure Stop_Time is
begin
Stop := Calendar.Clock;
end Stop_Time;
begin
Start_Time;
declare
R : constant String := R_Hello_Timeout_Demo.Client.sayHello
("pascal",
Endpoint => "http://www.google.com:9856",
Timeouts => Client.Timeouts
(Connect => 4.0, Send => 2.0, Receive => 1.0));
begin
Text_IO.Put_Line ("Result: '" & R & ''');
end;
exception
when E : others =>
Stop_Time;
Check_Duration (4.0, "SOAP");
Text_IO.Put_Line ("Exception: " & Exception_Name (E));
Text_IO.Put_Line ("Exception: " & Exception_Message (E));
end Test_SOAP_Timeout;
|