X-Git-Url: http://review.tizen.org/git/?p=platform%2Fcore%2Fuifw%2Fdali-toolkit.git;a=blobdiff_plain;f=automated-tests%2Fsrc%2Fdali-toolkit%2Futc-Dali-Builder.cpp;h=77439d4c809dd2d14be08be48310b3638e95dd39;hp=511d2ef7495d470b44187cde2458ff2e425bc999;hb=3fe7030fe503879c909bf28c4a953fd19fee2a3b;hpb=ce9ca5f372bb0b1880bcec297c4b0482c54145d9 diff --git a/automated-tests/src/dali-toolkit/utc-Dali-Builder.cpp b/automated-tests/src/dali-toolkit/utc-Dali-Builder.cpp index 511d2ef..77439d4 100644 --- a/automated-tests/src/dali-toolkit/utc-Dali-Builder.cpp +++ b/automated-tests/src/dali-toolkit/utc-Dali-Builder.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017 Samsung Electronics Co., Ltd. + * Copyright (c) 2018 Samsung Electronics Co., Ltd. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -16,14 +16,20 @@ */ #include -#include +#include +#include +#include +#include + #include #include +#include #include #include #include #include + #define STRINGIFY(A)#A using namespace Dali; @@ -1851,3 +1857,256 @@ int UtcDaliBuilderConfigurationP(void) END_TEST; } + + +int UtcDaliBase64EncodingP(void) +{ + std::vector data = { 0, 1, 2, 3, 4, 5, std::numeric_limits::min(), std::numeric_limits::max() }; + + Property::Value value; + EncodeBase64PropertyData( value, data ); + + std::cout << "Max uint32_t:" << std::numeric_limits::max() << std::endl; + std::cout << "Input data: "; + std::ostream_iterator out_it (std::cout,", "); + std::copy ( data.begin(), data.end(), out_it ); + std::cout << std::endl; + + std::string output; + DALI_TEST_CHECK( value.Get( output ) ); + DALI_TEST_EQUALS( output, "AAAAAAEAAAACAAAAAwAAAAQAAAAFAAAAAAAAAP////8", TEST_LOCATION ); + + std::cout << "Output data: " << output << std::endl; + + END_TEST; +} + +int UtcDaliBase64EncodingN(void) +{ + tet_infoline( "Test encoding an empty vector returns empty string" ); + std::vector data; + + Property::Value value; + EncodeBase64PropertyData( value, data ); + + std::string output; + DALI_TEST_CHECK( value.Get( output ) ); + DALI_TEST_EQUALS( output.empty(), true, TEST_LOCATION ); + + END_TEST; +} + +template +int b64l(std::vector&data) +{ + auto lengthInBytes = 4*data.size(); + return ceil( lengthInBytes * 1.33333f ); +} + +int UtcDaliBase64EncodingP02(void) +{ + tet_infoline( "Test encoding vectors of lengths m .. m+4 encode and decode back to the same length vectors" ); + + std::vector testData; + for(int i=0; i<8; ++i ) // 8 chosen to stay within single string output + { + testData.push_back(i); + } + Property::Value value; + EncodeBase64PropertyData( value, testData ); + + std::string output; + DALI_TEST_CHECK( value.Get( output ) ); + DALI_TEST_EQUALS( output.empty(), false, TEST_LOCATION); + DALI_TEST_EQUALS( output.length(), b64l(testData), TEST_LOCATION ); + + std::vector outData; + DecodeBase64PropertyData( value, outData ); + DALI_TEST_EQUALS( testData.size(), outData.size(), TEST_LOCATION ); + DALI_TEST_EQUALS( std::equal( testData.begin(), testData.end(), outData.begin()), true, TEST_LOCATION ); + + // n+1 + testData.push_back( 12345 ); + EncodeBase64PropertyData( value, testData ); + + DALI_TEST_CHECK( value.Get( output ) ); + DALI_TEST_EQUALS( output.empty(), false, TEST_LOCATION); + DALI_TEST_EQUALS( output.length(), b64l(testData), TEST_LOCATION ); + + outData.clear(); + DecodeBase64PropertyData( value, outData ); + DALI_TEST_EQUALS( testData.size(), outData.size(), TEST_LOCATION ); + DALI_TEST_EQUALS( std::equal( testData.begin(), testData.end(), outData.begin()), true, TEST_LOCATION ); + + // n+2 + testData.push_back( 67890 ); + EncodeBase64PropertyData( value, testData ); + + DALI_TEST_CHECK( value.Get( output ) ); + DALI_TEST_EQUALS( output.empty(), false, TEST_LOCATION); + DALI_TEST_EQUALS( output.length(), b64l(testData), TEST_LOCATION ); + + outData.clear(); + DecodeBase64PropertyData( value, outData ); + DALI_TEST_EQUALS( testData.size(), outData.size(), TEST_LOCATION ); + DALI_TEST_EQUALS( std::equal( testData.begin(), testData.end(), outData.begin()), true, TEST_LOCATION ); + + // n+3 + testData.push_back( -1 ); + EncodeBase64PropertyData( value, testData ); + + DALI_TEST_CHECK( value.Get( output ) ); + DALI_TEST_EQUALS( output.empty(), false, TEST_LOCATION); + DALI_TEST_EQUALS( output.length(), b64l(testData), TEST_LOCATION ); + + outData.clear(); + DecodeBase64PropertyData( value, outData ); + DALI_TEST_EQUALS( testData.size(), outData.size(), TEST_LOCATION ); + DALI_TEST_EQUALS( std::equal( testData.begin(), testData.end(), outData.begin()), true, TEST_LOCATION ); + + + END_TEST; +} + + +int UtcDaliBase64EncodingP03(void) +{ + tet_infoline( "Test encoding a vector of length 12 has output within single string" ); + + std::vector testData; + for(int i=0; i<12; ++i ) + { + testData.push_back(i); + } + Property::Value value; + EncodeBase64PropertyData( value, testData ); + + std::string output; + DALI_TEST_CHECK( value.Get( output ) ); + DALI_TEST_EQUALS( output.empty(), false, TEST_LOCATION); + DALI_TEST_EQUALS( output.length(), b64l(testData), TEST_LOCATION ); + + std::vector outData; + DecodeBase64PropertyData( value, outData ); + DALI_TEST_EQUALS( testData.size(), outData.size(), TEST_LOCATION ); + + END_TEST; +} + + +int UtcDaliBase64EncodingP04(void) +{ + tet_infoline( "Test encoding a vector of length 13 has output split over 2 strings" ); + + std::vector testData; + for(int i=0; i<13; ++i ) + { + testData.push_back(i); + } + Property::Value value; + EncodeBase64PropertyData( value, testData ); + + auto array = value.GetArray(); + DALI_TEST_CHECK( array ); + + DALI_TEST_EQUALS( array->Count(), 2, TEST_LOCATION ); + + std::vector outData; + DecodeBase64PropertyData( value, outData ); + DALI_TEST_EQUALS( testData.size(), outData.size(), TEST_LOCATION ); + + END_TEST; +} + + +int UtcDaliBase64EncodingP05(void) +{ + tet_infoline( "Test encoding a vector of length 24 has output split over 2 strings" ); + + std::vector testData; + for(int i=0; i<24; ++i ) + { + testData.push_back(i); + } + Property::Value value; + EncodeBase64PropertyData( value, testData ); + + auto array = value.GetArray(); + DALI_TEST_CHECK( array ); + + DALI_TEST_EQUALS( array->Count(), 2, TEST_LOCATION ); + + std::vector outData; + DecodeBase64PropertyData( value, outData ); + DALI_TEST_EQUALS( testData.size(), outData.size(), TEST_LOCATION ); + + END_TEST; +} + + +int UtcDaliBase64EncodingP06(void) +{ + tet_infoline( "Test encoding a vector of arbitrary length decodes OK." ); + + std::vector testData; + for(int i=0; i<97; ++i ) + { + testData.push_back(i); + } + Property::Value value; + EncodeBase64PropertyData( value, testData ); + + auto array = value.GetArray(); + DALI_TEST_CHECK( array ); + + std::vector outData; + DecodeBase64PropertyData( value, outData ); + DALI_TEST_EQUALS( testData.size(), outData.size(), TEST_LOCATION ); + + END_TEST; +} + + +int UtcDaliBase64DecodingN01(void) +{ + tet_infoline( "Test decoding empty string results in empty data" ); + + Property::Value value(""); + std::vector outputData; + DecodeBase64PropertyData( value, outputData); + DALI_TEST_EQUALS( outputData.size(), 0, TEST_LOCATION ); + END_TEST; +} + + +int UtcDaliBase64DecodingN02(void) +{ + tet_infoline( "Test decoding array with non-string values results in empty data" ); + + Property::Array array; + array.Resize(2); + array[0] = "Stuff, things"; + array[1] = 1; + Property::Value value(array); + + std::vector outputData; + DecodeBase64PropertyData( value, outputData); + DALI_TEST_EQUALS( outputData.size(), 0, TEST_LOCATION ); + END_TEST; +} + +int UtcDaliBase64DecodingP01(void) +{ + tet_infoline( "Test decoding string of known data gives expected result"); + + std::string testInput("//////7+/v4DAgEA"); + std::vector expectedResults = { 0xffffffff, 0xfefefefe, 0x00010203 }; + + std::vector outputData; + DecodeBase64PropertyData(Property::Value(testInput), outputData); + + DALI_TEST_EQUALS( std::equal( expectedResults.begin(), expectedResults.end(), outputData.begin() ), true, + TEST_LOCATION ); + + END_TEST; +}