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-Control.cpp;h=93311ed0a44f98c97c58c6ad6e2480c72cdba8ed;hp=c58bb83862c4abe0b10a4cb6ca9236612b1d1927;hb=f3da11c2818c6d17706fbb2417f21b602b3190f5;hpb=77c1621da0d4f13d67f9ed0b767a7fa640590830 diff --git a/automated-tests/src/dali-toolkit/utc-Dali-Control.cpp b/automated-tests/src/dali-toolkit/utc-Dali-Control.cpp index c58bb83..93311ed 100644 --- a/automated-tests/src/dali-toolkit/utc-Dali-Control.cpp +++ b/automated-tests/src/dali-toolkit/utc-Dali-Control.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014 Samsung Electronics Co., Ltd. + * Copyright (c) 2015 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. @@ -55,6 +55,15 @@ void TestVoidCallback() { } +static bool gKeyInputFocusCallBackCalled; + +static void TestKeyInputFocusCallback( Control control ) +{ + tet_infoline(" TestKeyInputFocusCallback"); + + gKeyInputFocusCallBackCalled = true; +} + } // namespace /////////////////////////////////////////////////////////////////////////////////////////////////// @@ -195,17 +204,16 @@ int UtcDaliControlKeyInputFocus(void) END_TEST; } -int UtcDaliControlGetImplementation(void) +int UtcDaliControlGetImplementationN(void) { ToolkitTestApplication application; - DummyControl control; // Get Empty { try { - Toolkit::Internal::Control& controlImpl = control.GetImplementation(); + Toolkit::Internal::Control& controlImpl = Toolkit::Internal::GetImplementation( control ); (void)controlImpl; // Avoid unused warning tet_result(TET_FAIL); } @@ -214,13 +222,20 @@ int UtcDaliControlGetImplementation(void) tet_result(TET_PASS); } } + END_TEST; +} + +int UtcDaliControlGetImplementationConstN(void) +{ + ToolkitTestApplication application; + DummyControl control; // Get Const Empty { try { const DummyControl constControl(control); - const Toolkit::Internal::Control& controlImpl = constControl.GetImplementation(); + const Toolkit::Internal::Control& controlImpl = Toolkit::Internal::GetImplementation( constControl ); (void)controlImpl; // Avoid unused warning tet_result(TET_FAIL); } @@ -229,14 +244,19 @@ int UtcDaliControlGetImplementation(void) tet_result(TET_PASS); } } + END_TEST; +} - control = DummyControl::New(); +int UtcDaliControlGetImplementationP(void) +{ + ToolkitTestApplication application; + DummyControl control = DummyControl::New(); // Get { try { - Toolkit::Internal::Control& controlImpl = control.GetImplementation(); + Toolkit::Internal::Control& controlImpl = Toolkit::Internal::GetImplementation( control ); (void)controlImpl; // Avoid unused warning tet_result(TET_PASS); } @@ -245,13 +265,19 @@ int UtcDaliControlGetImplementation(void) tet_result(TET_FAIL); } } + END_TEST; +} +int UtcDaliControlGetImplementationConstP(void) +{ + ToolkitTestApplication application; + DummyControl control = DummyControl::New(); // Get Const { try { const DummyControl constControl(control); - const Toolkit::Internal::Control& controlImpl = constControl.GetImplementation(); + const Toolkit::Internal::Control& controlImpl = Toolkit::Internal::GetImplementation( constControl ); (void)controlImpl; // Avoid unused warning tet_result(TET_PASS); } @@ -271,28 +297,24 @@ int UtcDaliControlSignalConnectDisconnect(void) DummyControl dummy = DummyControlImpl::New(); Actor actor = Actor::New(); - DALI_TEST_EQUALS( actor.SetSizeSignal().GetConnectionCount(), 0u, TEST_LOCATION ); - Toolkit::Internal::Control& control = dummy.GetImplementation(); + DALI_TEST_EQUALS( actor.OnStageSignal().GetConnectionCount(), 0u, TEST_LOCATION ); + Toolkit::Internal::Control& control = Toolkit::Internal::GetImplementation( dummy ); DummyControlImpl* dummyImpl = dynamic_cast(&control); DALI_TEST_CHECK( dummyImpl ); - actor.SetSizeSignal().Connect( dummyImpl, &DummyControlImpl::CustomSlot1 ); - DALI_TEST_EQUALS( actor.SetSizeSignal().GetConnectionCount(), 1u, TEST_LOCATION ); + actor.OnStageSignal().Connect( dummyImpl, &DummyControlImpl::CustomSlot1 ); + DALI_TEST_EQUALS( actor.OnStageSignal().GetConnectionCount(), 1u, TEST_LOCATION ); DALI_TEST_EQUALS( dummyImpl->mCustomSlot1Called, false, TEST_LOCATION ); - DALI_TEST_EQUALS( dummyImpl->mCustomSlot1Value, Vector3::ZERO, TEST_LOCATION ); - const Vector3 newSize( 10, 10, 0 ); - actor.SetSize( newSize ); + Stage::GetCurrent().Add( actor ); DALI_TEST_EQUALS( dummyImpl->mCustomSlot1Called, true, TEST_LOCATION ); - DALI_TEST_EQUALS( dummyImpl->mCustomSlot1Value, newSize, TEST_LOCATION ); dummyImpl->mCustomSlot1Called = false; - actor.SetSizeSignal().Disconnect( dummyImpl, &DummyControlImpl::CustomSlot1 ); - DALI_TEST_EQUALS( actor.SetSizeSignal().GetConnectionCount(), 0u, TEST_LOCATION ); - const Vector3 ignoredSize( 20, 20, 0 ); - actor.SetSize( ignoredSize ); + actor.OnStageSignal().Disconnect( dummyImpl, &DummyControlImpl::CustomSlot1 ); + DALI_TEST_EQUALS( actor.OnStageSignal().GetConnectionCount(), 0u, TEST_LOCATION ); + Stage::GetCurrent().Remove( actor ); + Stage::GetCurrent().Add( actor ); DALI_TEST_EQUALS( dummyImpl->mCustomSlot1Called, false, TEST_LOCATION ); - DALI_TEST_EQUALS( dummyImpl->mCustomSlot1Value, newSize/*not ignoredSize*/, TEST_LOCATION ); } END_TEST; } @@ -305,23 +327,21 @@ int UtcDaliControlSignalAutomaticDisconnect(void) { DummyControl dummy = DummyControlImpl::New(); - Toolkit::Internal::Control& control = dummy.GetImplementation(); + Toolkit::Internal::Control& control = Toolkit::Internal::GetImplementation( dummy ); DummyControlImpl* dummyImpl = dynamic_cast(&control); DALI_TEST_CHECK( dummyImpl ); - actor.SetSizeSignal().Connect( dummyImpl, &DummyControlImpl::CustomSlot1 ); - DALI_TEST_EQUALS( actor.SetSizeSignal().GetConnectionCount(), 1u, TEST_LOCATION ); + actor.OnStageSignal().Connect( dummyImpl, &DummyControlImpl::CustomSlot1 ); + DALI_TEST_EQUALS( actor.OnStageSignal().GetConnectionCount(), 1u, TEST_LOCATION ); DALI_TEST_EQUALS( dummyImpl->mCustomSlot1Called, false, TEST_LOCATION ); - DALI_TEST_EQUALS( dummyImpl->mCustomSlot1Value, Vector3::ZERO, TEST_LOCATION ); - const Vector3 newSize( 10, 10, 0 ); - actor.SetSize( newSize ); + Stage::GetCurrent().Add( actor ); DALI_TEST_EQUALS( dummyImpl->mCustomSlot1Called, true, TEST_LOCATION ); - DALI_TEST_EQUALS( dummyImpl->mCustomSlot1Value, newSize, TEST_LOCATION ); + Stage::GetCurrent().Remove( actor ); } // dummyControl automatically disconnects - DALI_TEST_EQUALS( actor.SetSizeSignal().GetConnectionCount(), 0u, TEST_LOCATION ); + DALI_TEST_EQUALS( actor.OnStageSignal().GetConnectionCount(), 0u, TEST_LOCATION ); const Vector3 ignoredSize( 20, 20, 0 ); actor.SetSize( ignoredSize ); @@ -333,26 +353,17 @@ int UtcDaliControlTestParameters(void) ToolkitTestApplication application; DummyControl test = DummyControl::New(); - Vector3 maxSize = test.GetNaturalSize(); - Vector3 minSize = maxSize / 2.0f; + test.SetSize( 0.7f, 0.7f, 0.7f ); - Toolkit::Control::SizePolicy widthPolicy( Control::Fixed ); - Toolkit::Control::SizePolicy heightPolicy( Control::Fixed ); - test.SetSizePolicy( widthPolicy, heightPolicy ); - test.GetSizePolicy( widthPolicy, heightPolicy ); + Stage::GetCurrent().Add( test ); - DALI_TEST_CHECK( widthPolicy == Control::Fixed && heightPolicy == Control::Fixed ); + application.SendNotification(); + application.Render(); - test.SetSize( 0.7f, 0.7f, 0.7f ); float width = 640.0f; float height = test.GetHeightForWidth( width ); - DALI_TEST_CHECK( test.GetWidthForHeight( height ) == width ); - - test.SetMinimumSize( minSize ); - DALI_TEST_CHECK( test.GetMinimumSize() == minSize ); - - test.SetMaximumSize( maxSize ); - DALI_TEST_CHECK( test.GetMaximumSize() == maxSize ); + DALI_TEST_EQUALS( 640.0f, height, TEST_LOCATION ); + DALI_TEST_EQUALS( 640.0f, test.GetWidthForHeight( height ), TEST_LOCATION ); test.KeyEventSignal(); @@ -368,12 +379,23 @@ int UtcDaliControlBackgroundColor(void) ToolkitTestApplication application; Control control = Control::New(); - DALI_TEST_CHECK( !control.GetBackgroundActor() ); DALI_TEST_EQUALS( control.GetBackgroundColor(), Color::TRANSPARENT, TEST_LOCATION ); control.SetBackgroundColor( Color::RED ); - DALI_TEST_CHECK( control.GetBackgroundActor() ); - DALI_TEST_EQUALS( control.GetBackgroundColor(), Color::RED, TEST_LOCATION ); + + Property::Value propValue = control.GetProperty( Control::Property::BACKGROUND ); + Property::Map* resultMap = propValue.GetMap(); + DALI_TEST_CHECK( resultMap->Find( "rendererType" ) ); + DALI_TEST_CHECK( resultMap->Find( "rendererType" )->Get() == "colorRenderer" ); + DALI_TEST_CHECK( resultMap->Find( "blendColor" ) ); + DALI_TEST_CHECK( resultMap->Find( "blendColor" )->Get() == Color::RED ); + + control.SetBackgroundColor( Color::YELLOW ); + + propValue = control.GetProperty( Control::Property::BACKGROUND ); + resultMap = propValue.GetMap(); + DALI_TEST_CHECK( resultMap->Find( "blendColor" ) ); + DALI_TEST_CHECK( resultMap->Find( "blendColor" )->Get() == Color::YELLOW ); END_TEST; } @@ -383,25 +405,25 @@ int UtcDaliControlBackgroundImage(void) ToolkitTestApplication application; Control control = Control::New(); - DALI_TEST_CHECK( !control.GetBackgroundActor() ); DALI_TEST_EQUALS( control.GetBackgroundColor(), Color::TRANSPARENT, TEST_LOCATION ); - Image image = Image::New("TestImage"); - control.SetBackground( image ); - DALI_TEST_CHECK( control.GetBackgroundActor() ); - DALI_TEST_EQUALS( control.GetBackgroundColor(), Color::WHITE, TEST_LOCATION ); + Image image = ResourceImage::New("TestImage"); + control.SetBackgroundImage( image ); - control.SetBackgroundColor( Color::GREEN ); - DALI_TEST_EQUALS( control.GetBackgroundColor(), Color::GREEN, TEST_LOCATION ); + Property::Value propValue = control.GetProperty( Control::Property::BACKGROUND ); + Property::Map* resultMap = propValue.GetMap(); + DALI_TEST_CHECK( resultMap->Find( "rendererType" ) ); + DALI_TEST_CHECK( resultMap->Find( "rendererType" )->Get() == "imageRenderer" ); + DALI_TEST_CHECK( resultMap->Find( "imageUrl" ) ); + DALI_TEST_CHECK( resultMap->Find( "imageUrl" )->Get() == "TestImage" ); - control.ClearBackground(); - DALI_TEST_CHECK( !control.GetBackgroundActor() ); - DALI_TEST_EQUALS( control.GetBackgroundColor(), Color::TRANSPARENT, TEST_LOCATION ); + image = ResourceImage::New("TestImage2"); + control.SetBackgroundImage( image ); - control.SetBackgroundColor( Color::YELLOW ); - control.SetBackground( image ); - DALI_TEST_CHECK( control.GetBackgroundActor() ); - DALI_TEST_EQUALS( control.GetBackgroundColor(), Color::YELLOW, TEST_LOCATION ); + propValue = control.GetProperty( Control::Property::BACKGROUND ); + resultMap = propValue.GetMap(); + DALI_TEST_CHECK( resultMap->Find( "imageUrl" ) ); + DALI_TEST_CHECK( resultMap->Find( "imageUrl" )->Get() == "TestImage2" ); END_TEST; } @@ -411,133 +433,148 @@ int UtcDaliControlBackgroundProperties(void) ToolkitTestApplication application; Control control = Control::New(); - DALI_TEST_CHECK( !control.GetBackgroundActor() ); DALI_TEST_EQUALS( control.GetBackgroundColor(), Color::TRANSPARENT, TEST_LOCATION ); - DALI_TEST_EQUALS( control.GetProperty( Control::PROPERTY_BACKGROUND_COLOR ).Get< Vector4 >(), Color::TRANSPARENT, TEST_LOCATION ); - DALI_TEST_CHECK( control.GetProperty( Control::PROPERTY_BACKGROUND ).Get< Property::Map >().Empty() ); - - control.SetProperty( Control::PROPERTY_BACKGROUND_COLOR, Color::RED ); - DALI_TEST_CHECK( control.GetBackgroundActor() ); - DALI_TEST_EQUALS( control.GetBackgroundColor(), Color::RED, TEST_LOCATION ); - DALI_TEST_EQUALS( control.GetProperty( Control::PROPERTY_BACKGROUND_COLOR ).Get< Vector4 >(), Color::RED, TEST_LOCATION ); + DALI_TEST_CHECK( control.GetProperty( Control::Property::BACKGROUND ).Get< Property::Map >().Empty() ); + + Property::Map colorMap; + colorMap["color"] = Color::RED; + control.SetProperty( Control::Property::BACKGROUND, colorMap ); + Property::Value propValue = control.GetProperty( Control::Property::BACKGROUND ); + Property::Map* resultMap = propValue.GetMap(); + DALI_TEST_CHECK( resultMap->Find( "rendererType" ) ); + DALI_TEST_CHECK( resultMap->Find( "rendererType" )->Get() == "colorRenderer" ); + DALI_TEST_CHECK( resultMap->Find( "blendColor" ) ); + DALI_TEST_CHECK( resultMap->Find( "blendColor" )->Get() == Color::RED ); Property::Map imageMap; imageMap[ "filename" ] = "TestImage"; - Property::Map map; - map[ "image" ] = imageMap; - control.SetProperty( Control::PROPERTY_BACKGROUND, map ); - DALI_TEST_CHECK( control.GetBackgroundActor() ); - DALI_TEST_EQUALS( control.GetBackgroundColor(), Color::RED, TEST_LOCATION ); - DALI_TEST_EQUALS( control.GetProperty( Control::PROPERTY_BACKGROUND_COLOR ).Get< Vector4 >(), Color::RED, TEST_LOCATION ); - - Property::Value propValue = control.GetProperty( Control::PROPERTY_BACKGROUND ); - DALI_TEST_CHECK( propValue.HasKey( "image" ) ); - DALI_TEST_CHECK( propValue.GetValue( "image" ).HasKey( "filename" ) ); - DALI_TEST_CHECK( propValue.GetValue( "image" ).GetValue( "filename" ).Get< std::string>() == "TestImage" ); + control.SetProperty( Control::Property::BACKGROUND, imageMap ); + propValue = control.GetProperty( Control::Property::BACKGROUND ); + resultMap = propValue.GetMap(); + DALI_TEST_CHECK( resultMap->Find( "rendererType" ) ); + DALI_TEST_CHECK( resultMap->Find( "rendererType" )->Get() == "imageRenderer" ); + DALI_TEST_CHECK( resultMap->Find( "imageUrl" ) ); + DALI_TEST_CHECK( resultMap->Find( "imageUrl" )->Get() == "TestImage" ); + + Property::Map rendererMap; + rendererMap["rendererType"] = "colorRenderer"; + rendererMap["blendColor"] = Color::CYAN; + control.SetProperty( Control::Property::BACKGROUND, rendererMap ); + propValue = control.GetProperty( Control::Property::BACKGROUND ); + resultMap = propValue.GetMap(); + DALI_TEST_CHECK( resultMap->Find( "rendererType" ) ); + DALI_TEST_CHECK( resultMap->Find( "rendererType" )->Get() == "colorRenderer" ); + DALI_TEST_CHECK( resultMap->Find( "blendColor" ) ); + DALI_TEST_CHECK( resultMap->Find( "blendColor" )->Get() == Color::CYAN ); Property::Map emptyMap; - control.SetProperty( Control::PROPERTY_BACKGROUND, emptyMap ); - DALI_TEST_CHECK( !control.GetBackgroundActor() ); - DALI_TEST_EQUALS( control.GetBackgroundColor(), Color::TRANSPARENT, TEST_LOCATION ); - DALI_TEST_EQUALS( control.GetProperty( Control::PROPERTY_BACKGROUND_COLOR ).Get< Vector4 >(), Color::TRANSPARENT, TEST_LOCATION ); - DALI_TEST_CHECK( control.GetProperty( Control::PROPERTY_BACKGROUND ).Get< Property::Map >().Empty() ); + control.SetProperty( Control::Property::BACKGROUND, emptyMap ); + DALI_TEST_CHECK( control.GetProperty( Control::Property::BACKGROUND ).Get< Property::Map >().Empty() ); END_TEST; } -int UtcDaliControlSizePolicyProperties(void) +int UtcDaliControlKeyProperties(void) { ToolkitTestApplication application; Control control = Control::New(); + Stage::GetCurrent().Add( control ); - Control::SizePolicy widthPolicy( Control::Fixed ); - Control::SizePolicy heightPolicy( Control::Fixed ); + DALI_TEST_EQUALS( control.HasKeyInputFocus(), control.GetProperty( Control::Property::KEY_INPUT_FOCUS ).Get< bool >(), TEST_LOCATION ); - control.GetSizePolicy( widthPolicy, heightPolicy ); - DALI_TEST_EQUALS( "FIXED", control.GetProperty( Control::PROPERTY_WIDTH_POLICY ).Get< std::string >(), TEST_LOCATION ); - DALI_TEST_EQUALS( "FIXED", control.GetProperty( Control::PROPERTY_HEIGHT_POLICY ).Get< std::string >(), TEST_LOCATION ); + control.SetKeyInputFocus(); + DALI_TEST_EQUALS( true, control.GetProperty( Control::Property::KEY_INPUT_FOCUS ).Get< bool >(), TEST_LOCATION ); - control.SetSizePolicy( Control::Flexible, Control::Range ); - DALI_TEST_EQUALS( "FLEXIBLE", control.GetProperty( Control::PROPERTY_WIDTH_POLICY ).Get< std::string >(), TEST_LOCATION ); - DALI_TEST_EQUALS( "RANGE", control.GetProperty( Control::PROPERTY_HEIGHT_POLICY ).Get< std::string >(), TEST_LOCATION ); + control.ClearKeyInputFocus(); + DALI_TEST_EQUALS( false, control.GetProperty( Control::Property::KEY_INPUT_FOCUS ).Get< bool >(), TEST_LOCATION ); - control.SetProperty( Control::PROPERTY_WIDTH_POLICY, "MAXIMUM" ); - control.SetProperty( Control::PROPERTY_HEIGHT_POLICY, "MINIMUM" ); - control.GetSizePolicy( widthPolicy, heightPolicy ); - DALI_TEST_EQUALS( Control::Maximum, widthPolicy, TEST_LOCATION ); - DALI_TEST_EQUALS( Control::Minimum, heightPolicy, TEST_LOCATION ); + control.SetProperty( Control::Property::KEY_INPUT_FOCUS, true ); + DALI_TEST_EQUALS( true, control.HasKeyInputFocus(), TEST_LOCATION ); END_TEST; } -int UtcDaliControlSizeProperties(void) +int UtcDaliControlGestureSignals(void) +{ + ToolkitTestApplication application; + ConnectionTracker connectionTracker; + Control control = Control::New(); + + // Each gesture detector gets created when connecting to the gesture signals + DALI_TEST_CHECK( !control.GetTapGestureDetector() ); + control.ConnectSignal( &connectionTracker, "tapped", &TestVoidCallback ); + DALI_TEST_CHECK( control.GetTapGestureDetector() ); + + DALI_TEST_CHECK( !control.GetPanGestureDetector() ); + control.ConnectSignal( &connectionTracker, "panned", &TestVoidCallback ); + DALI_TEST_CHECK( control.GetPanGestureDetector() ); + + DALI_TEST_CHECK( !control.GetPinchGestureDetector() ); + control.ConnectSignal( &connectionTracker, "pinched", &TestVoidCallback ); + DALI_TEST_CHECK( control.GetPinchGestureDetector() ); + + DALI_TEST_CHECK( !control.GetLongPressGestureDetector() ); + control.ConnectSignal( &connectionTracker, "longPressed", &TestVoidCallback ); + DALI_TEST_CHECK( control.GetLongPressGestureDetector() ); + + END_TEST; +} + +int UtcDaliControlImplKeyInputFocusGainedSignal(void) { ToolkitTestApplication application; Control control = Control::New(); + Stage::GetCurrent().Add( control ); - DALI_TEST_EQUALS( control.GetMinimumSize(), control.GetProperty( Control::PROPERTY_MINIMUM_SIZE ).Get< Vector3 >(), TEST_LOCATION ); - DALI_TEST_EQUALS( control.GetMaximumSize(), control.GetProperty( Control::PROPERTY_MAXIMUM_SIZE ).Get< Vector3 >(), TEST_LOCATION ); + gKeyInputFocusCallBackCalled = false; + control.KeyInputFocusGainedSignal().Connect(&TestKeyInputFocusCallback); - control.SetMinimumSize( Vector3( 100.0f, 200.0f, 300.0f ) ); - DALI_TEST_EQUALS( Vector3( 100.0f, 200.0f, 300.0f ), control.GetProperty( Control::PROPERTY_MINIMUM_SIZE ).Get< Vector3 >(), TEST_LOCATION ); + application.SendNotification(); + application.Render(); + control.SetKeyInputFocus(); - control.SetMaximumSize( Vector3( 200.0f, 250.0f, 800.0f ) ); - DALI_TEST_EQUALS( Vector3( 200.0f, 250.0f, 800.0f ), control.GetProperty( Control::PROPERTY_MAXIMUM_SIZE ).Get< Vector3 >(), TEST_LOCATION ); + DALI_TEST_CHECK( control.HasKeyInputFocus() ); - control.SetProperty( Control::PROPERTY_MINIMUM_SIZE, Vector3( 1.0f, 2.0f, 3.0f ) ); - control.SetProperty( Control::PROPERTY_MAXIMUM_SIZE, Vector3( 10.0f, 20.0f, 30.0f ) ); - DALI_TEST_EQUALS( control.GetMinimumSize(), Vector3( 1.0f, 2.0f, 3.0f ), TEST_LOCATION ); - DALI_TEST_EQUALS( control.GetMaximumSize(), Vector3( 10.0f, 20.0f, 30.0f ), TEST_LOCATION ); + DALI_TEST_CHECK( gKeyInputFocusCallBackCalled ); END_TEST; } -int UtcDaliControlKeyProperties(void) +int UtcDaliControlImplKeyInputFocusLostSignal(void) { ToolkitTestApplication application; Control control = Control::New(); Stage::GetCurrent().Add( control ); - DALI_TEST_EQUALS( control.HasKeyInputFocus(), control.GetProperty( Control::PROPERTY_KEY_INPUT_FOCUS ).Get< bool >(), TEST_LOCATION ); + gKeyInputFocusCallBackCalled = false; + control.KeyInputFocusLostSignal().Connect(&TestKeyInputFocusCallback); + + application.SendNotification(); + application.Render(); control.SetKeyInputFocus(); - DALI_TEST_EQUALS( true, control.GetProperty( Control::PROPERTY_KEY_INPUT_FOCUS ).Get< bool >(), TEST_LOCATION ); + + DALI_TEST_CHECK( control.HasKeyInputFocus() ); control.ClearKeyInputFocus(); - DALI_TEST_EQUALS( false, control.GetProperty( Control::PROPERTY_KEY_INPUT_FOCUS ).Get< bool >(), TEST_LOCATION ); - control.SetProperty( Control::PROPERTY_KEY_INPUT_FOCUS, true ); - DALI_TEST_EQUALS( true, control.HasKeyInputFocus(), TEST_LOCATION ); + DALI_TEST_CHECK( gKeyInputFocusCallBackCalled ); END_TEST; } -int UtcDaliControlGestureSignals(void) +int UtcDaliControlImplGetControlExtensionP(void) { ToolkitTestApplication application; - ConnectionTracker connectionTracker; Control control = Control::New(); - // Each gesture detector gets created when connecting to the gesture signals - DALI_TEST_CHECK( !control.GetTapGestureDetector() ); - control.ConnectSignal( &connectionTracker, Control::SIGNAL_TAPPED, &TestVoidCallback ); - DALI_TEST_CHECK( control.GetTapGestureDetector() ); - - DALI_TEST_CHECK( !control.GetPanGestureDetector() ); - control.ConnectSignal( &connectionTracker, Control::SIGNAL_PANNED, &TestVoidCallback ); - DALI_TEST_CHECK( control.GetPanGestureDetector() ); - - DALI_TEST_CHECK( !control.GetPinchGestureDetector() ); - control.ConnectSignal( &connectionTracker, Control::SIGNAL_PINCHED, &TestVoidCallback ); - DALI_TEST_CHECK( control.GetPinchGestureDetector() ); + Toolkit::Internal::Control& controlImpl = Toolkit::Internal::GetImplementation( control ); - DALI_TEST_CHECK( !control.GetLongPressGestureDetector() ); - control.ConnectSignal( &connectionTracker, Control::SIGNAL_LONG_PRESSED, &TestVoidCallback ); - DALI_TEST_CHECK( control.GetLongPressGestureDetector() ); + DALI_TEST_CHECK( NULL == controlImpl.GetControlExtension() ); END_TEST; }