2 * Copyright (c) 2014 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.
20 #include <dali/integration-api/events/key-event-integ.h>
21 #include <dali-toolkit-test-suite-utils.h>
22 #include <dali-toolkit/dali-toolkit.h>
23 #include <dali-toolkit/devel-api/styling/style-manager.h>
26 using namespace Toolkit;
28 void dali_textfield_startup(void)
30 test_return_value = TET_UNDEF;
33 void dali_textfield_cleanup(void)
35 test_return_value = TET_PASS;
41 const char* const PROPERTY_NAME_RENDERING_BACKEND = "rendering-backend";
42 const char* const PROPERTY_NAME_PLACEHOLDER_TEXT = "placeholder-text";
43 const char* const PROPERTY_NAME_TEXT = "text";
44 const char* const PROPERTY_NAME_FONT_FAMILY = "font-family";
45 const char* const PROPERTY_NAME_FONT_STYLE = "font-style";
46 const char* const PROPERTY_NAME_POINT_SIZE = "point-size";
47 const char* const PROPERTY_NAME_EXCEED_POLICY = "exceed-policy";
48 const char* const PROPERTY_NAME_PRIMARY_CURSOR_COLOR = "primary-cursor-color";
49 const char* const PROPERTY_NAME_SECONDARY_CURSOR_COLOR = "secondary-cursor-color";
50 const char* const PROPERTY_NAME_ENABLE_CURSOR_BLINK = "enable-cursor-blink";
51 const char* const PROPERTY_NAME_CURSOR_BLINK_INTERVAL = "cursor-blink-interval";
52 const char* const PROPERTY_NAME_CURSOR_BLINK_DURATION = "cursor-blink-duration";
53 const char* const PROPERTY_NAME_GRAB_HANDLE_IMAGE = "grab-handle-image";
54 const char* const PROPERTY_NAME_DECORATION_BOUNDING_BOX = "decoration-bounding-box";
55 const char* const PROPERTY_NAME_HORIZONTAL_ALIGNMENT = "horizontal-alignment";
56 const char* const PROPERTY_NAME_VERTICAL_ALIGNMENT = "vertical-alignment";
58 static bool gTextChangedCallBackCalled;
59 static bool gMaxCharactersCallBackCalled;
61 static void TestTextChangedCallback( TextField control )
63 tet_infoline(" TestTextChangedCallback");
65 gTextChangedCallBackCalled = true;
68 static void TestMaxLengthReachedCallback( TextField control )
70 tet_infoline(" TestMaxLengthReachedCallback");
72 gMaxCharactersCallBackCalled = true;
77 int UtcDaliToolkitTextFieldConstructorP(void)
79 ToolkitTestApplication application;
80 tet_infoline(" UtcDaliToolkitTextFieldConstructorP");
82 DALI_TEST_CHECK( !textField );
86 int UtcDaliToolkitTextFieldNewP(void)
88 ToolkitTestApplication application;
89 tet_infoline(" UtcDaliToolkitTextFieldNewP");
90 TextField textField = TextField::New();
91 DALI_TEST_CHECK( textField );
95 int UtcDaliToolkitTextFieldDownCastP(void)
97 ToolkitTestApplication application;
98 tet_infoline(" UtcDaliToolkitTextFieldDownCastP");
99 TextField textField1 = TextField::New();
100 BaseHandle object( textField1 );
102 TextField textField2 = TextField::DownCast( object );
103 DALI_TEST_CHECK( textField2 );
105 TextField textField3 = DownCast< TextField >( object );
106 DALI_TEST_CHECK( textField3 );
110 int UtcDaliToolkitTextFieldDownCastN(void)
112 ToolkitTestApplication application;
113 tet_infoline(" UtcDaliToolkitTextFieldDownCastN");
114 BaseHandle uninitializedObject;
115 TextField textField1 = TextField::DownCast( uninitializedObject );
116 DALI_TEST_CHECK( !textField1 );
118 TextField textField2 = DownCast< TextField >( uninitializedObject );
119 DALI_TEST_CHECK( !textField2 );
123 int UtcDaliToolkitTextFieldCopyConstructorP(void)
125 ToolkitTestApplication application;
126 tet_infoline(" UtcDaliToolkitTextFieldCopyConstructorP");
127 TextField textField = TextField::New();
128 textField.SetProperty( TextField::Property::TEXT, "Test" );
130 TextField copy( textField );
131 DALI_TEST_CHECK( copy );
132 DALI_TEST_CHECK( copy.GetProperty<std::string>( TextLabel::Property::TEXT ) == textField.GetProperty<std::string>( TextLabel::Property::TEXT ) );
136 int UtcDaliToolkitTextFieldAssignmentOperatorP(void)
138 ToolkitTestApplication application;
139 tet_infoline(" UtcDaliToolkitTextFieldAssignmentOperatorP");
140 TextField textField = TextField::New();
141 textField.SetProperty( TextField::Property::TEXT, "Test" );
143 TextField copy = textField;
144 DALI_TEST_CHECK( copy );
145 DALI_TEST_CHECK( copy.GetProperty<std::string>( TextField::Property::TEXT ) == textField.GetProperty<std::string>( TextField::Property::TEXT ) );
149 int UtcDaliTextFieldNewP(void)
151 ToolkitTestApplication application;
152 tet_infoline(" UtcDaliToolkitTextFieldNewP");
153 TextField textField = TextField::New();
154 DALI_TEST_CHECK( textField );
158 // Positive test case for a method
159 int UtcDaliTextFieldGetPropertyP(void)
161 ToolkitTestApplication application;
162 tet_infoline(" UtcDaliToolkitTextFieldGetPropertyP");
163 TextField field = TextField::New();
164 DALI_TEST_CHECK( field );
166 // Check Property Indices are correct
167 DALI_TEST_CHECK( field.GetPropertyIndex( PROPERTY_NAME_RENDERING_BACKEND ) == TextField::Property::RENDERING_BACKEND );
168 DALI_TEST_CHECK( field.GetPropertyIndex( PROPERTY_NAME_PLACEHOLDER_TEXT ) == TextField::Property::PLACEHOLDER_TEXT );
169 DALI_TEST_CHECK( field.GetPropertyIndex( PROPERTY_NAME_TEXT ) == TextField::Property::TEXT );
170 DALI_TEST_CHECK( field.GetPropertyIndex( PROPERTY_NAME_FONT_FAMILY ) == TextField::Property::FONT_FAMILY );
171 DALI_TEST_CHECK( field.GetPropertyIndex( PROPERTY_NAME_FONT_STYLE ) == TextField::Property::FONT_STYLE );
172 DALI_TEST_CHECK( field.GetPropertyIndex( PROPERTY_NAME_POINT_SIZE ) == TextField::Property::POINT_SIZE );
173 DALI_TEST_CHECK( field.GetPropertyIndex( PROPERTY_NAME_EXCEED_POLICY ) == TextField::Property::EXCEED_POLICY );
174 DALI_TEST_CHECK( field.GetPropertyIndex( PROPERTY_NAME_PRIMARY_CURSOR_COLOR ) == TextField::Property::PRIMARY_CURSOR_COLOR );
175 DALI_TEST_CHECK( field.GetPropertyIndex( PROPERTY_NAME_SECONDARY_CURSOR_COLOR ) == TextField::Property::SECONDARY_CURSOR_COLOR );
176 DALI_TEST_CHECK( field.GetPropertyIndex( PROPERTY_NAME_ENABLE_CURSOR_BLINK ) == TextField::Property::ENABLE_CURSOR_BLINK );
177 DALI_TEST_CHECK( field.GetPropertyIndex( PROPERTY_NAME_CURSOR_BLINK_INTERVAL ) == TextField::Property::CURSOR_BLINK_INTERVAL );
178 DALI_TEST_CHECK( field.GetPropertyIndex( PROPERTY_NAME_CURSOR_BLINK_DURATION ) == TextField::Property::CURSOR_BLINK_DURATION );
179 DALI_TEST_CHECK( field.GetPropertyIndex( PROPERTY_NAME_GRAB_HANDLE_IMAGE ) == TextField::Property::GRAB_HANDLE_IMAGE );
180 DALI_TEST_CHECK( field.GetPropertyIndex( PROPERTY_NAME_DECORATION_BOUNDING_BOX ) == TextField::Property::DECORATION_BOUNDING_BOX );
181 DALI_TEST_CHECK( field.GetPropertyIndex( PROPERTY_NAME_HORIZONTAL_ALIGNMENT ) == TextField::Property::HORIZONTAL_ALIGNMENT );
182 DALI_TEST_CHECK( field.GetPropertyIndex( PROPERTY_NAME_VERTICAL_ALIGNMENT ) == TextField::Property::VERTICAL_ALIGNMENT );
186 // Positive test case for a method
187 int UtcDaliTextFieldSetPropertyP(void)
189 ToolkitTestApplication application;
190 tet_infoline(" UtcDaliToolkitTextFieldSetPropertyP");
191 TextField field = TextField::New();
192 DALI_TEST_CHECK( field );
194 // Check exceed policy
195 field.SetProperty( TextField::Property::EXCEED_POLICY, TextField::EXCEED_POLICY_CLIP );
196 DALI_TEST_EQUALS( field.GetProperty<int>( TextField::Property::EXCEED_POLICY ), TextField::EXCEED_POLICY_CLIP, TEST_LOCATION );
198 // Check cursor properties
199 field.SetProperty( TextField::Property::ENABLE_CURSOR_BLINK, true );
200 DALI_TEST_EQUALS( field.GetProperty<bool>( TextField::Property::ENABLE_CURSOR_BLINK ), true, TEST_LOCATION );
201 field.SetProperty( TextField::Property::PRIMARY_CURSOR_COLOR, Color::RED );
202 DALI_TEST_EQUALS( field.GetProperty<Vector4>( TextField::Property::PRIMARY_CURSOR_COLOR ), Color::RED, TEST_LOCATION );
203 field.SetProperty( TextField::Property::SECONDARY_CURSOR_COLOR, Color::BLUE );
204 DALI_TEST_EQUALS( field.GetProperty<Vector4>( TextField::Property::SECONDARY_CURSOR_COLOR ), Color::BLUE, TEST_LOCATION );
205 field.SetProperty( TextField::Property::CURSOR_BLINK_DURATION, 10.0f );
206 DALI_TEST_EQUALS( field.GetProperty<float>( TextField::Property::CURSOR_BLINK_DURATION ), 10.0f, TEST_LOCATION );
209 field.SetProperty( TextField::Property::CURSOR_BLINK_INTERVAL, 1.0f );
210 DALI_TEST_EQUALS( field.GetProperty<float>( TextField::Property::CURSOR_BLINK_INTERVAL ), 1.0f, TEST_LOCATION );
212 // Decoration bounding box
213 field.SetProperty( TextField::Property::DECORATION_BOUNDING_BOX, Rect<int>( 0, 0, 1, 1 ) );
214 DALI_TEST_EQUALS( field.GetProperty<Rect <int > >( TextField::Property::DECORATION_BOUNDING_BOX ), Rect<int>( 0, 0, 1, 1 ), TEST_LOCATION );
216 // Check that the Alignment properties can be correctly set
217 field.SetProperty( TextField::Property::HORIZONTAL_ALIGNMENT, "BEGIN" );
218 DALI_TEST_EQUALS( field.GetProperty<std::string>( TextField::Property::HORIZONTAL_ALIGNMENT ), "BEGIN", TEST_LOCATION );
219 field.SetProperty( TextField::Property::VERTICAL_ALIGNMENT, "CENTER" );
220 DALI_TEST_EQUALS( field.GetProperty<std::string>( TextField::Property::VERTICAL_ALIGNMENT ), "CENTER", TEST_LOCATION );
223 field.SetProperty( TextField::Property::TEXT, "Setting Text" );
225 // Set placeholder text (currently not implemented)
226 field.SetProperty( TextField::Property::PLACEHOLDER_TEXT, "Setting Text" );
228 // Set Grab Handle image
229 field.SetProperty( TextField::Property::GRAB_HANDLE_IMAGE, "" );
231 // Check that the MAX_LENGTH property can be correctly set
232 const int maxNumberOfCharacters = 20;
233 field.SetProperty( TextField::Property::MAX_LENGTH, maxNumberOfCharacters );
234 DALI_TEST_EQUALS( field.GetProperty<int>( TextField::Property::MAX_LENGTH ), maxNumberOfCharacters, TEST_LOCATION );
239 // Positive Basic Text Renderer test
240 int utcDaliTextFieldBasicRenderP(void)
242 ToolkitTestApplication application;
243 tet_infoline("UtcDaliToolkitTextFieldBasicRenderP");
244 TextField field = TextField::New();
245 DALI_TEST_CHECK( field );
247 field.SetProperty( TextField::Property::HORIZONTAL_ALIGNMENT, "BEGIN" );
251 // Render some text with the basic backend
252 field.SetProperty( TextField::Property::RENDERING_BACKEND, Text::RENDERING_BASIC );
253 application.SendNotification();
254 application.Render();
258 tet_result(TET_FAIL);
263 // Positive Atlas Text Renderer test
264 int utcDaliTextFieldAtlasRenderP(void)
266 ToolkitTestApplication application;
267 tet_infoline(" UtcDaliToolkitTextFieldAtlasRenderP");
268 StyleManager styleManager = StyleManager::Get();
269 styleManager.RequestDefaultTheme();
270 TextField field = TextField::New();
271 DALI_TEST_CHECK( field );
273 field.SetProperty( TextField::Property::HORIZONTAL_ALIGNMENT, "CENTER" );
276 // Render some text with the shared atlas backend
277 field.SetProperty( TextField::Property::RENDERING_BACKEND, Text::RENDERING_SHARED_ATLAS );
278 application.SendNotification();
279 application.Render();
283 tet_result(TET_FAIL);
288 // Positive test for the text-changed signal.
289 int utcDaliTextFieldTextChangedP(void)
291 ToolkitTestApplication application;
292 tet_infoline(" utcDaliTextFieldTextChangedP");
293 TextField field = TextField::New();
294 DALI_TEST_CHECK( field );
296 Stage::GetCurrent().Add(field);
298 field.TextChangedSignal().Connect(&TestTextChangedCallback);
300 gTextChangedCallBackCalled = false;
301 field.SetProperty( TextField::Property::TEXT, "ABC" );
302 DALI_TEST_CHECK( gTextChangedCallBackCalled );
304 application.SendNotification();
306 field.SetKeyInputFocus();
308 Dali::Integration::KeyEvent keyevent;
309 keyevent.keyName = "D";
310 keyevent.keyString = "D";
311 keyevent.keyCode = 0;
312 keyevent.keyModifier = 0;
314 keyevent.state = Integration::KeyEvent::Down;
316 gTextChangedCallBackCalled = false;
317 application.ProcessEvent( keyevent );
318 DALI_TEST_CHECK( gTextChangedCallBackCalled );
323 // Negative test for the text-changed signal.
324 int utcDaliTextFieldTextChangedN(void)
326 ToolkitTestApplication application;
327 tet_infoline(" utcDaliTextFieldTextChangedN");
328 TextField field = TextField::New();
329 DALI_TEST_CHECK( field );
331 Stage::GetCurrent().Add(field);
333 field.TextChangedSignal().Connect(&TestTextChangedCallback);
335 gTextChangedCallBackCalled = false;
336 field.SetProperty( TextField::Property::PLACEHOLDER_TEXT, "ABC" ); // Setting placeholder, not TEXT
337 DALI_TEST_CHECK( ! gTextChangedCallBackCalled );
342 // Positive test for Max Characters reached signal.
343 int utcDaliTextFieldMaxCharactersReachedP(void)
345 ToolkitTestApplication application;
346 tet_infoline(" utcDaliTextFieldMaxCharactersReachedP");
347 TextField field = TextField::New();
348 DALI_TEST_CHECK( field );
350 Stage::GetCurrent().Add(field);
352 const int maxNumberOfCharacters = 1;
353 field.SetProperty( TextField::Property::MAX_LENGTH, maxNumberOfCharacters );
355 field.SetKeyInputFocus();
357 gMaxCharactersCallBackCalled = false;
358 field.MaxLengthReachedSignal().Connect(&TestMaxLengthReachedCallback);
360 Dali::Integration::KeyEvent keyevent;
361 keyevent.keyName = "a";
362 keyevent.keyString = "a";
363 keyevent.keyCode = 0;
364 keyevent.keyModifier = 0;
366 keyevent.state = Integration::KeyEvent::Down;
368 application.ProcessEvent( keyevent );
370 application.ProcessEvent( keyevent );
372 DALI_TEST_CHECK( gMaxCharactersCallBackCalled );
377 // Negative test for Max Characters reached signal.
378 int utcDaliTextFieldMaxCharactersReachedN(void)
380 ToolkitTestApplication application;
381 tet_infoline(" utcDaliTextFieldMaxCharactersReachedN");
382 TextField field = TextField::New();
383 DALI_TEST_CHECK( field );
385 Stage::GetCurrent().Add(field);
387 const int maxNumberOfCharacters = 3;
388 field.SetProperty( TextField::Property::MAX_LENGTH, maxNumberOfCharacters );
390 field.SetKeyInputFocus();
392 gMaxCharactersCallBackCalled = false;
393 field.MaxLengthReachedSignal().Connect(&TestMaxLengthReachedCallback);
395 Dali::Integration::KeyEvent keyevent;
396 keyevent.keyName = "a";
397 keyevent.keyString = "a";
398 keyevent.keyCode = 0;
399 keyevent.keyModifier = 0;
401 keyevent.state = Integration::KeyEvent::Down;
403 application.ProcessEvent( keyevent );
404 application.ProcessEvent( keyevent );
406 DALI_TEST_CHECK( !gMaxCharactersCallBackCalled );