genericopenlibs/liboil/tsrc/testsuite/random/src/random.c
author hgs
Thu, 14 Oct 2010 14:15:50 +0530
changeset 72 403e7f6ed6c5
parent 71 28ccaba883f4
permissions -rw-r--r--
201041
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
71
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description: 
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
#include <liboil/liboil.h>
hgs
parents:
diff changeset
    20
#include <liboil/liboilfunction.h>
72
hgs
parents: 71
diff changeset
    21
#include <liboil/liboilrandom.h>
71
hgs
parents:
diff changeset
    22
#include <stdio.h>
hgs
parents:
diff changeset
    23
#include <stdlib.h>
hgs
parents:
diff changeset
    24
hgs
parents:
diff changeset
    25
#include <liboil/globals.h>
hgs
parents:
diff changeset
    26
hgs
parents:
diff changeset
    27
#define LOG_FILE "c:\\logs\\testsuite_random_log.txt"
hgs
parents:
diff changeset
    28
#include "std_log_result.h"
hgs
parents:
diff changeset
    29
#define LOG_FILENAME_LINE __FILE__, __LINE__
hgs
parents:
diff changeset
    30
hgs
parents:
diff changeset
    31
#define SIZE    20
hgs
parents:
diff changeset
    32
hgs
parents:
diff changeset
    33
void create_xml(int result)
hgs
parents:
diff changeset
    34
{
hgs
parents:
diff changeset
    35
    if(result)
hgs
parents:
diff changeset
    36
        assert_failed = 1;
hgs
parents:
diff changeset
    37
    
hgs
parents:
diff changeset
    38
    testResultXml("testsuite_random");
hgs
parents:
diff changeset
    39
    close_log_file();
hgs
parents:
diff changeset
    40
}
hgs
parents:
diff changeset
    41
hgs
parents:
diff changeset
    42
void test_oil_random_s64()
hgs
parents:
diff changeset
    43
    {
hgs
parents:
diff changeset
    44
    int i = 0;
hgs
parents:
diff changeset
    45
    int pos = SIZE;
hgs
parents:
diff changeset
    46
    
hgs
parents:
diff changeset
    47
    oil_type_s64 output1[SIZE];
hgs
parents:
diff changeset
    48
    oil_type_s64 output2[SIZE];
hgs
parents:
diff changeset
    49
    
hgs
parents:
diff changeset
    50
    oil_random_s64(output1, SIZE);
hgs
parents:
diff changeset
    51
    oil_random_s64(output2, SIZE);
hgs
parents:
diff changeset
    52
    
hgs
parents:
diff changeset
    53
    for(i=0; i<SIZE; i++)
hgs
parents:
diff changeset
    54
        {
hgs
parents:
diff changeset
    55
        if(output1[i] != output2[i])
hgs
parents:
diff changeset
    56
            pos = i;
hgs
parents:
diff changeset
    57
        }
hgs
parents:
diff changeset
    58
    
hgs
parents:
diff changeset
    59
    if(pos == SIZE)
hgs
parents:
diff changeset
    60
        {
hgs
parents:
diff changeset
    61
        std_log(LOG_FILENAME_LINE,"oil_random_s64 returns same array everytime");
hgs
parents:
diff changeset
    62
        assert_failed = 1;
hgs
parents:
diff changeset
    63
        }
hgs
parents:
diff changeset
    64
    }
hgs
parents:
diff changeset
    65
hgs
parents:
diff changeset
    66
void test_oil_random_u64()
hgs
parents:
diff changeset
    67
    {
hgs
parents:
diff changeset
    68
    int i = 0;
hgs
parents:
diff changeset
    69
    int pos = SIZE;
hgs
parents:
diff changeset
    70
    
hgs
parents:
diff changeset
    71
    oil_type_u64 output1[SIZE];
hgs
parents:
diff changeset
    72
    oil_type_u64 output2[SIZE];
hgs
parents:
diff changeset
    73
    
hgs
parents:
diff changeset
    74
    oil_random_u64(output1, SIZE);
hgs
parents:
diff changeset
    75
    oil_random_u64(output2, SIZE);
hgs
parents:
diff changeset
    76
    
hgs
parents:
diff changeset
    77
    for(i=0; i<SIZE; i++)
hgs
parents:
diff changeset
    78
        {
hgs
parents:
diff changeset
    79
        if(output1[i] != output2[i])
hgs
parents:
diff changeset
    80
            pos = i;
hgs
parents:
diff changeset
    81
        }
hgs
parents:
diff changeset
    82
    
hgs
parents:
diff changeset
    83
    if(pos == SIZE)
hgs
parents:
diff changeset
    84
        {
hgs
parents:
diff changeset
    85
        std_log(LOG_FILENAME_LINE,"oil_random_s64 returns same array everytime");
hgs
parents:
diff changeset
    86
        assert_failed = 1;
hgs
parents:
diff changeset
    87
        }
hgs
parents:
diff changeset
    88
    }
hgs
parents:
diff changeset
    89
hgs
parents:
diff changeset
    90
int main (int argc, char *argv[])
hgs
parents:
diff changeset
    91
{
hgs
parents:
diff changeset
    92
  oil_init ();
hgs
parents:
diff changeset
    93
hgs
parents:
diff changeset
    94
  test_oil_random_s64();
hgs
parents:
diff changeset
    95
  test_oil_random_u64();
hgs
parents:
diff changeset
    96
  
hgs
parents:
diff changeset
    97
  if(assert_failed)
hgs
parents:
diff changeset
    98
      std_log(LOG_FILENAME_LINE,"Test Failed");
hgs
parents:
diff changeset
    99
  else
hgs
parents:
diff changeset
   100
      std_log(LOG_FILENAME_LINE,"Test Successful");
hgs
parents:
diff changeset
   101
hgs
parents:
diff changeset
   102
  create_xml(0);
hgs
parents:
diff changeset
   103
  return 0;
hgs
parents:
diff changeset
   104
}
hgs
parents:
diff changeset
   105