sl@0: /* sl@0: * Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies). sl@0: * All rights reserved. sl@0: * This component and the accompanying materials are made available sl@0: * under the terms of "Eclipse Public License v1.0" sl@0: * which accompanies this distribution, and is available sl@0: * at the URL "http://www.eclipse.org/legal/epl-v10.html". sl@0: * sl@0: * Initial Contributors: sl@0: * Nokia Corporation - initial contribution. sl@0: * sl@0: * Contributors: sl@0: * sl@0: * Description: sl@0: * sl@0: */ sl@0: sl@0: sl@0: #include <liboil/liboil.h> sl@0: #include <liboil/liboilfunction.h> sl@0: #include <stdio.h> sl@0: #include <stdlib.h> sl@0: sl@0: #include <liboil/globals.h> sl@0: sl@0: #define LOG_FILE "c:\\logs\\testsuite_composite_log.txt" sl@0: #include "std_log_result.h" sl@0: #define LOG_FILENAME_LINE __FILE__, __LINE__ sl@0: sl@0: #define SIZE 20 sl@0: sl@0: void create_xml(int result) sl@0: { sl@0: if(result) sl@0: assert_failed = 1; sl@0: sl@0: testResultXml("testsuite_composite"); sl@0: close_log_file(); sl@0: } sl@0: sl@0: void test_oil_composite_add_argb() sl@0: { sl@0: uint32_t input[SIZE]; sl@0: uint32_t output[SIZE]; sl@0: int i = 0; sl@0: sl@0: for(i = 0; i< SIZE; i++) sl@0: { sl@0: input[i] = i*10; sl@0: output[i] = i; sl@0: } sl@0: sl@0: oil_composite_add_argb(output, input, SIZE); sl@0: sl@0: for(i = 0; i<SIZE; i++) sl@0: { sl@0: if(output[i] != i+input[i]) sl@0: { sl@0: std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,i+input[i],output[i]); sl@0: assert_failed = 1; sl@0: } sl@0: } sl@0: } sl@0: sl@0: void test_oil_composite_add_argb_const_src() sl@0: { sl@0: uint32_t constant = 50; sl@0: uint32_t output[SIZE]; sl@0: int i = 0; sl@0: sl@0: for(i = 0; i< SIZE; i++) sl@0: { sl@0: output[i] = i; sl@0: } sl@0: sl@0: oil_composite_add_argb_const_src(output, &constant, SIZE); sl@0: sl@0: for(i = 0; i<SIZE; i++) sl@0: { sl@0: if(output[i] != i+constant) sl@0: { sl@0: std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,i+constant,output[i]); sl@0: assert_failed = 1; sl@0: } sl@0: } sl@0: } sl@0: sl@0: void test_oil_composite_add_u8() sl@0: { sl@0: uint8_t input[SIZE]; sl@0: uint8_t output[SIZE]; sl@0: int i = 0; sl@0: sl@0: for(i = 0; i< SIZE; i++) sl@0: { sl@0: input[i] = i*10; sl@0: output[i] = i; sl@0: } sl@0: sl@0: oil_composite_add_u8(output, input, SIZE); sl@0: sl@0: for(i = 0; i<SIZE; i++) sl@0: { sl@0: if(output[i] != i+input[i]) sl@0: { sl@0: std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,i+input[i],output[i]); sl@0: assert_failed = 1; sl@0: } sl@0: } sl@0: } sl@0: sl@0: void test_oil_composite_add_u8_const_src() sl@0: { sl@0: uint8_t constant = 50; sl@0: uint8_t output[SIZE]; sl@0: int i = 0; sl@0: sl@0: for(i = 0; i< SIZE; i++) sl@0: { sl@0: output[i] = i; sl@0: } sl@0: sl@0: oil_composite_add_u8_const_src(output, &constant, SIZE); sl@0: sl@0: for(i = 0; i<SIZE; i++) sl@0: { sl@0: if(output[i] != i+constant) sl@0: { sl@0: std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,i+constant,output[i]); sl@0: assert_failed = 1; sl@0: } sl@0: } sl@0: } sl@0: sl@0: void test_oil_composite_in_argb() sl@0: { sl@0: uint32_t input[SIZE]; sl@0: uint8_t mask[SIZE]; sl@0: uint32_t output[SIZE]; sl@0: int i = 0; sl@0: uint32_t linux_output[] = {0,0,0,0,0,0,0,0,1,1,1,1,1,1,2,2,2,2,3,3}; sl@0: sl@0: for(i = 0; i< SIZE; i++) sl@0: { sl@0: input[i] = i; sl@0: mask[i] = i*2; sl@0: } sl@0: sl@0: oil_composite_in_argb(output, input, mask, SIZE); sl@0: sl@0: for(i = 0; i < SIZE; i++) sl@0: { sl@0: if(output[i] != linux_output[i]) sl@0: { sl@0: std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]); sl@0: assert_failed = 1; sl@0: } sl@0: } sl@0: } sl@0: sl@0: void test_oil_composite_in_argb_const_mask() sl@0: { sl@0: uint32_t input[SIZE]; sl@0: uint8_t constant = 50; sl@0: uint32_t output[SIZE]; sl@0: uint32_t linux_output[] = {0,0,0,1,1,1,1,1,2,2,2,2,2,3,3,3,3,3,4,4}; sl@0: int i = 0; sl@0: sl@0: for(i = 0; i < SIZE; i++) sl@0: { sl@0: input[i] = i; sl@0: } sl@0: sl@0: oil_composite_in_argb_const_mask(output, input, &constant, SIZE); sl@0: sl@0: for(i = 0; i < SIZE; i++) sl@0: { sl@0: if(output[i] != linux_output[i]) sl@0: { sl@0: std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]); sl@0: assert_failed = 1; sl@0: } sl@0: } sl@0: } sl@0: sl@0: void test_oil_composite_in_argb_const_src() sl@0: { sl@0: uint32_t constant = 50; sl@0: uint8_t mask[SIZE]; sl@0: uint32_t output[SIZE]; sl@0: uint32_t linux_output[] = {0,0,1,1,2,2,2,3,3,4,4,4,5,5,5,6,6,7,7,7}; sl@0: int i = 0; sl@0: sl@0: for(i = 0; i< SIZE; i++) sl@0: { sl@0: mask[i] = i*2; sl@0: } sl@0: sl@0: oil_composite_in_argb_const_src(output, &constant, mask, SIZE); sl@0: sl@0: for(i = 0; i < SIZE; i++) sl@0: { sl@0: if(output[i] != linux_output[i]) sl@0: { sl@0: std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]); sl@0: assert_failed = 1; sl@0: } sl@0: } sl@0: } sl@0: sl@0: void test_oil_composite_in_over_argb() sl@0: { sl@0: uint32_t input[SIZE]; sl@0: uint8_t mask[SIZE]; sl@0: uint32_t output[SIZE]; sl@0: uint32_t linux_output[] = {0,10,20,30,40,50,60,70,81,91,101,111,121,131,142,152,162,172,183,193}; sl@0: int i = 0; sl@0: sl@0: for(i = 0; i< SIZE; i++) sl@0: { sl@0: input[i] = i; sl@0: mask[i] = i*2; sl@0: output[i] = i*10; sl@0: } sl@0: sl@0: oil_composite_in_over_argb(output, input, mask, SIZE); sl@0: sl@0: for(i = 0; i < SIZE; i++) sl@0: { sl@0: if(output[i] != linux_output[i]) sl@0: { sl@0: std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]); sl@0: assert_failed = 1; sl@0: } sl@0: } sl@0: } sl@0: sl@0: void test_oil_composite_in_over_argb_const_mask() sl@0: { sl@0: uint32_t input[SIZE]; sl@0: uint8_t constant = 50; sl@0: uint32_t output[SIZE]; sl@0: uint32_t linux_output[] = {0,10,20,31,41,51,61,71,82,92,102,112,122,133,143,153,163,173,184,194}; sl@0: int i = 0; sl@0: sl@0: for(i = 0; i< SIZE; i++) sl@0: { sl@0: input[i] = i; sl@0: output[i] = i*10; sl@0: } sl@0: sl@0: oil_composite_in_over_argb_const_mask(output, input, &constant, SIZE); sl@0: sl@0: for(i = 0; i < SIZE; i++) sl@0: { sl@0: if(output[i] != linux_output[i]) sl@0: { sl@0: std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]); sl@0: assert_failed = 1; sl@0: } sl@0: } sl@0: } sl@0: sl@0: void test_oil_composite_in_over_argb_const_src() sl@0: { sl@0: //uint32_t * i_n, const uint32_t * s1_1, const uint8_t * s2_n, int n sl@0: uint32_t constant = 50; sl@0: uint8_t mask[SIZE]; sl@0: uint32_t output[SIZE]; sl@0: uint32_t linux_output[] = {0,10,21,31,42,52,62,73,83,94,104,114,125,135,145,156,166,177,187,197}; sl@0: int i = 0; sl@0: sl@0: for(i = 0; i< SIZE; i++) sl@0: { sl@0: mask[i] = i*2; sl@0: output[i] = i*10; sl@0: } sl@0: sl@0: oil_composite_in_over_argb_const_src(output, &constant, mask, SIZE); sl@0: sl@0: for(i = 0; i < SIZE; i++) sl@0: { sl@0: if(output[i] != linux_output[i]) sl@0: { sl@0: std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]); sl@0: assert_failed = 1; sl@0: } sl@0: } sl@0: } sl@0: sl@0: void test_oil_composite_over_argb() sl@0: { sl@0: uint32_t input[SIZE]; sl@0: uint32_t output[SIZE]; sl@0: uint32_t linux_output[] = {0,11,22,33,44,55,66,77,88,99,110,121,132,143,154,165,176,187,198,209}; sl@0: int i = 0; sl@0: sl@0: for(i = 0; i< SIZE; i++) sl@0: { sl@0: input[i] = i; sl@0: output[i] = i*10; sl@0: } sl@0: sl@0: oil_composite_over_argb(output, input, SIZE); sl@0: sl@0: for(i = 0; i < SIZE; i++) sl@0: { sl@0: if(output[i] != linux_output[i]) sl@0: { sl@0: std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]); sl@0: assert_failed = 1; sl@0: } sl@0: } sl@0: } sl@0: sl@0: void test_oil_composite_over_argb_const_src() sl@0: { sl@0: uint32_t constant = 50; sl@0: uint32_t output[SIZE]; sl@0: uint32_t linux_output[] = {50,60,70,80,90,100,110,120,130,140,150,160,170,180,190,200,210,220,230,240}; sl@0: int i = 0; sl@0: sl@0: for(i = 0; i< SIZE; i++) sl@0: { sl@0: output[i] = i*10; sl@0: } sl@0: sl@0: oil_composite_over_argb_const_src(output, &constant, SIZE); sl@0: sl@0: for(i = 0; i < SIZE; i++) sl@0: { sl@0: if(output[i] != linux_output[i]) sl@0: { sl@0: std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]); sl@0: assert_failed = 1; sl@0: } sl@0: } sl@0: } sl@0: sl@0: void test_oil_composite_over_u8() sl@0: { sl@0: uint8_t input[SIZE]; sl@0: uint8_t output[SIZE]; sl@0: uint32_t linux_output[] = {0,11,22,33,43,54,65,75,85,96,106,116,126,136,146,156,166,176,185,195}; sl@0: int i = 0; sl@0: sl@0: for(i = 0; i< SIZE; i++) sl@0: { sl@0: input[i] = i; sl@0: output[i] = i*10; sl@0: } sl@0: sl@0: oil_composite_over_u8(output, input, SIZE); sl@0: sl@0: for(i = 0; i < SIZE; i++) sl@0: { sl@0: if(output[i] != linux_output[i]) sl@0: { sl@0: std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]); sl@0: assert_failed = 1; sl@0: } sl@0: } sl@0: } sl@0: sl@0: int main (int argc, char *argv[]) sl@0: { sl@0: oil_init(); sl@0: sl@0: std_log(LOG_FILENAME_LINE,"START oil_composite_add_argb TEST"); sl@0: test_oil_composite_add_argb(); sl@0: std_log(LOG_FILENAME_LINE,"END TEST"); sl@0: sl@0: std_log(LOG_FILENAME_LINE,"START oil_composite_add_argb_const_src TEST"); sl@0: test_oil_composite_add_argb_const_src(); sl@0: std_log(LOG_FILENAME_LINE,"END TEST"); sl@0: sl@0: std_log(LOG_FILENAME_LINE,"START oil_composite_add_u8 TEST"); sl@0: test_oil_composite_add_u8(); sl@0: std_log(LOG_FILENAME_LINE,"END TEST"); sl@0: sl@0: std_log(LOG_FILENAME_LINE,"START oil_composite_add_u8_const_src TEST"); sl@0: test_oil_composite_add_u8_const_src(); sl@0: std_log(LOG_FILENAME_LINE,"END TEST"); sl@0: sl@0: std_log(LOG_FILENAME_LINE,"START oil_composite_in_argb TEST"); sl@0: test_oil_composite_in_argb(); sl@0: std_log(LOG_FILENAME_LINE,"END TEST"); sl@0: sl@0: std_log(LOG_FILENAME_LINE,"START oil_composite_in_argb_const_mask TEST"); sl@0: test_oil_composite_in_argb_const_mask(); sl@0: std_log(LOG_FILENAME_LINE,"END TEST"); sl@0: sl@0: std_log(LOG_FILENAME_LINE,"START oil_composite_in_argb_const_src TEST"); sl@0: test_oil_composite_in_argb_const_src(); sl@0: std_log(LOG_FILENAME_LINE,"END TEST"); sl@0: sl@0: std_log(LOG_FILENAME_LINE,"START oil_composite_in_over_argb TEST"); sl@0: test_oil_composite_in_over_argb(); sl@0: std_log(LOG_FILENAME_LINE,"END TEST"); sl@0: sl@0: std_log(LOG_FILENAME_LINE,"START oil_composite_in_over_argb_const_mask TEST"); sl@0: test_oil_composite_in_over_argb_const_mask(); sl@0: std_log(LOG_FILENAME_LINE,"END TEST"); sl@0: sl@0: std_log(LOG_FILENAME_LINE,"START oil_composite_add_argb TEST"); sl@0: test_oil_composite_in_over_argb_const_src(); sl@0: std_log(LOG_FILENAME_LINE,"END TEST"); sl@0: sl@0: std_log(LOG_FILENAME_LINE,"START oil_composite_over_argb TEST"); sl@0: test_oil_composite_over_argb(); sl@0: std_log(LOG_FILENAME_LINE,"END TEST"); sl@0: sl@0: std_log(LOG_FILENAME_LINE,"START oil_composite_over_argb_const_src TEST"); sl@0: test_oil_composite_over_argb_const_src(); sl@0: std_log(LOG_FILENAME_LINE,"END TEST"); sl@0: sl@0: std_log(LOG_FILENAME_LINE,"START oil_composite_over_u8 TEST"); sl@0: test_oil_composite_over_u8(); sl@0: std_log(LOG_FILENAME_LINE,"END TEST"); sl@0: sl@0: if(assert_failed) sl@0: std_log(LOG_FILENAME_LINE,"Test Failed"); sl@0: else sl@0: std_log(LOG_FILENAME_LINE,"Test Successful"); sl@0: create_xml(0); sl@0: return 0; sl@0: } sl@0: