X-Git-Url: http://review.tizen.org/git/?p=platform%2Fcore%2Fuifw%2Fdali-toolkit.git;a=blobdiff_plain;f=automated-tests%2Fsrc%2Fdali-toolkit-styling%2Futc-Dali-StyleManager.cpp;h=94d625dbd4fe55d523851d52d95df97af2b70b36;hp=8d93d9c28c7840e644d2e7eee4ae593cdf122c4a;hb=71f37f16f983957d32defb8456fade32c99fcfef;hpb=36dbb1d0b2cd12285c54da4c44359658f2b92281 diff --git a/automated-tests/src/dali-toolkit-styling/utc-Dali-StyleManager.cpp b/automated-tests/src/dali-toolkit-styling/utc-Dali-StyleManager.cpp old mode 100644 new mode 100755 index 8d93d9c..94d625d --- a/automated-tests/src/dali-toolkit-styling/utc-Dali-StyleManager.cpp +++ b/automated-tests/src/dali-toolkit-styling/utc-Dali-StyleManager.cpp @@ -1,5 +1,5 @@ -/* - * Copyright (c) 2016 Samsung Electronics Co., Ltd. + /* + * Copyright (c) 2019 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. @@ -17,6 +17,8 @@ #include #include +#include +#include #include #include #include @@ -25,138 +27,31 @@ #include #include #include +#include +#include +#include +#include +#include +#include using namespace Dali; using namespace Dali::Toolkit; namespace { -const char* defaultTheme = -"{\n" -" \"styles\":\n" -" {\n" -" \"textlabel\":\n" -" {\n" -" \"pointSize\":18\n" -" },\n" -"\n" -" \"textlabelFontSize0\":\n" -" {\n" -" \"pointSize\":8\n" -" },\n" -" \"textlabelFontSize1\":\n" -" {\n" -" \"pointSize\":10\n" -" },\n" -" \"textlabelFontSize2\":\n" -" {\n" -" \"pointSize\":15\n" -" },\n" -" \"textlabelFontSize3\":\n" -" {\n" -" \"pointSize\":19\n" -" },\n" -" \"textlabelFontSize4\":\n" -" {\n" -" \"pointSize\":25\n" -" },\n" -"\n" -" \"textfield\":\n" -" {\n" -" \"pointSize\":18,\n" -" \"primaryCursorColor\":[0.0,0.72,0.9,1.0],\n" -" \"secondaryCursorColor\":[0.0,0.72,0.9,1.0],\n" -" \"cursorWidth\":3,\n" -" \"selectionHighlightColor\":[0.75,0.96,1.0,1.0],\n" -" \"grabHandleImage\" : \"{DALI_STYLE_IMAGE_DIR}cursor_handler_drop_center.png\",\n" -" \"selectionHandleImageLeft\" : {\"filename\":\"{DALI_STYLE_IMAGE_DIR}selection_handle_drop_left.png\" },\n" -" \"selectionHandleImageRight\": {\"filename\":\"{DALI_STYLE_IMAGE_DIR}selection_handle_drop_right.png\" }\n" -" },\n" -"\n" -" \"textfieldFontSize0\":\n" -" {\n" -" \"pointSize\":10\n" -" },\n" -" \"textfieldFontSize1\":\n" -" {\n" -" \"pointSize\":10\n" -" },\n" -" \"textfieldFontSize2\":\n" -" {\n" -" \"pointSize\":10\n" -" },\n" -" \"textfieldFontSize3\":\n" -" {\n" -" \"pointSize\":10\n" -" },\n" -" \"textfieldFontSize4\":\n" -" {\n" -" \"pointSize\":10\n" -" },\n" -" \"textselectionpopup\":\n" -" {\n" -" \"popupMaxSize\":[656,72],\n" -" \"optionDividerSize\":[2,0],\n" -" \"popupDividerColor\":[0.23,0.72,0.8,0.11],\n" -" \"popupIconColor\":[1.0,1.0,1.0,1.0],\n" -" \"popupPressedColor\":[0.24,0.72,0.8,0.11],\n" -" \"background\": {\n" -" \"rendererType\": \"nPatch\",\n" -" \"imageUrl\": \"{DALI_IMAGE_DIR}selection-popup-bg.9.png\"\n" -" },\n" -" \"popupFadeInDuration\":0.25,\n" -" \"popupFadeOutDuration\":0.25\n" -" },\n" -" \"textselectionpopupbutton\":\n" -" {\n" -" \"label\":\n" -" {\n" -" \"pointSize\":8,\n" -" \"fontStyle\":\"{\\\\""weight\\\\"":\\\\""light\\\\""}\"\n" -" }\n" -" },\n" -" \"textselectiontoolbar\":\n" -" {\n" -" \"enableOvershoot\":true,\n" -" \"scrollView\":\n" -" {\n" -" \"overshootAnimationSpeed\":360.0,\n" -" \"overshootSize\":[720.0,130.0]\n" -" }\n" -" },\n" -" \"scrollview\":\n" -" {\n" -" \"overshootEffectColor\":\"B018\",\n" -" \"overshootAnimationSpeed\":360.0,\n" -" \"overshootSize\":[720.0,130.0]\n" -" },\n" -" \"itemview\":\n" -" {\n" -" \"overshootEffectColor\":\"B018\",\n" -" \"overshootAnimationSpeed\":360.0,\n" -" \"overshootSize\":[720.0,130.0]\n" -" },\n" -" \"texteditor\":\n" -" {\n" -" \"pointSize\":18,\n" -" \"primaryCursorColor\":[0.0,0.72,0.9,1.0],\n" -" \"secondaryCursorColor\":[0.0,0.72,0.9,1.0],\n" -" \"cursorWidth\":3,\n" -" \"selectionHighlightColor\":[0.75,0.96,1.0,1.0],\n" -" \"grabHandleImage\" : \"{DALI_STYLE_IMAGE_DIR}cursor_handler_drop_center.png\",\n" -" \"selectionHandleImageLeft\" : {\"filename\":\"{DALI_STYLE_IMAGE_DIR}selection_handle_drop_left.png\" },\n" -" \"selectionHandleImageRight\": {\"filename\":\"{DALI_STYLE_IMAGE_DIR}selection_handle_drop_right.png\" }\n" -" }\n" -" }\n" -"}\n"; +std::string defaultTheme; } // anonymous namespace + void dali_style_manager_startup(void) { test_return_value = TET_UNDEF; + + std::ifstream t("src/dali-toolkit-styling/default-theme.json"); + defaultTheme = std::string((std::istreambuf_iterator(t)), std::istreambuf_iterator()); } void dali_style_manager_cleanup(void) @@ -164,6 +59,54 @@ void dali_style_manager_cleanup(void) test_return_value = TET_PASS; } + +Visual::Base CheckVisual( Impl::DummyControl& dummyImpl, Property::Index visualId, int type, const char* location ) +{ + DALI_TEST_EQUALS(dummyImpl.IsVisualEnabled(visualId), true, location); + Visual::Base visual = dummyImpl.GetVisual(visualId); + DALI_TEST_EQUALS( (bool)visual, true, location ); + Property::Map map; + visual.CreatePropertyMap( map ); + Property::Value* value = map.Find( Toolkit::Visual::Property::TYPE ); + DALI_TEST_EQUALS( value != NULL, true, location ); + + int visualType; + value->Get( visualType ); + DALI_TEST_EQUALS( visualType, type, location ); + return visual; +} + + +Integration::Bitmap* CreateBitmap( unsigned int imageWidth, unsigned int imageHeight, unsigned int initialColor, Pixel::Format pixelFormat ) +{ + Integration::Bitmap* bitmap = Integration::Bitmap::New( Integration::Bitmap::BITMAP_2D_PACKED_PIXELS, ResourcePolicy::OWNED_RETAIN ); + Integration::PixelBuffer* pixbuffer = bitmap->GetPackedPixelsProfile()->ReserveBuffer( pixelFormat, imageWidth, imageHeight, imageWidth, imageHeight ); + unsigned int bytesPerPixel = GetBytesPerPixel( pixelFormat ); + + memset( pixbuffer, initialColor, imageHeight * imageWidth * bytesPerPixel ); + + return bitmap; +} + +Integration::ResourcePointer CustomizeNinePatch( ToolkitTestApplication& application, + unsigned int ninePatchImageWidth, + unsigned int ninePatchImageHeight) +{ + TestPlatformAbstraction& platform = application.GetPlatform(); + + Pixel::Format pixelFormat = Pixel::RGBA8888; + + tet_infoline("Create Bitmap"); + platform.SetClosestImageSize(Vector2( ninePatchImageWidth, ninePatchImageHeight)); + Integration::Bitmap* bitmap = CreateBitmap( ninePatchImageWidth, ninePatchImageHeight, 0xFF, pixelFormat ); + + tet_infoline("Getting resource"); + Integration::ResourcePointer resourcePtr(bitmap); + platform.SetSynchronouslyLoadedResource( resourcePtr); + + return resourcePtr; +} + int UtcDaliStyleManagerConstructorP(void) { ToolkitTestApplication application; @@ -176,7 +119,7 @@ int UtcDaliStyleManagerConstructorP(void) int UtcDaliStyleManagerCopyConstructorP(void) { - TestApplication application; + ToolkitTestApplication application; StyleManager styleManager = StyleManager::Get(); StyleManager copyOfStyleManager( styleManager ); @@ -187,7 +130,7 @@ int UtcDaliStyleManagerCopyConstructorP(void) int UtcDaliStyleManagerAssignmentOperatorP(void) { - TestApplication application; + ToolkitTestApplication application; StyleManager styleManager = StyleManager::Get(); StyleManager copyOfStyleManager = styleManager; @@ -258,6 +201,10 @@ int UtcDaliStyleManagerApplyTheme(void) const char* json1 = "{\n" + " \"constants\":\n" + " {\n" + " \"CONFIG_SCRIPT_LOG_LEVEL\":\"Verbose\"\n" + " },\n" " \"styles\":\n" " {\n" " \"testbutton\":\n" @@ -291,6 +238,12 @@ int UtcDaliStyleManagerApplyTheme(void) styleManager.StyleChangedSignal().Connect(&styleChangedSignalHandler, &StyleChangedSignalChecker::OnStyleChanged); + // To ensure we make VisualFactory + VisualFactory factory = VisualFactory::Get(); + Property::Map propertyMap; + propertyMap.Insert( Toolkit::Visual::Property::TYPE, Visual::TEXT ); + Visual::Base textVisual = factory.CreateVisual( propertyMap ); + // Render and notify application.SendNotification(); application.Render(); @@ -362,6 +315,10 @@ int UtcDaliStyleManagerApplyDefaultTheme(void) const char* defaultTheme = "{\n" + " \"constants\":\n" + " {\n" + " \"CONFIG_SCRIPT_LOG_LEVEL\":\"Concise\"\n" + " },\n" " \"styles\":\n" " {\n" " \"testbutton\":\n" @@ -505,6 +462,10 @@ int UtcDaliStyleManagerApplyStyle(void) const char* json1 = "{\n" + " \"constants\":\n" + " {\n" + " \"CONFIG_SCRIPT_LOG_LEVEL\":\"General\"\n" + " },\n" " \"styles\":\n" " {\n" " \"testbutton\":\n" @@ -574,6 +535,107 @@ int UtcDaliStyleManagerApplyStyle(void) } +int UtcDaliStyleManagerIncludeStyleP(void) +{ + ToolkitTestApplication application; + + tet_infoline( "UtcDaliStyleManagerIncludeStyle - test that style sheet inclusion works" ); + + const char* json1 = + "{\n" + " \"includes\":\n" + " [\n" + " \"src/dali-toolkit-styling/theme2.json\"\n" + " ],\n" + " \"styles\":\n" + " {\n" + " \"testbutton\":\n" + " {\n" + " \"foregroundColor\":[0.0,0.0,1.0,1.0]\n" + " }\n" + " }\n" + "}\n"; + + // Add 2 buttons + Test::TestButton testButton = Test::TestButton::New(); + Test::TestButton testButton2 = Test::TestButton::New(); + Stage::GetCurrent().Add( testButton ); + Stage::GetCurrent().Add( testButton2 ); + StyleChangedSignalChecker styleChangedSignalHandler; + StyleManager styleManager = StyleManager::Get(); + + styleManager.StyleChangedSignal().Connect(&styleChangedSignalHandler, &StyleChangedSignalChecker::OnStyleChanged); + + tet_infoline("Apply the style"); + + std::string themeFile("ThemeOne"); + Test::StyleMonitor::SetThemeFileOutput(themeFile, json1); + + styleManager.ApplyTheme(themeFile); + + // Render and notify + application.SendNotification(); + application.Render(); + + Property::Value themedBgColor( testButton.GetProperty(Test::TestButton::Property::BACKGROUND_COLOR) ); + Property::Value themedFgColor( testButton.GetProperty(Test::TestButton::Property::FOREGROUND_COLOR) ); + + DALI_TEST_EQUALS( themedBgColor, Property::Value(Color::YELLOW), 0.001, TEST_LOCATION ); + DALI_TEST_EQUALS( themedFgColor, Property::Value(Color::BLUE), 0.001, TEST_LOCATION ); + + END_TEST; +} + + +int UtcDaliStyleManagerIncludeStyleN(void) +{ + ToolkitTestApplication application; + + tet_infoline( "UtcDaliStyleManagerIncludeStyle - test that style sheet inclusion works, but included stylesheet is bad json" ); + + const char* json1 = + "{\n" + " \"includes\":\n" + " [\n" + " \"src/dali-toolkit-styling/theme3.json\"\n" + " ],\n" + " \"styles\":\n" + " {\n" + " \"testbutton\":\n" + " {\n" + " \"foregroundColor\":[0.0,0.0,1.0,1.0]\n" + " }\n" + " }\n" + "}\n"; + + // Add 2 buttons + Test::TestButton testButton = Test::TestButton::New(); + Test::TestButton testButton2 = Test::TestButton::New(); + Stage::GetCurrent().Add( testButton ); + Stage::GetCurrent().Add( testButton2 ); + StyleChangedSignalChecker styleChangedSignalHandler; + StyleManager styleManager = StyleManager::Get(); + + styleManager.StyleChangedSignal().Connect(&styleChangedSignalHandler, &StyleChangedSignalChecker::OnStyleChanged); + + tet_infoline("Apply the style"); + + std::string themeFile("ThemeOne"); + Test::StyleMonitor::SetThemeFileOutput(themeFile, json1); + + try + { + styleManager.ApplyTheme(themeFile); + } + catch( Dali::DaliException& e ) + { + DALI_TEST_ASSERT( e, "!\"Cannot parse JSON\"", TEST_LOCATION ); + } + + END_TEST; +} + + int UtcDaliStyleManagerStyleChangedSignalFontFamily(void) { tet_infoline("Test that the StyleChange signal is fired when the font family is altered" ); @@ -586,8 +648,11 @@ int UtcDaliStyleManagerStyleChangedSignalFontFamily(void) Toolkit::TextLabel label = Toolkit::TextLabel::New(labelStr); Stage::GetCurrent().Add( label ); - Toolkit::TextLabel label2 = Toolkit::TextLabel::New(labelStr); - Stage::GetCurrent().Add( label2 ); + Toolkit::TextField field = Toolkit::TextField::New(); + Stage::GetCurrent().Add( field ); + + Toolkit::TextEditor editor = Toolkit::TextEditor::New(); + Stage::GetCurrent().Add( editor ); StyleChangedSignalChecker styleChangedSignalHandler; Dali::StyleMonitor styleMonitor = Dali::StyleMonitor::Get(); @@ -610,6 +675,18 @@ int UtcDaliStyleManagerStyleChangedSignalFontFamily(void) DALI_TEST_EQUALS( familyStr, "Times New Roman", TEST_LOCATION); + // Check that the field's font style has been altered + family = field.GetProperty(TextField::Property::FONT_FAMILY); + family.Get( familyStr ); + + DALI_TEST_EQUALS( familyStr, "Times New Roman", TEST_LOCATION); + + // Check that the editor's font style has been altered + family = editor.GetProperty(TextEditor::Property::FONT_FAMILY); + family.Get( familyStr ); + + DALI_TEST_EQUALS( familyStr, "Times New Roman", TEST_LOCATION); + END_TEST; } @@ -860,3 +937,420 @@ int UtcDaliStyleManagerStyleChangedSignalFontSizeTextEditor(void) END_TEST; } + + +int UtcDaliStyleManagerSetState01(void) +{ + tet_infoline("Instantiate dummy control and test state/visual/transition capture" ); + Test::StyleMonitor::SetThemeFileOutput( DALI_STYLE_DIR "dali-toolkit-default-theme.json", + defaultTheme ); + + ToolkitTestApplication application; + + StyleChangedSignalChecker styleChangedSignalHandler; + Dali::StyleMonitor styleMonitor = Dali::StyleMonitor::Get(); + StyleManager styleManager = StyleManager::Get(); + + DummyControl actor = DummyControl::New(true); + actor.SetStyleName("BasicControl"); + Stage::GetCurrent().Add(actor); + + Impl::DummyControl& dummyImpl = static_cast(actor.GetImplementation()); + Integration::ResourcePointer ninePatch = CustomizeNinePatch( application, 30, 30 ); + + DALI_TEST_EQUALS(dummyImpl.IsVisualEnabled(DummyControl::Property::FOREGROUND_VISUAL), true, TEST_LOCATION); + Visual::Base visual1 = dummyImpl.GetVisual(DummyControl::Property::FOREGROUND_VISUAL); + Visual::Base labelVisual1 = dummyImpl.GetVisual(DummyControl::Property::LABEL_VISUAL); + Property::Map labelMap; + labelVisual1.CreatePropertyMap( labelMap ); + labelMap[TextVisual::Property::TEXT] = "New text"; + VisualFactory factory = VisualFactory::Get(); + labelVisual1 = factory.CreateVisual(labelMap); + dummyImpl.UnregisterVisual(DummyControl::Property::LABEL_VISUAL ); + dummyImpl.RegisterVisual(DummyControl::Property::LABEL_VISUAL, labelVisual1 ); + + actor.SetProperty( DevelControl::Property::STATE, DevelControl::FOCUSED ); + + DALI_TEST_EQUALS(dummyImpl.IsVisualEnabled(DummyControl::Property::FOREGROUND_VISUAL), true, TEST_LOCATION); + DALI_TEST_EQUALS(dummyImpl.IsVisualEnabled(DummyControl::Property::FOCUS_VISUAL), true, TEST_LOCATION); + DALI_TEST_EQUALS(dummyImpl.IsVisualEnabled(DummyControl::Property::LABEL_VISUAL), true, TEST_LOCATION); + + Visual::Base visual2 = dummyImpl.GetVisual(DummyControl::Property::FOREGROUND_VISUAL); + Visual::Base labelVisual2 = dummyImpl.GetVisual(DummyControl::Property::LABEL_VISUAL); + DALI_TEST_CHECK( visual1 != visual2 ); + DALI_TEST_CHECK( labelVisual1 != labelVisual2 ); + labelMap.Clear(); + labelVisual2.CreatePropertyMap( labelMap ); + Property::Value* textValue = labelMap.Find( Toolkit::TextVisual::Property::TEXT, "text"); + DALI_TEST_CHECK( textValue ); + Property::Value* pointSizeValue = labelMap.Find( Toolkit::TextVisual::Property::POINT_SIZE, "pointSize"); + tet_infoline( "Check that the instance data has been copied to the new text visual\n"); + DALI_TEST_EQUALS( textValue->Get(), "New text", TEST_LOCATION ); + DALI_TEST_EQUALS( pointSizeValue->Get(), 10, TEST_LOCATION ); + + + actor.SetProperty( DevelControl::Property::STATE, DevelControl::DISABLED ); + + DALI_TEST_EQUALS(dummyImpl.IsVisualEnabled(DummyControl::Property::FOREGROUND_VISUAL), true, TEST_LOCATION); + + Visual::Base visual3 = dummyImpl.GetVisual(DummyControl::Property::FOREGROUND_VISUAL); + Visual::Base focusVisual = dummyImpl.GetVisual(DummyControl::Property::FOCUS_VISUAL); + DALI_TEST_CHECK( !focusVisual ); + DALI_TEST_EQUALS(dummyImpl.IsVisualEnabled(DummyControl::Property::FOCUS_VISUAL), false, TEST_LOCATION); + + DALI_TEST_CHECK( visual1 != visual3 ); + DALI_TEST_CHECK( visual2 != visual3 ); + + Visual::Base labelVisual3 = dummyImpl.GetVisual(DummyControl::Property::LABEL_VISUAL); + DALI_TEST_CHECK( labelVisual2 != labelVisual3 ); + + labelVisual2.CreatePropertyMap( labelMap ); + textValue = labelMap.Find(Toolkit::TextVisual::Property::TEXT, "text"); + DALI_TEST_CHECK( textValue ); + pointSizeValue = labelMap.Find(Toolkit::TextVisual::Property::POINT_SIZE, "pointSize"); + tet_infoline( "Check that the instance data has been copied to the new text visual\n"); + DALI_TEST_EQUALS( textValue->Get(), "New text", TEST_LOCATION ); + DALI_TEST_EQUALS( pointSizeValue->Get(), 10, TEST_LOCATION ); + + END_TEST; +} + +int UtcDaliStyleManagerSetState02(void) +{ + tet_infoline("Instantiate dummy control and test state/visual/transition capture" ); + Test::StyleMonitor::SetThemeFileOutput( DALI_STYLE_DIR "dali-toolkit-default-theme.json", + defaultTheme ); + + ToolkitTestApplication application; + + StyleChangedSignalChecker styleChangedSignalHandler; + Dali::StyleMonitor styleMonitor = Dali::StyleMonitor::Get(); + StyleManager styleManager = StyleManager::Get(); + + DummyControl actor = DummyControl::New(true); + actor.SetStyleName("BasicControl"); + Stage::GetCurrent().Add(actor); + + Impl::DummyControl& dummyImpl = static_cast(actor.GetImplementation()); + Integration::ResourcePointer ninePatch = CustomizeNinePatch( application, 30, 30 ); + + int state = actor.GetProperty( DevelControl::Property::STATE ); + DALI_TEST_EQUALS( state, (int) DevelControl::NORMAL, TEST_LOCATION ); + + DALI_TEST_EQUALS(dummyImpl.IsVisualEnabled(DummyControl::Property::FOREGROUND_VISUAL), true, TEST_LOCATION); + Visual::Base visual1 = dummyImpl.GetVisual(DummyControl::Property::FOREGROUND_VISUAL); + + actor.SetProperty( DevelControl::Property::STATE, + Property::Map().Add( "state", "FOCUSED" ).Add("withTransitions", false)); + + state = actor.GetProperty( DevelControl::Property::STATE ); + DALI_TEST_EQUALS( state, (int) DevelControl::FOCUSED, TEST_LOCATION ); + + DALI_TEST_EQUALS(dummyImpl.IsVisualEnabled(DummyControl::Property::FOREGROUND_VISUAL), true, TEST_LOCATION); + DALI_TEST_EQUALS(dummyImpl.IsVisualEnabled(DummyControl::Property::FOCUS_VISUAL), true, TEST_LOCATION); + + Visual::Base visual2 = dummyImpl.GetVisual(DummyControl::Property::FOREGROUND_VISUAL); + DALI_TEST_CHECK( visual1 != visual2 ); + + actor.SetProperty( DevelControl::Property::STATE, + Property::Map().Add( "state", "DISABLED" ).Add("withTransitions", false)); + + state = actor.GetProperty( DevelControl::Property::STATE ); + DALI_TEST_EQUALS( state, (int) DevelControl::DISABLED, TEST_LOCATION ); + + DALI_TEST_EQUALS(dummyImpl.IsVisualEnabled(DummyControl::Property::FOREGROUND_VISUAL), true, TEST_LOCATION); + + Visual::Base visual3 = dummyImpl.GetVisual(DummyControl::Property::FOREGROUND_VISUAL); + + Visual::Base testVisual = dummyImpl.GetVisual(DummyControl::Property::FOCUS_VISUAL); + DALI_TEST_CHECK( !testVisual ); + testVisual = dummyImpl.GetVisual(DummyControl::Property::TEST_VISUAL); + DALI_TEST_CHECK( !testVisual ); + testVisual = dummyImpl.GetVisual(DummyControl::Property::TEST_VISUAL2); + DALI_TEST_CHECK( !testVisual ); + testVisual = dummyImpl.GetVisual(DummyControl::Property::LABEL_VISUAL); + DALI_TEST_CHECK( testVisual ); + + + DALI_TEST_CHECK( visual1 != visual3 ); + DALI_TEST_CHECK( visual2 != visual3 ); + + actor.SetProperty( DevelControl::Property::STATE, + Property::Map().Add( "state", "NORMAL" ).Add("withTransitions", false)); + + state = actor.GetProperty( DevelControl::Property::STATE ); + DALI_TEST_EQUALS( state, (int) DevelControl::NORMAL, TEST_LOCATION ); + + DALI_TEST_EQUALS(dummyImpl.IsVisualEnabled(DummyControl::Property::FOREGROUND_VISUAL), true, TEST_LOCATION); + + visual1 = dummyImpl.GetVisual(DummyControl::Property::FOREGROUND_VISUAL); + DALI_TEST_CHECK( visual1 ); + + Visual::Base focusVisual = dummyImpl.GetVisual(DummyControl::Property::FOCUS_VISUAL); + DALI_TEST_CHECK( !focusVisual ); + DALI_TEST_EQUALS(dummyImpl.IsVisualEnabled(DummyControl::Property::FOCUS_VISUAL), false, TEST_LOCATION); + + + END_TEST; +} + + +int UtcDaliStyleManagerSetState03N(void) +{ + tet_infoline("Instantiate dummy control and test state transition without state style" ); + Test::StyleMonitor::SetThemeFileOutput( DALI_STYLE_DIR "dali-toolkit-default-theme.json", + defaultTheme ); + + ToolkitTestApplication application; + + StyleChangedSignalChecker styleChangedSignalHandler; + Dali::StyleMonitor styleMonitor = Dali::StyleMonitor::Get(); + StyleManager styleManager = StyleManager::Get(); + + DummyControl actor = DummyControl::New(true); + actor.SetStyleName("NoStyles"); + Stage::GetCurrent().Add(actor); + + Impl::DummyControl& dummyImpl = static_cast(actor.GetImplementation()); + Property::Map propertyMap; + propertyMap.Insert(Visual::Property::TYPE, Visual::COLOR); + propertyMap.Insert(ColorVisual::Property::MIX_COLOR, Color::BLUE); + VisualFactory factory = VisualFactory::Get(); + Visual::Base visual = factory.CreateVisual( propertyMap ); + dummyImpl.RegisterVisual( DummyControl::Property::TEST_VISUAL, visual ); + + int state = actor.GetProperty( DevelControl::Property::STATE ); + DALI_TEST_EQUALS( state, (int) DevelControl::NORMAL, TEST_LOCATION ); + + actor.SetProperty( DevelControl::Property::STATE, + Property::Map().Add( "state", "FOCUSED" ).Add("withTransitions", false)); + + Visual::Base testVisual = dummyImpl.GetVisual(DummyControl::Property::TEST_VISUAL); + DALI_TEST_CHECK( testVisual = visual ); + + state = actor.GetProperty( DevelControl::Property::STATE ); + DALI_TEST_EQUALS( state, (int) DevelControl::FOCUSED, TEST_LOCATION ); + + actor.SetProperty( DevelControl::Property::STATE, + Property::Map().Add( "state", "DISABLED" ).Add("withTransitions", false)); + + testVisual = dummyImpl.GetVisual(DummyControl::Property::TEST_VISUAL); + DALI_TEST_CHECK( testVisual = visual ); + + state = actor.GetProperty( DevelControl::Property::STATE ); + DALI_TEST_EQUALS( state, (int) DevelControl::DISABLED, TEST_LOCATION ); + + END_TEST; +} + + +int UtcDaliStyleManagerSetState04N(void) +{ + tet_infoline("Instantiate dummy control and test state transition with style without state" ); + Test::StyleMonitor::SetThemeFileOutput( DALI_STYLE_DIR "dali-toolkit-default-theme.json", + defaultTheme ); + + ToolkitTestApplication application; + + StyleChangedSignalChecker styleChangedSignalHandler; + Dali::StyleMonitor styleMonitor = Dali::StyleMonitor::Get(); + StyleManager styleManager = StyleManager::Get(); + + DummyControl actor = DummyControl::New(true); + actor.SetStyleName("NoStateStyle"); + Stage::GetCurrent().Add(actor); + + Impl::DummyControl& dummyImpl = static_cast(actor.GetImplementation()); + Property::Map propertyMap; + propertyMap.Insert(Visual::Property::TYPE, Visual::COLOR); + propertyMap.Insert(ColorVisual::Property::MIX_COLOR, Color::BLUE); + VisualFactory factory = VisualFactory::Get(); + Visual::Base visual = factory.CreateVisual( propertyMap ); + dummyImpl.RegisterVisual( DummyControl::Property::TEST_VISUAL, visual ); + + int state = actor.GetProperty( DevelControl::Property::STATE ); + DALI_TEST_EQUALS( state, (int) DevelControl::NORMAL, TEST_LOCATION ); + + actor.SetProperty( DevelControl::Property::STATE, + Property::Map().Add( "state", "FOCUSED" ).Add("withTransitions", false)); + + Visual::Base testVisual = dummyImpl.GetVisual(DummyControl::Property::TEST_VISUAL); + DALI_TEST_CHECK( testVisual = visual ); + + state = actor.GetProperty( DevelControl::Property::STATE ); + DALI_TEST_EQUALS( state, (int) DevelControl::FOCUSED, TEST_LOCATION ); + + actor.SetProperty( DevelControl::Property::STATE, + Property::Map().Add( "state", "DISABLED" ).Add("withTransitions", false)); + + testVisual = dummyImpl.GetVisual(DummyControl::Property::TEST_VISUAL); + DALI_TEST_CHECK( testVisual = visual ); + + state = actor.GetProperty( DevelControl::Property::STATE ); + DALI_TEST_EQUALS( state, (int) DevelControl::DISABLED, TEST_LOCATION ); + + END_TEST; +} + +int UtcDaliStyleManagerSetSubState01(void) +{ + tet_infoline("Instantiate dummy control and test state/visual/transition capture" ); + Test::StyleMonitor::SetThemeFileOutput( DALI_STYLE_DIR "dali-toolkit-default-theme.json", + defaultTheme ); + + ToolkitTestApplication application; + + StyleChangedSignalChecker styleChangedSignalHandler; + Dali::StyleMonitor styleMonitor = Dali::StyleMonitor::Get(); + StyleManager styleManager = StyleManager::Get(); + + DummyControl actor = DummyControl::New(true); + actor.SetProperty(DevelControl::Property::STATE, "NORMAL"); + actor.SetProperty(DevelControl::Property::SUB_STATE, "SELECTED"); + actor.SetStyleName("ComplexControl"); + Stage::GetCurrent().Add(actor); + + Integration::ResourcePointer ninePatch = CustomizeNinePatch( application, 30, 30 ); + + Impl::DummyControl& dummyImpl = static_cast(actor.GetImplementation()); + + CheckVisual( dummyImpl, DummyControl::Property::FOREGROUND_VISUAL, Toolkit::Visual::IMAGE, TEST_LOCATION); + CheckVisual( dummyImpl, DummyControl::Property::TEST_VISUAL, Toolkit::Visual::IMAGE, TEST_LOCATION); + CheckVisual( dummyImpl, DummyControl::Property::TEST_VISUAL2, Toolkit::Visual::GRADIENT, TEST_LOCATION); + + actor.SetProperty(DevelControl::Property::SUB_STATE, "UNSELECTED"); + + CheckVisual( dummyImpl, DummyControl::Property::FOREGROUND_VISUAL, Toolkit::Visual::IMAGE, TEST_LOCATION); + CheckVisual( dummyImpl, DummyControl::Property::TEST_VISUAL, Toolkit::Visual::IMAGE, TEST_LOCATION); + CheckVisual( dummyImpl, DummyControl::Property::TEST_VISUAL2, Toolkit::Visual::COLOR, TEST_LOCATION); + + actor.SetProperty(DevelControl::Property::SUB_STATE, "SELECTED"); + + CheckVisual( dummyImpl, DummyControl::Property::FOREGROUND_VISUAL, Toolkit::Visual::IMAGE, TEST_LOCATION); + CheckVisual( dummyImpl, DummyControl::Property::TEST_VISUAL, Toolkit::Visual::IMAGE, TEST_LOCATION); + CheckVisual( dummyImpl, DummyControl::Property::TEST_VISUAL2, Toolkit::Visual::GRADIENT, TEST_LOCATION); + + END_TEST; +} + + +int UtcDaliStyleManagerSetSubState02(void) +{ + tet_infoline("Instantiate complex control and test state/substate change" ); + Test::StyleMonitor::SetThemeFileOutput( DALI_STYLE_DIR "dali-toolkit-default-theme.json", + defaultTheme ); + + ToolkitTestApplication application; + + StyleChangedSignalChecker styleChangedSignalHandler; + Dali::StyleMonitor styleMonitor = Dali::StyleMonitor::Get(); + StyleManager styleManager = StyleManager::Get(); + + DummyControl actor = DummyControl::New(true); + actor.SetProperty(DevelControl::Property::STATE, "NORMAL"); + actor.SetProperty(DevelControl::Property::SUB_STATE, "SELECTED"); + tet_infoline( "Setting state to NORMAL/SELECTED before re-styling\n"); + + actor.SetStyleName("ComplexControl"); + Stage::GetCurrent().Add(actor); + + Integration::ResourcePointer ninePatch = CustomizeNinePatch( application, 30, 30 ); + + Impl::DummyControl& dummyImpl = static_cast(actor.GetImplementation()); + + CheckVisual( dummyImpl, DummyControl::Property::FOREGROUND_VISUAL, Toolkit::Visual::IMAGE, TEST_LOCATION); + CheckVisual( dummyImpl, DummyControl::Property::TEST_VISUAL2, Toolkit::Visual::GRADIENT, TEST_LOCATION); + + actor.SetProperty(DevelControl::Property::SUB_STATE, "UNSELECTED"); + tet_infoline( "Changing substate to UNSELECTED - check visual changes\n"); + + CheckVisual( dummyImpl, DummyControl::Property::FOREGROUND_VISUAL, Toolkit::Visual::IMAGE, TEST_LOCATION); + CheckVisual( dummyImpl, DummyControl::Property::TEST_VISUAL2, Toolkit::Visual::COLOR, TEST_LOCATION); + + actor.SetProperty(DevelControl::Property::STATE, "FOCUSED"); + tet_infoline( "Changing state to FOCUSED - check visual changes\n"); + + Visual::Base fgVisual1 = CheckVisual( dummyImpl, DummyControl::Property::FOREGROUND_VISUAL, Toolkit::Visual::GRADIENT, TEST_LOCATION); + Visual::Base focusVisual1 = CheckVisual( dummyImpl, DummyControl::Property::FOCUS_VISUAL, Toolkit::Visual::N_PATCH, TEST_LOCATION); + + actor.SetProperty(DevelControl::Property::SUB_STATE, "SELECTED"); + tet_infoline( "Changing substate to SELECTED - Expect no change\n"); + + Visual::Base fgVisual2 = CheckVisual( dummyImpl, DummyControl::Property::FOREGROUND_VISUAL, Toolkit::Visual::GRADIENT, TEST_LOCATION); + Visual::Base focusVisual2 = CheckVisual( dummyImpl, DummyControl::Property::FOCUS_VISUAL, Toolkit::Visual::N_PATCH, TEST_LOCATION); + + DALI_TEST_CHECK( fgVisual1 == fgVisual2 ); + DALI_TEST_CHECK( focusVisual1 == focusVisual2 ); + + actor.SetProperty(DevelControl::Property::STATE, "NORMAL"); + tet_infoline( "Changing state to NORMAL - Expect to change to NORMAL/SELECTED \n"); + + CheckVisual( dummyImpl, DummyControl::Property::FOREGROUND_VISUAL, Toolkit::Visual::IMAGE, TEST_LOCATION); + CheckVisual( dummyImpl, DummyControl::Property::TEST_VISUAL2, Toolkit::Visual::GRADIENT, TEST_LOCATION); + + Visual::Base focusVisual = dummyImpl.GetVisual(DummyControl::Property::FOCUS_VISUAL); + DALI_TEST_CHECK( ! focusVisual ); + + actor.SetProperty(DevelControl::Property::STATE, "DISABLED"); + tet_infoline( "Changing state to DISABLED - Expect to change to DISABLED/SELECTED \n"); + + CheckVisual( dummyImpl, DummyControl::Property::FOREGROUND_VISUAL, Toolkit::Visual::COLOR, TEST_LOCATION); + CheckVisual( dummyImpl, DummyControl::Property::TEST_VISUAL, Toolkit::Visual::IMAGE, TEST_LOCATION); + + Visual::Base testVisual = dummyImpl.GetVisual(DummyControl::Property::FOCUS_VISUAL); + DALI_TEST_CHECK( ! testVisual ); + testVisual = dummyImpl.GetVisual(DummyControl::Property::LABEL_VISUAL); + DALI_TEST_CHECK( ! testVisual ); + + END_TEST; +} + + +int UtcDaliStyleManagerConfigSectionTest(void) +{ + tet_infoline("Test that the properties in config section are works" ); + + const char* defaultTheme = + "{\n" + " \"constants\":\n" + " {\n" + " \"TEST\":\"broken\"\n" + " },\n" + " \"config\":\n" + " {\n" + " \"brokenImageUrl\":\"{TEST}|{TEST}|{TEST|TEST.png\",\n" + " \"alwaysShowFocus\":false,\n" + " \"clearFocusOnEscape\":false\n" + " },\n" + " \"styles\":\n" + " {\n" + " }\n" + "}\n"; + + Test::StyleMonitor::SetThemeFileOutput( DALI_STYLE_DIR "dali-toolkit-default-theme.json", defaultTheme ); + + ToolkitTestApplication application; + + Toolkit::StyleManager styleManager = Toolkit::StyleManager::Get(); + + Property::Map config = Toolkit::DevelStyleManager::GetConfigurations( styleManager ); + bool alwaysShowFocus = config["alwaysShowFocus"].Get(); + DALI_TEST_CHECK( !alwaysShowFocus ); + bool clearFocusOnEscape = config["clearFocusOnEscape"].Get(); + DALI_TEST_CHECK( !clearFocusOnEscape ); + std::string brokenImageUrl = config["brokenImageUrl"].Get(); + DALI_TEST_CHECK( brokenImageUrl.compare( "broken|broken|{TEST|TEST.png" ) == 0 ); + + // For coverage + Toolkit::TextEditor editor = Toolkit::TextEditor::New(); + editor.SetKeyboardFocusable( true ); + Stage::GetCurrent().Add( editor ); + + Toolkit::KeyboardFocusManager::Get().SetCurrentFocusActor( editor ); + + application.ProcessEvent( Integration::KeyEvent( "", "", "", DALI_KEY_ESCAPE, 0, 0, Integration::KeyEvent::Down, "", "", Device::Class::NONE, Device::Subclass::NONE ) ); + application.SendNotification(); + application.Render(); + + END_TEST; +}