X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=automated-tests%2Fsrc%2Fdali-toolkit%2Futc-Dali-ShaderEffects.cpp;h=01926d461fa3a180590951e34eb5e2d77ff66954;hb=c41dd692678d095817e4bf528d926cc9e1b12a92;hp=cc5195da83451639daa207dd8ab87cebc0180f6d;hpb=763bfa8baa1a2aefd4e0f7e6a0e1b6c27ac6e0a6;p=platform%2Fcore%2Fuifw%2Fdali-toolkit.git diff --git a/automated-tests/src/dali-toolkit/utc-Dali-ShaderEffects.cpp b/automated-tests/src/dali-toolkit/utc-Dali-ShaderEffects.cpp index cc5195d..01926d4 100644 --- a/automated-tests/src/dali-toolkit/utc-Dali-ShaderEffects.cpp +++ b/automated-tests/src/dali-toolkit/utc-Dali-ShaderEffects.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015 Samsung Electronics Co., Ltd. + * Copyright (c) 2016 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. @@ -35,7 +35,6 @@ #include #include #include -#include #include #include #include @@ -47,13 +46,39 @@ #include using namespace Dali; +using namespace Dali::Toolkit; int UtcDaliCreateAlphaDiscardEffect(void) { ToolkitTestApplication application; - ShaderEffect effect = Toolkit::CreateAlphaDiscardEffect(); - DALI_TEST_CHECK( effect ); + Property::Map effect = Toolkit::CreateAlphaDiscardEffect(); + DALI_TEST_CHECK( !effect.Empty() ); + + Property::Value* customShaderValue = effect.Find( Visual::Property::SHADER ); + DALI_TEST_CHECK( customShaderValue ); + + Property::Map customShader; + DALI_TEST_CHECK( customShaderValue->Get( customShader ) ); + + Property::Value* vertexShaderValue = customShader.Find( Visual::Shader::Property::VERTEX_SHADER ); + DALI_TEST_CHECK( !vertexShaderValue ); + + Property::Value* fragmentShaderValue = customShader.Find( Visual::Shader::Property::FRAGMENT_SHADER ); + DALI_TEST_CHECK( fragmentShaderValue ); + + std::string fragmentShader; + DALI_TEST_CHECK( fragmentShaderValue->Get( fragmentShader ) ); + DALI_TEST_CHECK( !fragmentShader.empty() ); + + Property::Value* gridXValue = customShader.Find( Visual::Shader::Property::SUBDIVIDE_GRID_X ); + DALI_TEST_CHECK( !gridXValue ); + + Property::Value* gridYValue = customShader.Find( Visual::Shader::Property::SUBDIVIDE_GRID_Y ); + DALI_TEST_CHECK( !gridYValue ); + + Property::Value* hintsValue = customShader.Find( Visual::Shader::Property::HINTS ); + DALI_TEST_CHECK( !hintsValue ); END_TEST; } @@ -123,24 +148,69 @@ int UtcDaliCreateDisplacementEffectFixed(void) END_TEST; } -int UtcDaliCreateDissolveEffect(void) +int UtcDaliCreateDissolveEffect( bool highPrecision ) { ToolkitTestApplication application; - ShaderEffect effect = Toolkit::CreateDissolveEffect(); - DALI_TEST_CHECK( effect ); + Property::Map effect = Toolkit::CreateDissolveEffect( highPrecision ); + DALI_TEST_CHECK( !effect.Empty() ); + + Property::Value* customShaderValue = effect.Find( Visual::Property::SHADER ); + DALI_TEST_CHECK( customShaderValue ); + + Property::Map customShader; + DALI_TEST_CHECK( customShaderValue->Get( customShader ) ); + + Property::Value* vertexShaderValue = customShader.Find( Visual::Shader::Property::VERTEX_SHADER ); + DALI_TEST_CHECK( vertexShaderValue ); + + std::string vertexShader; + DALI_TEST_CHECK( vertexShaderValue->Get( vertexShader ) ); + DALI_TEST_CHECK( !vertexShader.empty() ); + + Property::Value* fragmentShaderValue = customShader.Find( Visual::Shader::Property::FRAGMENT_SHADER ); + DALI_TEST_CHECK( fragmentShaderValue ); + + std::string fragmentShader; + DALI_TEST_CHECK( fragmentShaderValue->Get( fragmentShader ) ); + DALI_TEST_CHECK( !fragmentShader.empty() ); + + Property::Value* gridXValue = customShader.Find( Visual::Shader::Property::SUBDIVIDE_GRID_X ); + DALI_TEST_CHECK( gridXValue ); + + int gridX = 0; + DALI_TEST_CHECK( gridXValue->Get( gridX ) ); + DALI_TEST_CHECK( gridX > 1 ); + + Property::Value* gridYValue = customShader.Find( Visual::Shader::Property::SUBDIVIDE_GRID_Y ); + DALI_TEST_CHECK( gridYValue ); + + int gridY = 0; + DALI_TEST_CHECK( gridYValue->Get( gridY ) ); + DALI_TEST_CHECK( gridY > 1 ); + + Property::Value* hintsValue = customShader.Find( Visual::Shader::Property::HINTS ); + DALI_TEST_CHECK( hintsValue ); + + int hints;; + DALI_TEST_CHECK( hintsValue->Get( hints ) ); + DALI_TEST_CHECK( hints == Shader::Hint::OUTPUT_IS_TRANSPARENT ); + + Actor actor = Actor::New(); + Toolkit::DissolveEffectSetCentralLine( actor, Vector2::ONE, Vector2::ONE, 0.0f ); + DALI_TEST_CHECK( actor.GetPropertyIndex( "uPercentage" ) != Property::INVALID_INDEX ); END_TEST; } -int UtcDaliCreateDissolveEffectMediumPrecision(void) +int UtcDaliCreateDissolveEffectHighPrecision(void) { - ToolkitTestApplication application; - - ShaderEffect effect = Toolkit::CreateDissolveEffect(false); - DALI_TEST_CHECK( effect ); + return UtcDaliCreateDissolveEffect(true); +} - END_TEST; +int UtcDaliCreateDissolveEffectMediumPrecision(void) +{ + return UtcDaliCreateDissolveEffect(false); } int UtcDaliCreateDissolveLocalEffect(void) @@ -153,12 +223,38 @@ int UtcDaliCreateDissolveLocalEffect(void) END_TEST; } -int UtcDaliCreateDistanceFieldEffect(void) +int UtcDaliCreateDissolveEffect(void) { ToolkitTestApplication application; - ShaderEffect effect = Toolkit::CreateDistanceFieldEffect(); - DALI_TEST_CHECK( effect ); + Property::Map effect = Toolkit::CreateDistanceFieldEffect(); + DALI_TEST_CHECK( !effect.Empty() ); + + Property::Value* customShaderValue = effect.Find( Visual::Property::SHADER ); + DALI_TEST_CHECK( customShaderValue ); + + Property::Map customShader; + DALI_TEST_CHECK( customShaderValue->Get( customShader ) ); + + Property::Value* vertexShaderValue = customShader.Find( Visual::Shader::Property::VERTEX_SHADER ); + DALI_TEST_CHECK( !vertexShaderValue ); + + Property::Value* fragmentShaderValue = customShader.Find( Visual::Shader::Property::FRAGMENT_SHADER ); + DALI_TEST_CHECK( fragmentShaderValue ); + + std::string fragmentShader; + DALI_TEST_CHECK( fragmentShaderValue->Get( fragmentShader ) ); + DALI_TEST_CHECK( !fragmentShader.empty() ); + + Property::Value* gridXValue = customShader.Find( Visual::Shader::Property::SUBDIVIDE_GRID_X ); + DALI_TEST_CHECK( !gridXValue ); + + Property::Value* hintsValue = customShader.Find( Visual::Shader::Property::HINTS ); + DALI_TEST_CHECK( hintsValue ); + + int hints;; + DALI_TEST_CHECK( hintsValue->Get( hints ) ); + DALI_TEST_CHECK( hints == Shader::Hint::OUTPUT_IS_TRANSPARENT ); END_TEST; } @@ -167,8 +263,33 @@ int UtcDaliCreateImageRegionEffect(void) { ToolkitTestApplication application; - ShaderEffect effect = Toolkit::CreateImageRegionEffect(); - DALI_TEST_CHECK( effect ); + Property::Map effect = Toolkit::CreateImageRegionEffect(); + DALI_TEST_CHECK( !effect.Empty() ); + + Property::Value* customShaderValue = effect.Find( Visual::Property::SHADER ); + DALI_TEST_CHECK( customShaderValue ); + + Property::Map customShader; + DALI_TEST_CHECK( customShaderValue->Get( customShader ) ); + + Property::Value* vertexShaderValue = customShader.Find( Visual::Shader::Property::VERTEX_SHADER ); + DALI_TEST_CHECK( vertexShaderValue ); + + std::string vertexShader; + DALI_TEST_CHECK( vertexShaderValue->Get( vertexShader ) ); + DALI_TEST_CHECK( !vertexShader.empty() ); + + Property::Value* fragmentShaderValue = customShader.Find( Visual::Shader::Property::FRAGMENT_SHADER ); + DALI_TEST_CHECK( !fragmentShaderValue ); + + Property::Value* gridXValue = customShader.Find( Visual::Shader::Property::SUBDIVIDE_GRID_X ); + DALI_TEST_CHECK( !gridXValue ); + + Property::Value* gridYValue = customShader.Find( Visual::Shader::Property::SUBDIVIDE_GRID_Y ); + DALI_TEST_CHECK( !gridYValue ); + + Property::Value* hintsValue = customShader.Find( Visual::Shader::Property::HINTS ); + DALI_TEST_CHECK( !hintsValue ); END_TEST; } @@ -209,12 +330,61 @@ int UtcDaliCreateMotionBlurEffect(void) { ToolkitTestApplication application; - unsigned int sampleCount(4); - ShaderEffect effect = Toolkit::CreateMotionBlurEffect(sampleCount); - DALI_TEST_CHECK( effect ); + Property::Map effect = Toolkit::CreateMotionBlurEffect(); + DALI_TEST_CHECK( !effect.Empty() ); + + Property::Value* customShaderValue = effect.Find( Visual::Property::SHADER ); + DALI_TEST_CHECK( customShaderValue ); + + Property::Map customShader; + DALI_TEST_CHECK( customShaderValue->Get( customShader ) ); + + Property::Value* vertexShaderValue = customShader.Find( Visual::Shader::Property::VERTEX_SHADER ); + DALI_TEST_CHECK( vertexShaderValue ); + + std::string vertexShader; + DALI_TEST_CHECK( vertexShaderValue->Get( vertexShader ) ); + DALI_TEST_CHECK( !vertexShader.empty() ); + + Property::Value* fragmentShaderValue = customShader.Find( Visual::Shader::Property::FRAGMENT_SHADER ); + DALI_TEST_CHECK( fragmentShaderValue ); + + std::string fragmentShader; + DALI_TEST_CHECK( fragmentShaderValue->Get( fragmentShader ) ); + DALI_TEST_CHECK( !fragmentShader.empty() ); + + Property::Value* gridXValue = customShader.Find( Visual::Shader::Property::SUBDIVIDE_GRID_X ); + DALI_TEST_CHECK( gridXValue ); - Property::Value value = effect.GetProperty( effect.GetPropertyIndex("uNumSamples")); - DALI_TEST_EQUALS( value.Get(), (float)sampleCount, TEST_LOCATION ); + int gridX = 0; + DALI_TEST_CHECK( gridXValue->Get( gridX ) ); + DALI_TEST_CHECK( gridX > 1 ); + + Property::Value* gridYValue = customShader.Find( Visual::Shader::Property::SUBDIVIDE_GRID_Y ); + DALI_TEST_CHECK( gridYValue ); + + int gridY = 0; + DALI_TEST_CHECK( gridYValue->Get( gridY ) ); + DALI_TEST_CHECK( gridY > 1 ); + + Property::Value* hintsValue = customShader.Find( Visual::Shader::Property::HINTS ); + DALI_TEST_CHECK( hintsValue ); + + int hints;; + DALI_TEST_CHECK( hintsValue->Get( hints ) ); + DALI_TEST_CHECK( hints == Shader::Hint::OUTPUT_IS_TRANSPARENT ); + + unsigned int sampleCount( 4 ); + Actor actor = Actor::New(); + Toolkit::SetMotionBlurProperties( actor, sampleCount ); + DALI_TEST_CHECK( actor.GetPropertyIndex( "uBlurTexCoordScale" ) != Property::INVALID_INDEX ); + DALI_TEST_CHECK( actor.GetPropertyIndex( "uGeometryStretchFactor" ) != Property::INVALID_INDEX ); + DALI_TEST_CHECK( actor.GetPropertyIndex( "uSpeedScalingFactor" ) != Property::INVALID_INDEX ); + DALI_TEST_CHECK( actor.GetPropertyIndex( "uObjectFadeStart" ) != Property::INVALID_INDEX ); + DALI_TEST_CHECK( actor.GetPropertyIndex( "uObjectFadeEnd" ) != Property::INVALID_INDEX ); + DALI_TEST_CHECK( actor.GetPropertyIndex( "uAlphaScale" ) != Property::INVALID_INDEX ); + DALI_TEST_CHECK( actor.GetPropertyIndex( "uNumSamples" ) != Property::INVALID_INDEX ); + DALI_TEST_CHECK( actor.GetPropertyIndex( "uModelLastFrame" ) != Property::INVALID_INDEX ); END_TEST; } @@ -223,8 +393,58 @@ int UtcDaliCreateMotionStretchEffect(void) { ToolkitTestApplication application; - ShaderEffect effect = Toolkit::CreateMotionStretchEffect(); - DALI_TEST_CHECK( effect ); + Property::Map effect = Toolkit::CreateMotionStretchEffect(); + DALI_TEST_CHECK( !effect.Empty() ); + + Property::Value* customShaderValue = effect.Find( Visual::Property::SHADER ); + DALI_TEST_CHECK( customShaderValue ); + + Property::Map customShader; + DALI_TEST_CHECK( customShaderValue->Get( customShader ) ); + + Property::Value* vertexShaderValue = customShader.Find( Visual::Shader::Property::VERTEX_SHADER ); + DALI_TEST_CHECK( vertexShaderValue ); + + std::string vertexShader; + DALI_TEST_CHECK( vertexShaderValue->Get( vertexShader ) ); + DALI_TEST_CHECK( !vertexShader.empty() ); + + Property::Value* fragmentShaderValue = customShader.Find( Visual::Shader::Property::FRAGMENT_SHADER ); + DALI_TEST_CHECK( fragmentShaderValue ); + + std::string fragmentShader; + DALI_TEST_CHECK( fragmentShaderValue->Get( fragmentShader ) ); + DALI_TEST_CHECK( !fragmentShader.empty() ); + + Property::Value* gridXValue = customShader.Find( Visual::Shader::Property::SUBDIVIDE_GRID_X ); + DALI_TEST_CHECK( gridXValue ); + + int gridX = 0; + DALI_TEST_CHECK( gridXValue->Get( gridX ) ); + DALI_TEST_CHECK( gridX > 1 ); + + Property::Value* gridYValue = customShader.Find( Visual::Shader::Property::SUBDIVIDE_GRID_Y ); + DALI_TEST_CHECK( gridYValue ); + + int gridY = 0; + DALI_TEST_CHECK( gridYValue->Get( gridY ) ); + DALI_TEST_CHECK( gridY > 1 ); + + Property::Value* hintsValue = customShader.Find( Visual::Shader::Property::HINTS ); + DALI_TEST_CHECK( hintsValue ); + + int hints;; + DALI_TEST_CHECK( hintsValue->Get( hints ) ); + DALI_TEST_CHECK( hints == Shader::Hint::OUTPUT_IS_TRANSPARENT ); + + Actor actor = Actor::New(); + Toolkit::SetMotionStretchProperties( actor ); + DALI_TEST_CHECK( actor.GetPropertyIndex( "uGeometryStretchFactor" ) != Property::INVALID_INDEX ); + DALI_TEST_CHECK( actor.GetPropertyIndex( "uSpeedScalingFactor" ) != Property::INVALID_INDEX ); + DALI_TEST_CHECK( actor.GetPropertyIndex( "uObjectFadeStart" ) != Property::INVALID_INDEX ); + DALI_TEST_CHECK( actor.GetPropertyIndex( "uObjectFadeEnd" ) != Property::INVALID_INDEX ); + DALI_TEST_CHECK( actor.GetPropertyIndex( "uAlphaScale" ) != Property::INVALID_INDEX ); + DALI_TEST_CHECK( actor.GetPropertyIndex( "uModelLastFrame" ) != Property::INVALID_INDEX ); END_TEST; }