2 * Copyright (c) 2016 Samsung Electronics Co., Ltd.
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
21 // Need to override adaptor classes for toolkit test harness, so include
22 // test harness headers before dali headers.
23 #include <dali-toolkit-test-suite-utils.h>
26 #include <dali-toolkit/dali-toolkit.h>
27 #include <dali-toolkit/devel-api/controls/super-blur-view/super-blur-view.h>
30 using namespace Dali::Toolkit;
32 void utc_dali_toolkit_super_blur_view_startup(void)
34 test_return_value = TET_UNDEF;
37 void utc_dali_toolkit_super_blur_view_cleanup(void)
39 test_return_value = TET_PASS;
45 const int BLUR_LEVELS = 3;
46 const int RENDER_FRAME_INTERVAL = 16;
47 static const char* TEST_IMAGE_FILE_NAME = TEST_RESOURCE_DIR "/gallery-small-1.jpg";
48 static bool gObjectCreatedCallBackCalled;
49 static void TestCallback(BaseHandle handle)
51 gObjectCreatedCallBackCalled = true;
55 * Simulate time passed by.
57 * @note this will always process at least 1 frame (1/60 sec)
59 * @param application Test application instance
60 * @param duration Time to pass in milliseconds.
61 * @return The actual time passed in milliseconds
63 int Wait(ToolkitTestApplication& application, int duration = 0)
67 for(int i = 0; i <= ( duration / RENDER_FRAME_INTERVAL); i++)
69 application.SendNotification();
70 application.Render(RENDER_FRAME_INTERVAL);
71 time += RENDER_FRAME_INTERVAL;
77 Texture CreateSolidColorTexture( ToolkitTestApplication& application, const Vector4& color, unsigned int width, unsigned int height )
79 unsigned int size = width * height;
80 uint8_t* pixbuf = new uint8_t[size*4];
82 for( size_t i = 0; i < size; i++ )
84 pixbuf[i*4+0] = 0xFF * color.r;
85 pixbuf[i*4+1] = 0xFF * color.g;
86 pixbuf[i*4+2] = 0xFF * color.b;
87 pixbuf[i*4+3] = 0xFF * color.a;
90 PixelData pixels = PixelData::New( pixbuf, size, width, height, Pixel::RGBA8888, PixelData::ReleaseFunction::DELETE_ARRAY );
92 Texture texture = Texture::New( TextureType::TEXTURE_2D, pixels.GetPixelFormat(), pixels.GetWidth(), pixels.GetHeight() );
93 texture.Upload( pixels, 0, 0, 0, 0, pixels.GetWidth(), pixels.GetHeight() );
98 class SignalHandler : public Dali::ConnectionTracker
106 void Callback( SuperBlurView handle )
109 tet_infoline( "Signal called" );
112 unsigned int GetCalls() const
118 unsigned int mCalls; ///< Keeps track of how many times the signal has been called.
124 int UtcDaliSuperBlurViewNew(void)
126 ToolkitTestApplication application;
128 tet_infoline(" UtcDaliSuperBlurViewNew ");
130 // Test default constructor.
131 SuperBlurView blurView;
132 DALI_TEST_CHECK( !blurView );
134 // Test object creation
135 blurView = SuperBlurView::New( BLUR_LEVELS );
136 DALI_TEST_CHECK( blurView );
138 //Additional check to ensure object is created by checking if it's registered
139 ObjectRegistry registry = Stage::GetCurrent().GetObjectRegistry();
140 DALI_TEST_CHECK( registry );
142 gObjectCreatedCallBackCalled = false;
143 registry.ObjectCreatedSignal().Connect( &TestCallback );
145 SuperBlurView blurView = SuperBlurView::New( BLUR_LEVELS );
147 DALI_TEST_CHECK( gObjectCreatedCallBackCalled );
149 // Test copy constructor
150 SuperBlurView blurViewCopy2( blurView );
151 DALI_TEST_CHECK( blurViewCopy2 );
155 actorView = blurView;
156 SuperBlurView downCastView = SuperBlurView::DownCast( actorView );
157 DALI_TEST_CHECK( downCastView );
161 int UtcDaliSuperBlurViewCreate(void)
163 ToolkitTestApplication application;
165 tet_infoline(" UtcDaliSuperBlurViewNew ");
167 // Test default constructor.
168 SuperBlurView blurView;
169 DALI_TEST_CHECK( !blurView );
171 // Test object creation
172 TypeInfo type = TypeRegistry::Get().GetTypeInfo("SuperBlurView");
175 Dali::BaseHandle handle = type.CreateInstance();
178 blurView = Dali::Toolkit::SuperBlurView::DownCast( handle );
182 DALI_TEST_CHECK( blurView );
188 int UtcDaliSuperBlurViewSetTexture(void)
190 ToolkitTestApplication application;
192 tet_infoline(" UtcDaliSuperBlurViewSetTexture ");
194 SuperBlurView blurView = SuperBlurView::New( BLUR_LEVELS );
195 blurView.SetSize( 100.f, 100.f );
197 Texture inputTexture = CreateSolidColorTexture( application, Color::GREEN, 50, 50 );
198 blurView.SetTexture( inputTexture );
199 // start multiple guassian blur call, each guassian blur creates two render tasks
200 DALI_TEST_CHECK( Stage::GetCurrent().GetRenderTaskList().GetTaskCount() == 1+BLUR_LEVELS*2);
203 // create renderers for the original image and each blurred image
204 Stage::GetCurrent().Add( blurView );
206 DALI_TEST_EQUALS(blurView.GetRendererCount(), BLUR_LEVELS+1, TEST_LOCATION );
209 Stage::GetCurrent().Remove( blurView );
215 int UtcDaliSuperBlurViewSetTexture2(void)
217 ToolkitTestApplication application;
218 Stage stage = Stage::GetCurrent();
220 tet_infoline(" UtcDaliSuperBlurViewSetTexture2 - test setting a second texture ");
222 SuperBlurView blurView = SuperBlurView::New( BLUR_LEVELS );
223 blurView.SetSize( 100.f, 100.f );
225 tet_infoline("Call SetTexture and add blurview to stage");
226 Texture inputTexture = CreateSolidColorTexture( application, Color::GREEN, 50, 50 );
227 blurView.SetTexture( inputTexture );
229 // start multiple guassian blur call, each guassian blur creates two render tasks
230 DALI_TEST_CHECK( Stage::GetCurrent().GetRenderTaskList().GetTaskCount() == 1+BLUR_LEVELS*2);
232 // create renderers for the original image and each blurred image
233 stage.Add( blurView );
235 DALI_TEST_EQUALS(blurView.GetRendererCount(), BLUR_LEVELS+1, TEST_LOCATION );
237 tet_infoline("Wait for a second to allow blur to finish");
238 Wait(application, 1000);
240 tet_infoline("Remove from stage");
241 Stage::GetCurrent().Remove( blurView );
244 tet_infoline("Test that there are no render tasks remaining");
245 DALI_TEST_EQUALS(blurView.GetRendererCount(), 0, TEST_LOCATION );
247 tet_infoline("Call SetTexture a second time and add blurview back to stage");
248 Texture inputTexture2 = CreateSolidColorTexture( application, Color::CYAN, 50, 50 );
249 blurView.SetTexture( inputTexture2 );
250 // start multiple guassian blur call, each guassian blur creates two render tasks
251 DALI_TEST_CHECK( Stage::GetCurrent().GetRenderTaskList().GetTaskCount() == 1+BLUR_LEVELS*2);
254 // create renderers for the original image and each blurred image
255 Stage::GetCurrent().Add( blurView );
257 DALI_TEST_EQUALS(blurView.GetRendererCount(), BLUR_LEVELS+1, TEST_LOCATION );
259 tet_infoline("Wait for a second to allow blur to finish");
260 Wait(application, 1000);
262 tet_infoline("Remove from stage");
263 Stage::GetCurrent().Remove( blurView );
266 tet_infoline("Test that there are no render tasks remaining");
267 DALI_TEST_EQUALS(blurView.GetRendererCount(), 0, TEST_LOCATION );
273 int UtcDaliSuperBlurViewSetProperty(void)
275 ToolkitTestApplication application;
277 tet_infoline(" UtcDaliSuperBlurViewSetProperty ");
279 SuperBlurView blurView = SuperBlurView::New( BLUR_LEVELS );
280 // create renderers for the original image and each blurred image
281 Stage::GetCurrent().Add( blurView );
282 blurView.SetSize( 100.f, 100.f );
284 // Will create ResourceImage
285 blurView.SetProperty(SuperBlurView::Property::IMAGE_URL, TEST_IMAGE_FILE_NAME);
288 // start multiple guassian blur call, each guassian blur creates two render tasks
290 unsigned int count = Stage::GetCurrent().GetRenderTaskList().GetTaskCount();
291 DALI_TEST_CHECK( count == 1+BLUR_LEVELS*2 );
299 int UtcDaliSuperBlurViewGetProperty(void)
301 ToolkitTestApplication application;
303 tet_infoline(" UtcDaliSuperBlurViewSetProperty ");
305 SuperBlurView blurView = SuperBlurView::New( BLUR_LEVELS );
306 blurView.SetSize( 100.f, 100.f );
308 blurView.SetProperty(SuperBlurView::Property::IMAGE_URL, TEST_IMAGE_FILE_NAME);
311 // create renderers for the original image and each blurred image
312 Stage::GetCurrent().Add( blurView );
314 std::string imageUrl = blurView.GetProperty<std::string>( SuperBlurView::Property::IMAGE_URL );
315 DALI_TEST_EQUALS( imageUrl, TEST_IMAGE_FILE_NAME, TEST_LOCATION );
321 int UtcDaliSuperBlurViewSetGetBlurStrength(void)
323 ToolkitTestApplication application;
325 tet_infoline(" UtcDaliSuperBlurViewSetGetBlurStrength ");
327 SuperBlurView blurView = SuperBlurView::New( BLUR_LEVELS );
328 DALI_TEST_EQUALS(blurView.GetCurrentBlurStrength(), 0.f, TEST_LOCATION );
330 blurView.SetBlurStrength( 0.65f );
332 DALI_TEST_EQUALS(blurView.GetCurrentBlurStrength(), 0.65f, TEST_LOCATION );
336 int UtcDaliSuperBlurViewGetBlurStrengthPropertyIndex(void)
338 ToolkitTestApplication application;
340 tet_infoline(" UtcDaliSuperBlurViewGetBlurStrengthPropertyIndex ");
342 SuperBlurView blurView = SuperBlurView::New( BLUR_LEVELS );
343 Property::Index blurPropertyIdx = blurView.GetBlurStrengthPropertyIndex();
346 (blurView.GetProperty( blurPropertyIdx )).Get(blurStrength);
347 DALI_TEST_EQUALS(blurStrength, 0.f, TEST_LOCATION );
349 blurView.SetBlurStrength( 0.65f );
351 (blurView.GetProperty( blurPropertyIdx )).Get(blurStrength);
352 DALI_TEST_EQUALS(blurStrength, 0.65f, TEST_LOCATION );
356 int UtcDaliSuperBlurViewGetBlurredTexture(void)
358 ToolkitTestApplication application;
360 tet_infoline( "UtcDaliSuperBlurViewGetBlurredTexture" );
362 SuperBlurView blurView = SuperBlurView::New( BLUR_LEVELS );
363 blurView.SetSize( 100.f,100.f );
364 Texture inputTexture = CreateSolidColorTexture( application, Color::GREEN, 100, 100 );
365 blurView.SetTexture( inputTexture );
367 Wait(application, 200); // Make sure all the gaussian blur finished
369 Texture texture1 = blurView.GetBlurredTexture( 1 );
370 DALI_TEST_CHECK( texture1 );
372 Texture texture2 = blurView.GetBlurredTexture( 2 );
373 DALI_TEST_EQUALS( texture2.GetWidth(), 25u, TEST_LOCATION );
374 DALI_TEST_EQUALS( texture2.GetHeight(), 25u, TEST_LOCATION );
376 Texture texture3 = blurView.GetBlurredTexture( 3 );
377 DALI_TEST_CHECK( texture3 );
382 int UtcDaliSuperBlurViewBlurSignal(void)
384 ToolkitTestApplication application;
386 tet_infoline(" UtcDaliSuperBlurViewSignal ");
388 SuperBlurView blurView = SuperBlurView::New( BLUR_LEVELS );
389 blurView.SetSize( 100.f, 100.f );
391 Texture inputTexture = CreateSolidColorTexture( application, Color::GREEN, 50, 50 );
392 blurView.SetTexture( inputTexture );
393 // start multiple guassian blur call, each guassian blur creates two render tasks
394 DALI_TEST_CHECK( Stage::GetCurrent().GetRenderTaskList().GetTaskCount() == 1+BLUR_LEVELS*2);
396 SignalHandler signalHandler;
397 blurView.BlurFinishedSignal().Connect(&signalHandler, &SignalHandler::Callback);
399 // create renderers for the original image and each blurred image
400 Stage::GetCurrent().Add( blurView );
401 Wait(application, 1000);
403 DALI_TEST_EQUALS(blurView.GetRendererCount(), BLUR_LEVELS+1, TEST_LOCATION );
404 //DALI_TEST_EQUALS(signalHandler.GetCalls(), 1, TEST_LOCATION);