X-Git-Url: http://review.tizen.org/git/?p=platform%2Fcore%2Fuifw%2Fdali-toolkit.git;a=blobdiff_plain;f=automated-tests%2Fsrc%2Fdali-toolkit-internal%2Futc-Dali-Text-Controller.cpp;h=ad3660749012600012f729325dc6dcc33ff85a22;hp=cdb29f982d22a9e5c6242ed889f393ce28238a43;hb=a9e879edf14d08f54adf5f712fb2a1c04e8bfc24;hpb=4be17ce4114c629f694703381a0d09cca895850d diff --git a/automated-tests/src/dali-toolkit-internal/utc-Dali-Text-Controller.cpp b/automated-tests/src/dali-toolkit-internal/utc-Dali-Text-Controller.cpp index cdb29f9..ad36607 100644 --- a/automated-tests/src/dali-toolkit-internal/utc-Dali-Text-Controller.cpp +++ b/automated-tests/src/dali-toolkit-internal/utc-Dali-Text-Controller.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2016 Samsung Electronics Co., Ltd. + * Copyright (c) 2017 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. @@ -19,13 +19,14 @@ #include #include -#include #include #include +#include #include #include #include +#include using namespace Dali; using namespace Toolkit; @@ -43,34 +44,6 @@ const char* const OPTION_CLIPBOARD("optionClipboard"); // "Clipboard" popup const Size CONTROL_SIZE( 300.f, 60.f ); -const std::string DEFAULT_FONT_DIR( "/resources/fonts" ); - -class ControlImpl : public ControlInterface, public Text::EditableControlInterface -{ -public: - ControlImpl() - : ControlInterface() - {} - - virtual ~ControlImpl() - {} - - virtual void AddDecoration( Actor& actor, bool needsClipping ) - {} - - virtual void RequestTextRelayout() - {} - - virtual void TextChanged() - {} - - virtual void MaxLengthReached() - {} - - virtual void InputStyleChanged( InputStyle::Mask inputStyleMask ) - {} -}; - std::string gClipboardText; void ContentSelectedCallback( ClipboardEventNotifier& notifier ) { @@ -86,9 +59,73 @@ int UtcDaliTextController(void) // Creates a text controller. ControllerPtr controller = Controller::New(); + DALI_TEST_CHECK( controller ); + + tet_result(TET_PASS); + END_TEST; +} +int UtcDaliTextControllerSetGetScrollEnabled(void) +{ + tet_infoline(" UtcDaliTextControllerSetGetScrollEnabled"); + ToolkitTestApplication application; + + // Creates a text controller. + ControllerPtr controller = Controller::New(); DALI_TEST_CHECK( controller ); + // Configures the text controller similarly to the text-editor. + ConfigureTextEditor( controller ); + + DALI_TEST_CHECK( !controller->IsHorizontalScrollEnabled() ); + DALI_TEST_CHECK( controller->IsVerticalScrollEnabled() ); + + // Configures the text controller similarly to the text-field. + ConfigureTextField( controller ); + + DALI_TEST_CHECK( controller->IsHorizontalScrollEnabled() ); + DALI_TEST_CHECK( !controller->IsVerticalScrollEnabled() ); + + // Configures the text controller similarly to the text-label. + ConfigureTextLabel( controller ); + + DALI_TEST_CHECK( !controller->IsHorizontalScrollEnabled() ); + DALI_TEST_CHECK( !controller->IsVerticalScrollEnabled() ); + + tet_result(TET_PASS); + END_TEST; +} + +int UtcDaliTextControllerSetIsTextElide(void) +{ + tet_infoline(" UtcDaliTextControllerSetIsTextElide"); + ToolkitTestApplication application; + + // Creates a text controller. + ControllerPtr controller = Controller::New(); + DALI_TEST_CHECK( controller ); + + // Configures the text controller similarly to the text-editor. + ConfigureTextEditor( controller ); + DALI_TEST_EQUALS( false, controller->IsTextElideEnabled(), TEST_LOCATION ); + + controller->SetTextElideEnabled( true ); + DALI_TEST_EQUALS( true, controller->IsTextElideEnabled(), TEST_LOCATION ); + + // Configures the text controller similarly to the text-field. + ConfigureTextField( controller ); + DALI_TEST_EQUALS( false, controller->IsTextElideEnabled(), TEST_LOCATION ); + + controller->SetTextElideEnabled( true ); + DALI_TEST_EQUALS( true, controller->IsTextElideEnabled(), TEST_LOCATION ); + + // Configures the text controller similarly to the text-label. + ConfigureTextLabel( controller ); + DALI_TEST_EQUALS( true, controller->IsTextElideEnabled(), TEST_LOCATION ); + + controller->SetTextElideEnabled( false ); + DALI_TEST_EQUALS( false, controller->IsTextElideEnabled(), TEST_LOCATION ); + tet_result(TET_PASS); END_TEST; } @@ -100,7 +137,6 @@ int UtcDaliTextControllerEnableCursorBlinking(void) // Creates a text controller. ControllerPtr controller = Controller::New(); - DALI_TEST_CHECK( controller ); // There is no text input enabled. @@ -149,9 +185,16 @@ int UtcDaliTextControllerImfEvent(void) // Enables the text input. controller->EnableTextInput( decorator ); + // Set the placeholder text. + controller->SetPlaceholderText( Controller::PLACEHOLDER_TYPE_INACTIVE, "Hello Dali" ); + // Creates an ImfManager. ImfManager imfManager = ImfManager::Get(); + // For coverage. + imfEvent = ImfManager::ImfEventData( ImfManager::GETSURROUNDING, "", 0, 0 ); + controller->OnImfEvent( imfManager, imfEvent ); + // Send VOID event. imfEvent = ImfManager::ImfEventData( ImfManager::VOID, "", 0, 0 ); controller->OnImfEvent( imfManager, imfEvent ); @@ -159,6 +202,18 @@ int UtcDaliTextControllerImfEvent(void) controller->GetText( text ); DALI_TEST_CHECK( text.empty() ); + imfEvent = ImfManager::ImfEventData( ImfManager::COMMIT, "Hello ", 0, 6 ); + controller->OnImfEvent( imfManager, imfEvent ); + controller->GetNaturalSize(); + + // Check 'Delete All' key which means the input panel send a big range + imfEvent = ImfManager::ImfEventData( ImfManager::DELETESURROUNDING, "", -100, 100 ); + controller->OnImfEvent( imfManager, imfEvent ); + controller->GetNaturalSize(); + + controller->GetText( text ); + DALI_TEST_EQUALS( "", text, TEST_LOCATION ); + // Send COMMIT event. imfEvent = ImfManager::ImfEventData( ImfManager::COMMIT, "Hello ", 0, 6 ); controller->OnImfEvent( imfManager, imfEvent ); @@ -206,6 +261,13 @@ int UtcDaliTextControllerImfEvent(void) controller->GetText( text ); DALI_TEST_EQUALS( "Hello wo", text, TEST_LOCATION ); + // Send PRIVATECOMMAND event + imfEvent = ImfManager::ImfEventData( ImfManager::PRIVATECOMMAND, "", 0, 0 ); + controller->OnImfEvent( imfManager, imfEvent ); + + controller->GetText( text ); + DALI_TEST_EQUALS( "Hello wo", text, TEST_LOCATION ); + tet_result(TET_PASS); END_TEST; } @@ -402,3 +464,229 @@ int UtcDaliTextControllerSetGetAutoScrollEnabled(void) tet_result(TET_PASS); END_TEST; } + +int UtcDaliTextControllerSetGetCheckProperty(void) +{ + tet_infoline(" UtcDaliTextControllerSetGetCheckProperty"); + ToolkitTestApplication application; + + // Creates a text controller. + ControllerPtr controller = Controller::New(); + + DALI_TEST_CHECK( controller ); + + // Enable the text input. + // Creates a decorator. + Text::DecoratorPtr decorator = Text::Decorator::New( *controller, *controller ); + + // Enables the text input. + controller->EnableTextInput( decorator ); + + DALI_TEST_CHECK( !controller->IsInputModePassword() ); + + // Set the text input to password. + controller->SetInputModePassword( true ); + + DALI_TEST_CHECK( controller->IsInputModePassword() ); + + // Unset the text input to password. + controller->SetInputModePassword( false ); + + DALI_TEST_CHECK( !controller->IsInputModePassword() ); + + tet_result(TET_PASS); + END_TEST; +} + +int UtcDaliTextControllerSetGetTapLongPressAction(void) +{ + tet_infoline(" UtcDaliTextControllerSetGetTapLongPressAction"); + ToolkitTestApplication application; + + // Creates a text controller. + ControllerPtr controller = Controller::New(); + + DALI_TEST_CHECK( controller ); + + // Test first with no decorator. + + DALI_TEST_EQUALS( Controller::NoTextTap::NO_ACTION, controller->GetNoTextDoubleTapAction(), TEST_LOCATION ); + controller->SetNoTextDoubleTapAction( Controller::NoTextTap::HIGHLIGHT ); + DALI_TEST_EQUALS( Controller::NoTextTap::NO_ACTION, controller->GetNoTextDoubleTapAction(), TEST_LOCATION ); + + DALI_TEST_EQUALS( Controller::NoTextTap::NO_ACTION, controller->GetNoTextLongPressAction(), TEST_LOCATION ); + controller->SetNoTextLongPressAction( Controller::NoTextTap::HIGHLIGHT ); + DALI_TEST_EQUALS( Controller::NoTextTap::NO_ACTION, controller->GetNoTextLongPressAction(), TEST_LOCATION ); + + // Add a decorator and re-test. + + // Creates a decorator. + Text::DecoratorPtr decorator = Text::Decorator::New( *controller, *controller ); + + // Enables the text input. + controller->EnableTextInput( decorator ); + + DALI_TEST_EQUALS( Controller::NoTextTap::NO_ACTION, controller->GetNoTextDoubleTapAction(), TEST_LOCATION ); + controller->SetNoTextDoubleTapAction( Controller::NoTextTap::HIGHLIGHT ); + DALI_TEST_EQUALS( Controller::NoTextTap::HIGHLIGHT, controller->GetNoTextDoubleTapAction(), TEST_LOCATION ); + + DALI_TEST_EQUALS( Controller::NoTextTap::SHOW_SELECTION_POPUP, controller->GetNoTextLongPressAction(), TEST_LOCATION ); // The default is SHOW_SELECTION_POPUP + controller->SetNoTextLongPressAction( Controller::NoTextTap::HIGHLIGHT ); + DALI_TEST_EQUALS( Controller::NoTextTap::HIGHLIGHT, controller->GetNoTextLongPressAction(), TEST_LOCATION ); + + END_TEST; +} + +int UtcDaliTextControllerSetGetLineSpacingProperty(void) +{ + tet_infoline(" UtcDaliTextControllerSetGetLineSpacingProperty"); + ToolkitTestApplication application; + + const Size size( Dali::Stage::GetCurrent().GetSize() ); + + // single line text + const std::string textSingle("A Quick Brown Fox Jumps Over The Lazy Dog"); + + // multi-line text + const std::string textMulti("A Quick Brown\nFox Jumps Over\nThe Lazy Dog"); + + // Creates a text controller. + ControllerPtr controller = Controller::New(); + + ConfigureTextLabel(controller); + + // single line, line spacing = 0px + { + const float EXPECTED_SPACING = 0.0f; + const Vector2 EXPECTED_LAYOUT_SIZE( 326.0f, 19.0f); + const Vector3 EXPECTED_NATURAL_SIZE( 326.0f, 20.0f, 0.0f ); + + controller->SetText(textSingle); + controller->Relayout(size); + controller->SetMultiLineEnabled( false ); + + Vector3 naturalSize = controller->GetNaturalSize(); + Vector2 layoutSize = controller->GetTextModel()->GetLayoutSize(); + float lineSpacing0 = controller->GetDefaultLineSpacing(); + + DALI_TEST_EQUALS( EXPECTED_SPACING, lineSpacing0, TEST_LOCATION ); + DALI_TEST_EQUALS( EXPECTED_LAYOUT_SIZE, layoutSize, TEST_LOCATION ); + DALI_TEST_EQUALS( EXPECTED_NATURAL_SIZE, naturalSize, TEST_LOCATION ); + } + + // single line, line spacing = 20px + { + const float EXPECTED_SPACING = 20.0f; + const Vector2 EXPECTED_LAYOUT_SIZE( 326.0f, 19.0f ); + const Vector3 EXPECTED_NATURAL_SIZE( 326.0f, 40.0f, 0.0f ); + + controller->SetText(textSingle); + controller->Relayout(size); + controller->SetDefaultLineSpacing( 20 ); + controller->SetMultiLineEnabled( false ); + + Vector3 naturalSize = controller->GetNaturalSize(); + Vector2 layoutSize = controller->GetTextModel()->GetLayoutSize(); + float lineSpacing0 = controller->GetDefaultLineSpacing(); + + DALI_TEST_EQUALS( EXPECTED_SPACING, lineSpacing0, TEST_LOCATION ); + DALI_TEST_EQUALS( EXPECTED_LAYOUT_SIZE, layoutSize, TEST_LOCATION ); + DALI_TEST_EQUALS( EXPECTED_NATURAL_SIZE, naturalSize, TEST_LOCATION ); + } + + // multi-line, line spacing = 0px + { + const float EXPECTED_SPACING = 0.0f; + const Vector2 EXPECTED_LAYOUT_SIZE( 318.0f, 39.0f ); + const Vector3 EXPECTED_NATURAL_SIZE( 116.0f, 58.0f, 0.0f ); + + controller->SetText(textMulti); + controller->Relayout(size); + controller->SetMultiLineEnabled( true ); + controller->SetDefaultLineSpacing( 0 ); + + Vector3 naturalSize = controller->GetNaturalSize(); + Vector2 layoutSize = controller->GetTextModel()->GetLayoutSize(); + float lineSpacing0 = controller->GetDefaultLineSpacing(); + + DALI_TEST_EQUALS( EXPECTED_SPACING, lineSpacing0, TEST_LOCATION ); + DALI_TEST_EQUALS( EXPECTED_LAYOUT_SIZE, layoutSize, TEST_LOCATION ); + DALI_TEST_EQUALS( EXPECTED_NATURAL_SIZE, naturalSize, TEST_LOCATION ); + } + + // multi-line, line spacing = 20px + { + const float EXPECTED_SPACING = 20.0f; + const Vector2 EXPECTED_LAYOUT_SIZE( 115.0f, 57.0f ); + const Vector3 EXPECTED_NATURAL_SIZE( 116.0f, 118.0f, 0.0f ); + + controller->SetText(textMulti); + controller->Relayout(size); + controller->SetMultiLineEnabled( true ); + controller->SetDefaultLineSpacing( 20 ); + + Vector3 naturalSize = controller->GetNaturalSize(); + Vector2 layoutSize = controller->GetTextModel()->GetLayoutSize(); + float lineSpacing0 = controller->GetDefaultLineSpacing(); + + DALI_TEST_EQUALS( EXPECTED_SPACING, lineSpacing0, TEST_LOCATION ); + DALI_TEST_EQUALS( EXPECTED_LAYOUT_SIZE, layoutSize, TEST_LOCATION ); + DALI_TEST_EQUALS( EXPECTED_NATURAL_SIZE, naturalSize, TEST_LOCATION ); + } + + // multi-line, line spacing = 30px + { + const float EXPECTED_SPACING = 30.0f; + const Vector2 EXPECTED_LAYOUT_SIZE( 115.0f, 117.0f ); + const Vector3 EXPECTED_NATURAL_SIZE( 116.0f, 148.0f, 0.0f ); + + controller->SetText(textMulti); + controller->Relayout(size); + controller->SetMultiLineEnabled( true ); + controller->SetDefaultLineSpacing( 30 ); + + Vector3 naturalSize = controller->GetNaturalSize(); + Vector2 layoutSize = controller->GetTextModel()->GetLayoutSize(); + float lineSpacing0 = controller->GetDefaultLineSpacing(); + + DALI_TEST_EQUALS( EXPECTED_SPACING, lineSpacing0, TEST_LOCATION ); + DALI_TEST_EQUALS( EXPECTED_LAYOUT_SIZE, layoutSize, TEST_LOCATION ); + DALI_TEST_EQUALS( EXPECTED_NATURAL_SIZE, naturalSize, TEST_LOCATION ); + } + + + END_TEST; + +} + +int UtcDaliTextControllerCheckBufferIndices(void) +{ + tet_infoline(" UtcDaliTextControllerCheckBufferIndices"); + ToolkitTestApplication application; + + // Creates a text controller. + ControllerPtr controller = Controller::New(); + + ConfigureTextLabel(controller); + + // Set the text + const std::string text("A Quick Brown Fox Jumps Over The Lazy Dog"); + controller->SetText(text); + + // Get the implementation of the text controller + Controller::Impl& mImpl = Controller::Impl::GetImplementation( *controller.Get() ); + + // Tweak some parameters to make the indices to access the text buffer invalid + mImpl.mTextUpdateInfo.mNumberOfCharactersToAdd = mImpl.mModel->mLogicalModel->mText.Count() * 10u; + mImpl.mTextUpdateInfo.mNumberOfCharactersToRemove = 0u; + mImpl.mTextUpdateInfo.mPreviousNumberOfCharacters = 0u; + mImpl.mOperationsPending = Controller::ALL_OPERATIONS; + + // Perform a relayout + const Size size( Dali::Stage::GetCurrent().GetSize() ); + controller->Relayout(size); + + tet_result(TET_PASS); + + END_TEST; +}