Test suite results for test file test/tstack.pp

Test run data :

Run ID:
Operating system: linux
Processor: mips
Version: 3.3.1
Fails/OK/Total: 49/9162/9211
Version: 3.3.1
Full version: 3.3.1-15675-g485b31de215
Comment: -Fl/usr/lib/gcc/mips-linux-gnu/8 -k-m -kelf32btsmip -Fl/usr/lib/gcc/mips-linux-gnu/8 -Fl/usr/lib32 -Fl/lib32 -Fl/usr/lib/mips-linux-gnu -O2 -Fd
Machine: cfarm230
Category: 1
SVN revisions: 9b1861a1049:d6cf3c98d0e:e657d6a07df:485b31de215
Submitter: muller
Date: 2024/05/08 16:39:00 <> 2024/05/06
Previous run: 944872
Next run: 954182

Hide skipped tests

Hide successful tests

Test file "test/tstack.pp" information:

t_id 84
t_adddate 2003/10/03
t_result 0
t_knownrunerror 0

Detailed test run results:

tr_idruntr_oktr_skiptr_result
525600586948213TrueFalseSuccessfully run

Record count: 1

No log of 948213.

Source:

{$S+}

{ Program to check that an infinite recursion
  does generate a RTE ... }

{$R-}
{ make that recursion really infinite 
  needs that range check is disabled }

const 
  level : longint = 0;

function inf_rec(x : longint) : longint;

begin
  inc(level);
  inf_rec:=x+inf_rec(x-1);
end;


const
  saveexit : pointer = nil;
  x : longint = 0;

procedure stack_check_exit;

begin
  exitproc:=saveexit;
  if errorcode<>0 then
    begin
      Writeln('An error occured at level ',level);
      if errorcode=202 then
        begin
          Writeln('Stack overflow correctly handled');
          erroraddr:=nil;
          errorcode:=0;
          exitcode:=0;
        end
      else if errorcode=216 then
        begin
          Writeln('RTL returns an RTE 216 on stack overflow');
          Writeln('Not perfect, but acceptable');
          erroraddr:=nil;
          errorcode:=0;
          exitcode:=0;
        end;
    end
  else
    begin
      exitcode:=1;
      errorcode:=1;
    end;
  exitproc:=saveexit;
end;

begin
  saveexit:=exitproc;
  exitproc:=@stack_check_exit;
  x:=inf_rec(5000);
end. 

Link to SVN view of test/tstack.pp source.