Test suite results for test file test/tmove.pp

Test run data :

Free Pascal Compiler Test Suite Results

View Test suite results

Please specify search criteria:
File:
Operating system:
Processor:
Version
Date
Submitter
Machine
Comment
Limit
Cond
Category
Only failed tests
Hide skipped tests
List all tests

Test file "test/tmove.pp" information:

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

Detailed test run results:

Record count: 50

Total = 50

OK=50 Percentage= 100.00

Result type Cat. Count Percentage First date Last Date
Successfully run 50 100.0 2024/06/02 01:36:00 47 2024/06/02 06:26:00 40
i386 8 16.0 2024/06/02 01:36:00 47 2024/06/02 06:02:00 0
m68k 1 2.0 2024/06/02 05:48:00 63 2024/06/02 05:48:00 63
sparc 5 10.0 2024/06/02 03:07:00 41 2024/06/02 05:32:00 44
arm 1 2.0 2024/06/02 05:51:00 67 2024/06/02 05:51:00 67
x86_64 19 38.0 2024/06/02 01:57:00 22 2024/06/02 06:26:00 40
powerpc64 4 8.0 2024/06/02 04:15:00 53 2024/06/02 04:32:00 57
mips 2 4.0 2024/06/02 04:00:00 47 2024/06/02 05:58:00 243
mipsel 1 2.0 2024/06/02 04:06:00 185 2024/06/02 04:06:00 185
aarch64 7 14.0 2024/06/02 01:46:00 39 2024/06/02 05:56:00 30
sparc64 1 2.0 2024/06/02 05:03:00 157 2024/06/02 05:03:00 157
riscv64 1 2.0 2024/06/02 04:39:00 31 2024/06/02 04:39:00 31
linux 38 76.0 2024/06/02 01:36:00 47 2024/06/02 05:59:00 27
win32 1 2.0 2024/06/02 06:02:00 0 2024/06/02 06:02:00 0
go32v2 2 4.0 2024/06/02 04:24:00 56 2024/06/02 05:03:00 55
solaris 6 12.0 2024/06/02 03:07:00 41 2024/06/02 06:26:00 40
darwin 3 6.0 2024/06/02 05:42:00 24 2024/06/02 05:56:00 30
3.3.1 20 40.0 2024/06/02 01:46:00 39 2024/06/02 06:26:00 40
3.2.3 30 60.0 2024/06/02 01:36:00 47 2024/06/02 06:02:00 0

Source:

const
  err: boolean = false;

var
  a, b: array[0..512] of byte;
      
procedure test_forward_move;
var
  i, j, k: longint;   
  l: longint;
begin
  for i := 0 to 512 do
    begin
      a[i] := byte(i);
      b[i] := 0;
    end;
  for i := 0 to 256 do
    for j := 0 to 31 do
      for k := 0 to 31 do
        begin
          move(a[j],b[k+4],i);
          { check whether we didn't write a byte too early }
          for l := 0 to k+3 do
            begin
              if b[l] <> 0 then
                begin
                  writeln('Forward test error 1');
                  err := true;
                  halt(1);
                end;
              b[l] := 0;
            end;
          { check whether the actual values were copied correctly }
          for l := k+4 to k+i+3 do
            begin
              if b[l] <> a[j+l-(k+4)] then
                begin
                  writeln('Forward test error 2');
                  err := true;
                  halt(1);
                end;
              b[l] := 0;
            end;
          { check whether we didn't write past the end }
          for l := k+i+4 to 512 do
            begin
              if b[l] <> 0 then
                begin
                  writeln('Forward test error 3');
                  err := true;
                  halt(1);
                end;
              b[l] := 0;
            end;
        end;
end;


procedure test_backward_move;
var
  i, j, k: longint;   
  l: longint;
begin
  for i := 0 to 128 do
    begin
      for j := 0 to 31 do
        for k := 0 to 31 do
          begin
            for l := 0 to 255 do
              begin
                a[l] := l;
              end;

            move(a[127-j],a[127-j-k],i);
            { check whether we didn't write a byte too early }
            for l := 0 to 127-j-k-1 do
              begin
                if a[l] <> l then
                  begin
                    writeln('Backward test error 1');
                    err := true;
                    halt(1);
                  end;
              end;
            { check whether the actual values were copied correctly }
            for l := 127-j-k to 127-j-k+i-1 do
              begin
                if a[l] <> l+k then
                  begin
                    writeln('Backward test error 2');
                    err := true;
                    halt(1);
                 end;
              end;
            { check whether we didn't write past the end }
            for l := 127-j-k+i to 255 do
              begin
                if a[l] <> l then
                  begin
                    writeln('Backward test error 3');
                    err := true;
                    halt(1);
                  end;
              end;
          end;
    end;
end;


begin
  test_forward_move;
  test_backward_move;
  if err then
    halt(1);
end.

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