genericopenlibs/liboil/tsrc/testsuite/liboiltest/src/liboiltest.c
author hgs
Wed, 13 Oct 2010 19:39:18 +0530
changeset 71 28ccaba883f4
permissions -rw-r--r--
201039
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/liboiltest.h>
hgs
parents:
diff changeset
    21
#include <liboil/liboilfunction.h>
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_liboiltest_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_liboiltest");
hgs
parents:
diff changeset
    39
    close_log_file();
hgs
parents:
diff changeset
    40
}
hgs
parents:
diff changeset
    41
hgs
parents:
diff changeset
    42
void abs_f32_f32_test(float * dest, int dstr, const float * src, int sstr, int n)
hgs
parents:
diff changeset
    43
    {
hgs
parents:
diff changeset
    44
    int i = 0;
hgs
parents:
diff changeset
    45
    std_log(LOG_FILENAME_LINE,"abs_f32_f32_test is called");
hgs
parents:
diff changeset
    46
    assert_failed = 0;
hgs
parents:
diff changeset
    47
    
hgs
parents:
diff changeset
    48
    for(i=0; i<SIZE; i++)
hgs
parents:
diff changeset
    49
        dest[i] = 10;
hgs
parents:
diff changeset
    50
    }
hgs
parents:
diff changeset
    51
hgs
parents:
diff changeset
    52
void test()
hgs
parents:
diff changeset
    53
    {
hgs
parents:
diff changeset
    54
    OilTest *test;
hgs
parents:
diff changeset
    55
    OilParameter *p;
hgs
parents:
diff changeset
    56
    int16_t *data;
hgs
parents:
diff changeset
    57
    int n;
hgs
parents:
diff changeset
    58
    int footer;
hgs
parents:
diff changeset
    59
    int footer_increment = 10;
hgs
parents:
diff changeset
    60
    OilFunctionClass *klass;
hgs
parents:
diff changeset
    61
    OilFunctionImpl *impl;
hgs
parents:
diff changeset
    62
    
hgs
parents:
diff changeset
    63
    klass = oil_class_get("abs_f32_f32");
hgs
parents:
diff changeset
    64
    
hgs
parents:
diff changeset
    65
    if(klass != NULL)
hgs
parents:
diff changeset
    66
        {
hgs
parents:
diff changeset
    67
        test = (OilTest *)oil_test_new(klass); 
hgs
parents:
diff changeset
    68
        
hgs
parents:
diff changeset
    69
        if(test != NULL)
hgs
parents:
diff changeset
    70
            {
hgs
parents:
diff changeset
    71
            impl = (OilFunctionImpl*)calloc(sizeof(OilFunctionImpl), 0);
hgs
parents:
diff changeset
    72
            impl->func = (void*)abs_f32_f32_test;
hgs
parents:
diff changeset
    73
            impl->name = "abs_f32_f32_test";
hgs
parents:
diff changeset
    74
            impl->klass = klass;
hgs
parents:
diff changeset
    75
            
hgs
parents:
diff changeset
    76
            oil_test_set_impl(test, impl);
hgs
parents:
diff changeset
    77
            
hgs
parents:
diff changeset
    78
            if(test->impl != impl)
hgs
parents:
diff changeset
    79
                {
hgs
parents:
diff changeset
    80
                std_log(LOG_FILENAME_LINE,"oil_test_set_impl failed. errno = %d", errno);
hgs
parents:
diff changeset
    81
                assert_failed = 1;
hgs
parents:
diff changeset
    82
                }
hgs
parents:
diff changeset
    83
            
hgs
parents:
diff changeset
    84
            p = &test->params[1];
hgs
parents:
diff changeset
    85
            footer = p->test_footer;
hgs
parents:
diff changeset
    86
            oil_test_set_test_footer(test, p, OIL_TEST_FOOTER+footer_increment);
hgs
parents:
diff changeset
    87
            
hgs
parents:
diff changeset
    88
            if(p->test_footer != footer+footer_increment)
hgs
parents:
diff changeset
    89
                {
hgs
parents:
diff changeset
    90
                std_log(LOG_FILENAME_LINE,"oil_test_set_test_footer failed. errno = %d", errno);
hgs
parents:
diff changeset
    91
                assert_failed = 1;
hgs
parents:
diff changeset
    92
                }
hgs
parents:
diff changeset
    93
            
hgs
parents:
diff changeset
    94
            data = (int16_t *)oil_test_get_source_data (test, OIL_ARG_SRC1);
hgs
parents:
diff changeset
    95
            n = oil_test_get_arg_pre_n (test, OIL_ARG_SRC1);
hgs
parents:
diff changeset
    96
            
hgs
parents:
diff changeset
    97
            oil_test_cleanup(test);
hgs
parents:
diff changeset
    98
            oil_test_free(test);
hgs
parents:
diff changeset
    99
            }
hgs
parents:
diff changeset
   100
        else
hgs
parents:
diff changeset
   101
            {
hgs
parents:
diff changeset
   102
            std_log(LOG_FILENAME_LINE,"oil_test_new returned NULL. errno = %d", errno);
hgs
parents:
diff changeset
   103
            assert_failed = 1;
hgs
parents:
diff changeset
   104
            }
hgs
parents:
diff changeset
   105
        }
hgs
parents:
diff changeset
   106
    else
hgs
parents:
diff changeset
   107
        {
hgs
parents:
diff changeset
   108
        std_log(LOG_FILENAME_LINE,"oil_class_get returned NULL. errno = %d", errno);
hgs
parents:
diff changeset
   109
        assert_failed = 1;
hgs
parents:
diff changeset
   110
        }
hgs
parents:
diff changeset
   111
    }
hgs
parents:
diff changeset
   112
hgs
parents:
diff changeset
   113
int main (int argc, char *argv[])
hgs
parents:
diff changeset
   114
{
hgs
parents:
diff changeset
   115
    oil_init ();
hgs
parents:
diff changeset
   116
 
hgs
parents:
diff changeset
   117
    test();
hgs
parents:
diff changeset
   118
    
hgs
parents:
diff changeset
   119
    if(assert_failed)
hgs
parents:
diff changeset
   120
      std_log(LOG_FILENAME_LINE,"Test Failed");
hgs
parents:
diff changeset
   121
    else
hgs
parents:
diff changeset
   122
      std_log(LOG_FILENAME_LINE,"Test Successful");
hgs
parents:
diff changeset
   123
    
hgs
parents:
diff changeset
   124
    create_xml(0);
hgs
parents:
diff changeset
   125
    return 0;
hgs
parents:
diff changeset
   126
}
hgs
parents:
diff changeset
   127