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-AnimatedImageVisual.cpp;h=0e06386af8ea3391d15dcd279430dfdc8bb608c3;hp=97f04ac4f64c68c929304a9dc98b93d612673bfd;hb=0e8dfa9c961af84b18edf2e3307840b0d94fb430;hpb=46322a558e537267a6d3c48630c45afca91b5e27 diff --git a/automated-tests/src/dali-toolkit/utc-Dali-AnimatedImageVisual.cpp b/automated-tests/src/dali-toolkit/utc-Dali-AnimatedImageVisual.cpp index 97f04ac..0e06386 100644 --- a/automated-tests/src/dali-toolkit/utc-Dali-AnimatedImageVisual.cpp +++ b/automated-tests/src/dali-toolkit/utc-Dali-AnimatedImageVisual.cpp @@ -1,6 +1,6 @@ /* - * 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. @@ -21,10 +21,10 @@ #include #include #include -#include -#include #include #include +#include +#include #include "dummy-control.h" using namespace Dali; @@ -70,7 +70,7 @@ int UtcDaliAnimatedImageVisualGetPropertyMap01(void) VisualFactory factory = VisualFactory::Get(); Visual::Base animatedImageVisual = factory.CreateVisual( Property::Map() - .Add( Visual::Property::TYPE, DevelVisual::ANIMATED_IMAGE ) + .Add( Toolkit::Visual::Property::TYPE, Visual::ANIMATED_IMAGE ) .Add( ImageVisual::Property::URL, TEST_GIF_FILE_NAME ) .Add( ImageVisual::Property::PIXEL_AREA, Vector4() ) .Add( ImageVisual::Property::WRAP_MODE_U, WrapMode::REPEAT ) @@ -79,9 +79,9 @@ int UtcDaliAnimatedImageVisualGetPropertyMap01(void) Property::Map resultMap; animatedImageVisual.CreatePropertyMap( resultMap ); // check the property values from the returned map from a visual - Property::Value* value = resultMap.Find( Visual::Property::TYPE, Property::INTEGER ); + Property::Value* value = resultMap.Find( Toolkit::Visual::Property::TYPE, Property::INTEGER ); DALI_TEST_CHECK( value ); - DALI_TEST_CHECK( value->Get() == DevelVisual::ANIMATED_IMAGE ); + DALI_TEST_CHECK( value->Get() == Visual::ANIMATED_IMAGE ); value = resultMap.Find( ImageVisual::Property::URL, Property::STRING ); DALI_TEST_CHECK( value ); @@ -92,9 +92,9 @@ int UtcDaliAnimatedImageVisualGetPropertyMap01(void) resultMap.Clear(); animatedImageVisual2.CreatePropertyMap( resultMap ); // check the property values from the returned map from a visual - value = resultMap.Find( Visual::Property::TYPE, Property::INTEGER ); + value = resultMap.Find( Toolkit::Visual::Property::TYPE, Property::INTEGER ); DALI_TEST_CHECK( value ); - DALI_TEST_CHECK( value->Get() == DevelVisual::ANIMATED_IMAGE ); + DALI_TEST_CHECK( value->Get() == Visual::ANIMATED_IMAGE ); value = resultMap.Find( ImageVisual::Property::URL, Property::STRING ); DALI_TEST_CHECK( value ); @@ -116,10 +116,11 @@ int UtcDaliAnimatedImageVisualGetPropertyMap02(void) Visual::Base animatedImageVisual = factory.CreateVisual( Property::Map() - .Add( Visual::Property::TYPE, DevelVisual::ANIMATED_IMAGE ) + .Add( Toolkit::Visual::Property::TYPE, Visual::ANIMATED_IMAGE ) .Add( "url", urls ) .Add( "batchSize", 4 ) .Add( "cacheSize", 8 ) + .Add( "loopCount", 10 ) .Add( "frameDelay", 200 ) .Add( "pixelArea", Vector4() ) .Add( "wrapModeU", WrapMode::REPEAT ) @@ -128,25 +129,29 @@ int UtcDaliAnimatedImageVisualGetPropertyMap02(void) Property::Map resultMap; animatedImageVisual.CreatePropertyMap( resultMap ); // check the property values from the returned map from a visual - Property::Value* value = resultMap.Find( Visual::Property::TYPE, Property::INTEGER ); + Property::Value* value = resultMap.Find( Toolkit::Visual::Property::TYPE, Property::INTEGER ); DALI_TEST_CHECK( value ); - DALI_TEST_CHECK( value->Get() == DevelVisual::ANIMATED_IMAGE ); + DALI_TEST_CHECK( value->Get() == Visual::ANIMATED_IMAGE ); - value = resultMap.Find( DevelImageVisual::Property::URL, "url" ); + value = resultMap.Find( ImageVisual::Property::URL, "url" ); DALI_TEST_CHECK( value ); Property::Array* resultUrls = value->GetArray(); DALI_TEST_CHECK( resultUrls ); DALI_TEST_EQUALS( resultUrls->Count(), urls.Count(), TEST_LOCATION ); - value = resultMap.Find( DevelImageVisual::Property::BATCH_SIZE, "batchSize" ); + value = resultMap.Find( ImageVisual::Property::BATCH_SIZE, "batchSize" ); DALI_TEST_CHECK( value ); DALI_TEST_EQUALS( value->Get(), 4, TEST_LOCATION ); - value = resultMap.Find( DevelImageVisual::Property::CACHE_SIZE, "cacheSize" ); + value = resultMap.Find( ImageVisual::Property::CACHE_SIZE, "cacheSize" ); DALI_TEST_CHECK( value ); DALI_TEST_EQUALS( value->Get(), 8, TEST_LOCATION ); - value = resultMap.Find( DevelImageVisual::Property::FRAME_DELAY, "frameDelay" ); + value = resultMap.Find( Toolkit::DevelImageVisual::Property::LOOP_COUNT, "loopCount" ); + DALI_TEST_CHECK( value ); + DALI_TEST_EQUALS( value->Get(), 10, TEST_LOCATION ); + + value = resultMap.Find( ImageVisual::Property::FRAME_DELAY, "frameDelay" ); DALI_TEST_CHECK( value ); DALI_TEST_EQUALS( value->Get(), 200, TEST_LOCATION ); @@ -167,10 +172,10 @@ int UtcDaliAnimatedImageVisualMultiImage01(void) { Property::Map propertyMap; propertyMap.Insert(Visual::Property::TYPE, Visual::IMAGE ); - propertyMap.Insert( DevelImageVisual::Property::URL, Property::Value(urls) ); - propertyMap.Insert( DevelImageVisual::Property::BATCH_SIZE, 4); - propertyMap.Insert( DevelImageVisual::Property::CACHE_SIZE, 8); - propertyMap.Insert( DevelImageVisual::Property::FRAME_DELAY, 100); + propertyMap.Insert( ImageVisual::Property::URL, Property::Value(urls) ); + propertyMap.Insert( ImageVisual::Property::BATCH_SIZE, 4); + propertyMap.Insert( ImageVisual::Property::CACHE_SIZE, 8); + propertyMap.Insert( ImageVisual::Property::FRAME_DELAY, 100); VisualFactory factory = VisualFactory::Get(); Visual::Base visual = factory.CreateVisual( propertyMap ); @@ -261,10 +266,10 @@ int UtcDaliAnimatedImageVisualMultiImage02(void) Property::Map propertyMap; propertyMap.Insert(Visual::Property::TYPE, Visual::IMAGE ); - propertyMap.Insert( DevelImageVisual::Property::URL, Property::Value(urls) ); - propertyMap.Insert( DevelImageVisual::Property::BATCH_SIZE, 0); - propertyMap.Insert( DevelImageVisual::Property::CACHE_SIZE, 0); - propertyMap.Insert( DevelImageVisual::Property::FRAME_DELAY, 100); + propertyMap.Insert( ImageVisual::Property::URL, Property::Value(urls) ); + propertyMap.Insert( ImageVisual::Property::BATCH_SIZE, 0); + propertyMap.Insert( ImageVisual::Property::CACHE_SIZE, 0); + propertyMap.Insert( ImageVisual::Property::FRAME_DELAY, 100); VisualFactory factory = VisualFactory::Get(); Visual::Base visual = factory.CreateVisual( propertyMap ); // TexMgr::Request load tId:0 @@ -334,17 +339,17 @@ int UtcDaliAnimatedImageVisualMultiImage03(void) Property::Map animatedImageMap1; animatedImageMap1.Insert(Visual::Property::TYPE, Visual::IMAGE ); - animatedImageMap1.Insert( DevelImageVisual::Property::URL, Property::Value(urls1) ); - animatedImageMap1.Insert( DevelImageVisual::Property::BATCH_SIZE, 3); - animatedImageMap1.Insert( DevelImageVisual::Property::CACHE_SIZE, 3); - animatedImageMap1.Insert( DevelImageVisual::Property::FRAME_DELAY, 100); + animatedImageMap1.Insert( ImageVisual::Property::URL, Property::Value(urls1) ); + animatedImageMap1.Insert( ImageVisual::Property::BATCH_SIZE, 3); + animatedImageMap1.Insert( ImageVisual::Property::CACHE_SIZE, 3); + animatedImageMap1.Insert( ImageVisual::Property::FRAME_DELAY, 100); Property::Map animatedImageMap2; animatedImageMap2.Insert(Visual::Property::TYPE, Visual::IMAGE ); - animatedImageMap2.Insert( DevelImageVisual::Property::URL, Property::Value(urls2) ); - animatedImageMap2.Insert( DevelImageVisual::Property::BATCH_SIZE, 2); - animatedImageMap2.Insert( DevelImageVisual::Property::CACHE_SIZE, 2); - animatedImageMap2.Insert( DevelImageVisual::Property::FRAME_DELAY, 100); + animatedImageMap2.Insert( ImageVisual::Property::URL, Property::Value(urls2) ); + animatedImageMap2.Insert( ImageVisual::Property::BATCH_SIZE, 2); + animatedImageMap2.Insert( ImageVisual::Property::CACHE_SIZE, 2); + animatedImageMap2.Insert( ImageVisual::Property::FRAME_DELAY, 100); VisualFactory factory = VisualFactory::Get(); Visual::Base animatedImageVisual1 = factory.CreateVisual( animatedImageMap1 ); @@ -417,10 +422,10 @@ int UtcDaliAnimatedImageVisualMultiImage04(void) { Property::Map propertyMap; propertyMap.Insert(Visual::Property::TYPE, Visual::IMAGE ); - propertyMap.Insert( DevelImageVisual::Property::URL, Property::Value(urls) ); - propertyMap.Insert( DevelImageVisual::Property::BATCH_SIZE, 6); - propertyMap.Insert( DevelImageVisual::Property::CACHE_SIZE, 11); - propertyMap.Insert( DevelImageVisual::Property::FRAME_DELAY, 100); + propertyMap.Insert( ImageVisual::Property::URL, Property::Value(urls) ); + propertyMap.Insert( ImageVisual::Property::BATCH_SIZE, 6); + propertyMap.Insert( ImageVisual::Property::CACHE_SIZE, 11); + propertyMap.Insert( ImageVisual::Property::FRAME_DELAY, 100); VisualFactory factory = VisualFactory::Get(); Visual::Base visual = factory.CreateVisual( propertyMap ); @@ -503,10 +508,10 @@ int UtcDaliAnimatedImageVisualMultiImage05(void) { Property::Map propertyMap; propertyMap.Insert(Visual::Property::TYPE, Visual::IMAGE ); - propertyMap.Insert( DevelImageVisual::Property::URL, Property::Value(urls) ); - propertyMap.Insert( DevelImageVisual::Property::BATCH_SIZE, 4); - propertyMap.Insert( DevelImageVisual::Property::CACHE_SIZE, 11); - propertyMap.Insert( DevelImageVisual::Property::FRAME_DELAY, 100); + propertyMap.Insert( ImageVisual::Property::URL, Property::Value(urls) ); + propertyMap.Insert( ImageVisual::Property::BATCH_SIZE, 4); + propertyMap.Insert( ImageVisual::Property::CACHE_SIZE, 11); + propertyMap.Insert( ImageVisual::Property::FRAME_DELAY, 100); VisualFactory factory = VisualFactory::Get(); Visual::Base visual = factory.CreateVisual( propertyMap ); @@ -551,3 +556,171 @@ int UtcDaliAnimatedImageVisualMultiImage05(void) END_TEST; } + +void TestLoopCount( ToolkitTestApplication &application, DummyControl &dummyControl, uint16_t frameCount, uint16_t loopCount, const char * location ) +{ + TestGlAbstraction& gl = application.GetGlAbstraction(); + TraceCallStack& textureTrace = gl.GetTextureTrace(); + + textureTrace.Enable(true); + Stage::GetCurrent().Add( dummyControl ); + application.SendNotification(); + application.Render(16); + + tet_infoline( "Test that a timer has been created" ); + DALI_TEST_EQUALS( Test::GetTimerCount(), 1, TEST_INNER_LOCATION( location ) ); + + for ( uint16_t i = 0; i <= loopCount; i++ ) + { + for ( uint16_t j = 0; j < frameCount; j++ ) + { + tet_printf( "Test that after %u ticks, and we have %u frame \n", j + 1u, j + 1u ); + Test::EmitGlobalTimerSignal(); + application.SendNotification(); + application.Render(16); + DALI_TEST_EQUALS( gl.GetNumGeneratedTextures(), 1, TEST_INNER_LOCATION( location ) ); + DALI_TEST_EQUALS( Test::AreTimersRunning(), true, TEST_INNER_LOCATION( location ) ); + } + tet_printf( "\nTest Loop %u \n", i ); + } + + tet_printf( "Test that after %u loops, and we have no frame. Timer should stop \n", loopCount ); + Test::EmitGlobalTimerSignal(); + application.SendNotification(); + application.Render(16); + DALI_TEST_EQUALS( Test::AreTimersRunning(), false, TEST_INNER_LOCATION( location ) ); + + dummyControl.Unparent(); +} + +int UtcDaliAnimatedImageVisualLoopCount(void) +{ + ToolkitTestApplication application; + + tet_infoline( "UtcDaliAnimatedImageVisualLoopCount" ); + + { + // request AnimatedImageVisual with a property map + // Test with no (0) loop count + VisualFactory factory = VisualFactory::Get(); + Visual::Base animatedImageVisual = factory.CreateVisual( + Property::Map() + .Add( Toolkit::Visual::Property::TYPE, Visual::ANIMATED_IMAGE ) + .Add( ImageVisual::Property::URL, TEST_GIF_FILE_NAME ) + .Add( ImageVisual::Property::PIXEL_AREA, Vector4() ) + .Add( ImageVisual::Property::WRAP_MODE_U, WrapMode::REPEAT ) + .Add( ImageVisual::Property::WRAP_MODE_V, WrapMode::DEFAULT ) + .Add( DevelImageVisual::Property::LOOP_COUNT, 0 )); + + DummyControl dummyControl = DummyControl::New(true); + Impl::DummyControl& dummyImpl = static_cast(dummyControl.GetImplementation()); + dummyImpl.RegisterVisual( DummyControl::Property::TEST_VISUAL, animatedImageVisual ); + dummyControl.SetResizePolicy( ResizePolicy::FILL_TO_PARENT, Dimension::ALL_DIMENSIONS ); + + TestLoopCount( application, dummyControl, 4, 0, TEST_LOCATION ); + + // Test with no (1) loop count. Request AnimatedImageVisual with a property map + animatedImageVisual = factory.CreateVisual( + Property::Map() + .Add( Toolkit::Visual::Property::TYPE, Visual::ANIMATED_IMAGE ) + .Add( ImageVisual::Property::URL, TEST_GIF_FILE_NAME ) + .Add( ImageVisual::Property::PIXEL_AREA, Vector4() ) + .Add( ImageVisual::Property::WRAP_MODE_U, WrapMode::REPEAT ) + .Add( ImageVisual::Property::WRAP_MODE_V, WrapMode::DEFAULT ) + .Add( DevelImageVisual::Property::LOOP_COUNT, 1 )); + + dummyImpl.RegisterVisual( DummyControl::Property::TEST_VISUAL, animatedImageVisual ); + + TestLoopCount( application, dummyControl, 4, 1, TEST_LOCATION ); + + // Test with no (100) loop count. Request AnimatedImageVisual with a property map + animatedImageVisual = factory.CreateVisual( + Property::Map() + .Add( Toolkit::Visual::Property::TYPE, Visual::ANIMATED_IMAGE ) + .Add( ImageVisual::Property::URL, TEST_GIF_FILE_NAME ) + .Add( ImageVisual::Property::PIXEL_AREA, Vector4() ) + .Add( ImageVisual::Property::WRAP_MODE_U, WrapMode::REPEAT ) + .Add( ImageVisual::Property::WRAP_MODE_V, WrapMode::DEFAULT ) + .Add( DevelImageVisual::Property::LOOP_COUNT, 100 )); + + dummyImpl.RegisterVisual( DummyControl::Property::TEST_VISUAL, animatedImageVisual ); + + TestLoopCount( application, dummyControl, 4, 100, TEST_LOCATION ); + } + + END_TEST; +} + +int UtcDaliAnimatedImageVisualPlayback(void) +{ + ToolkitTestApplication application; + TestGlAbstraction& gl = application.GetGlAbstraction(); + TraceCallStack& textureTrace = gl.GetTextureTrace(); + + tet_infoline( "UtcDaliAnimatedImageVisualPlayback" ); + + { + // request AnimatedImageVisual with a property map + // Test with forever (-1) loop count + VisualFactory factory = VisualFactory::Get(); + Visual::Base animatedImageVisual = factory.CreateVisual( + Property::Map() + .Add( Toolkit::Visual::Property::TYPE, Visual::ANIMATED_IMAGE ) + .Add( ImageVisual::Property::URL, TEST_GIF_FILE_NAME ) + .Add( ImageVisual::Property::PIXEL_AREA, Vector4() ) + .Add( ImageVisual::Property::WRAP_MODE_U, WrapMode::REPEAT ) + .Add( ImageVisual::Property::WRAP_MODE_V, WrapMode::DEFAULT ) + .Add( DevelImageVisual::Property::LOOP_COUNT, -1 )); + + DummyControl dummyControl = DummyControl::New(true); + Impl::DummyControl& dummyImpl = static_cast(dummyControl.GetImplementation()); + dummyImpl.RegisterVisual( DummyControl::Property::TEST_VISUAL, animatedImageVisual ); + dummyControl.SetResizePolicy( ResizePolicy::FILL_TO_PARENT, Dimension::ALL_DIMENSIONS ); + + textureTrace.Enable(true); + Stage::GetCurrent().Add( dummyControl ); + application.SendNotification(); + application.Render(16); + + tet_infoline( "Test that a timer has been created" ); + DALI_TEST_EQUALS( Test::GetTimerCount(), 1, TEST_LOCATION ); + + Test::EmitGlobalTimerSignal(); + application.SendNotification(); + application.Render(16); + DALI_TEST_EQUALS( Test::AreTimersRunning(), true, TEST_LOCATION ); + + Property::Map attributes; + tet_infoline( "Test Pause action. Timer should stop after Pause action" ); + DevelControl::DoAction( dummyControl, DummyControl::Property::TEST_VISUAL, Dali::Toolkit::DevelAnimatedImageVisual::Action::PAUSE, attributes ); + Test::EmitGlobalTimerSignal(); + application.SendNotification(); + application.Render(16); + DALI_TEST_EQUALS( Test::AreTimersRunning(), false, TEST_LOCATION ); + + tet_infoline( "Test Play action. Timer should Restart after Play action" ); + DevelControl::DoAction( dummyControl, DummyControl::Property::TEST_VISUAL, Dali::Toolkit::DevelAnimatedImageVisual::Action::PLAY, attributes ); + Test::EmitGlobalTimerSignal(); + application.SendNotification(); + application.Render(16); + DALI_TEST_EQUALS( Test::AreTimersRunning(), true, TEST_LOCATION ); + + tet_infoline( "Test Stop action. Timer should stop after Stop action" ); + DevelControl::DoAction( dummyControl, DummyControl::Property::TEST_VISUAL, Dali::Toolkit::DevelAnimatedImageVisual::Action::STOP, attributes ); + Test::EmitGlobalTimerSignal(); + application.SendNotification(); + application.Render(16); + DALI_TEST_EQUALS( Test::AreTimersRunning(), false, TEST_LOCATION ); + + tet_infoline( "Test Play action. Timer should Restart after Play action" ); + DevelControl::DoAction( dummyControl, DummyControl::Property::TEST_VISUAL, Dali::Toolkit::DevelAnimatedImageVisual::Action::PLAY, attributes ); + Test::EmitGlobalTimerSignal(); + application.SendNotification(); + application.Render(16); + DALI_TEST_EQUALS( Test::AreTimersRunning(), true, TEST_LOCATION ); + + dummyControl.Unparent(); + } + + END_TEST; +} \ No newline at end of file