/*
- * Copyright (c) 2014 Samsung Electronics Co., Ltd.
+ * Copyright (c) 2020 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.
*
*/
-#include <iostream>
-
-#include <stdlib.h>
-#include <dali/public-api/dali-core.h>
#include <dali-test-suite-utils.h>
+#include <dali/public-api/dali-core.h>
+#include <stdlib.h>
+
+#include <iostream>
using namespace Dali;
test_return_value = TET_PASS;
}
-
// Positive test case for a method
int UtcDaliRectCons01(void)
{
Rect<float> rect(10.0f, 20.0f, 400.0f, 200.0f);
- Rect<float> r2 = rect;
+ Rect<float> r2(rect);
DALI_TEST_EQUALS(r2.x, 10.0f, 0.001, TEST_LOCATION);
DALI_TEST_EQUALS(r2.y, 20.0f, 0.001, TEST_LOCATION);
{
TestApplication application;
+ Vector4 vec4(10.0f, 20.0f, 400.0f, 200.0f);
+
+ Rect<float> rect(vec4);
+
+ DALI_TEST_EQUALS(rect.x, 10.0f, 0.001, TEST_LOCATION);
+ DALI_TEST_EQUALS(rect.y, 20.0f, 0.001, TEST_LOCATION);
+ DALI_TEST_EQUALS(rect.width, 400.0f, 0.001, TEST_LOCATION);
+ DALI_TEST_EQUALS(rect.height, 200.0f, 0.001, TEST_LOCATION);
+ END_TEST;
+}
+
+int UtcDaliRectMoveConstructor(void)
+{
+ TestApplication application;
+
Rect<float> rect(10.0f, 20.0f, 400.0f, 200.0f);
- Rect<float> r2(rect);
+ Rect<float> r2 = std::move(rect);
+
+ DALI_TEST_EQUALS(r2.x, 10.0f, 0.001, TEST_LOCATION);
+ DALI_TEST_EQUALS(r2.y, 20.0f, 0.001, TEST_LOCATION);
+ DALI_TEST_EQUALS(r2.width, 400.0f, 0.001, TEST_LOCATION);
+ DALI_TEST_EQUALS(r2.height, 200.0f, 0.001, TEST_LOCATION);
+ END_TEST;
+}
+
+int UtcDaliRectMoveAssignmentOperator(void)
+{
+ TestApplication application;
+
+ Rect<float> rect(10.0f, 20.0f, 400.0f, 200.0f);
+
+ Rect<float> r2;
+ r2 = std::move(rect);
+
+ DALI_TEST_EQUALS(r2.x, 10.0f, 0.001, TEST_LOCATION);
+ DALI_TEST_EQUALS(r2.y, 20.0f, 0.001, TEST_LOCATION);
+ DALI_TEST_EQUALS(r2.width, 400.0f, 0.001, TEST_LOCATION);
+ DALI_TEST_EQUALS(r2.height, 200.0f, 0.001, TEST_LOCATION);
+ END_TEST;
+}
+
+int UtcDaliRectAssignmentOperatorRect(void)
+{
+ TestApplication application;
+
+ Rect<float> rect(10.0f, 20.0f, 400.0f, 200.0f);
+
+ Rect<float> r2;
+ r2 = rect;
DALI_TEST_EQUALS(r2.x, 10.0f, 0.001, TEST_LOCATION);
DALI_TEST_EQUALS(r2.y, 20.0f, 0.001, TEST_LOCATION);
END_TEST;
}
+int UtcDaliRectAssignmentOperatorVector4(void)
+{
+ TestApplication application;
+
+ Vector4 vec4(10.0f, 20.0f, 400.0f, 200.0f);
+
+ Rect<float> rect;
+ rect = vec4;
+
+ DALI_TEST_EQUALS(rect.x, 10.0f, 0.001, TEST_LOCATION);
+ DALI_TEST_EQUALS(rect.y, 20.0f, 0.001, TEST_LOCATION);
+ DALI_TEST_EQUALS(rect.width, 400.0f, 0.001, TEST_LOCATION);
+ DALI_TEST_EQUALS(rect.height, 200.0f, 0.001, TEST_LOCATION);
+ END_TEST;
+}
+
int UtcDaliRectSet(void)
{
TestApplication application;
{
TestApplication application;
- Rect<int> ri;
- Rect<float> rf(10.0f, 20.0f, 400.0f, 200.0f);
- Rect<float> rf2;
- Rect<float> rf3(10.0f, 20.0f, 0.0f, 200.0f);
- Rect<float> rf4(10.0f, 20.0f, 400.0f, 0.0f);
- Rect<double> rd(10.0, 20.0, 0.0, 200.0);
+ Rect<int> ri;
+ Rect<float> rf(10.0f, 20.0f, 400.0f, 200.0f);
+ Rect<float> rf2;
+ Rect<float> rf3(10.0f, 20.0f, 0.0f, 200.0f);
+ Rect<float> rf4(10.0f, 20.0f, 400.0f, 0.0f);
+ Rect<double> rd(10.0, 20.0, 0.0, 200.0);
Rect<unsigned int> ru(0u, 0u, 4u, 0u);
DALI_TEST_CHECK(!rf.IsEmpty());
END_TEST;
}
-
int UtcDaliRectArea(void)
{
TestApplication application;
END_TEST;
}
-
int UtcDaliRectIntersects(void)
{
TestApplication application;
- Rect<float> rf1( 10.0f, 20.0f, 200.0f, 200.0f);
- Rect<float> rf2( 10.0f, 120.0f, 200.0f, 200.0f);
- Rect<float> rf3( 10.0f, -80.0f, 200.0f, 200.0f);
- Rect<float> rf4(110.0f, 20.0f, 200.0f, 200.0f);
- Rect<float> rf5(-90.0f, 20.0f, 200.0f, 200.0f);
+ Rect<float> rf1(10.0f, 20.0f, 200.0f, 200.0f);
+ Rect<float> rf2(10.0f, 120.0f, 200.0f, 200.0f);
+ Rect<float> rf3(10.0f, -80.0f, 200.0f, 200.0f);
+ Rect<float> rf4(110.0f, 20.0f, 200.0f, 200.0f);
+ Rect<float> rf5(-90.0f, 20.0f, 200.0f, 200.0f);
Rect<float> rf6(1000.0f, 1200.0f, 10.0f, 10.0f);
DALI_TEST_CHECK(rf1.Intersects(rf2));
END_TEST;
}
-
-
int UtcDaliRectContains(void)
{
TestApplication application;
- Rect<float> rf1( 10.0f, 20.0f, 200.0f, 200.0f);
+ Rect<float> rf1(10.0f, 20.0f, 200.0f, 200.0f);
- Rect<float> rf2( 10.0f, 120.0f, 200.0f, 200.0f);
- Rect<float> rf3( 10.0f, -80.0f, 200.0f, 200.0f);
- Rect<float> rf4(110.0f, 20.0f, 200.0f, 200.0f);
- Rect<float> rf5(-90.0f, 20.0f, 200.0f, 200.0f);
+ Rect<float> rf2(10.0f, 120.0f, 200.0f, 200.0f);
+ Rect<float> rf3(10.0f, -80.0f, 200.0f, 200.0f);
+ Rect<float> rf4(110.0f, 20.0f, 200.0f, 200.0f);
+ Rect<float> rf5(-90.0f, 20.0f, 200.0f, 200.0f);
Rect<float> rf6(1000.0f, 1200.0f, 10.0f, 10.0f);
- Rect<float> rf7( 50.0f, 70.0f, 50.0f, 50.0f);
+ Rect<float> rf7(50.0f, 70.0f, 50.0f, 50.0f);
- Rect<float> rf8( 10.0f, 20.0f, 100.0f, 100.0f);
- Rect<float> rf9( 110.0f, 20.0f, 100.0f, 100.0f);
- Rect<float> rf10( 110.0f, 120.0f, 100.0f, 100.0f);
- Rect<float> rf11( 10.0f, 120.0f, 100.0f, 100.0f);
+ Rect<float> rf8(10.0f, 20.0f, 100.0f, 100.0f);
+ Rect<float> rf9(110.0f, 20.0f, 100.0f, 100.0f);
+ Rect<float> rf10(110.0f, 120.0f, 100.0f, 100.0f);
+ Rect<float> rf11(10.0f, 120.0f, 100.0f, 100.0f);
DALI_TEST_CHECK(rf1.Contains(rf1));
DALI_TEST_CHECK(!rf1.Contains(rf2));
END_TEST;
}
-
int UtcDaliRectOperatorNotEquals(void)
{
TestApplication application;
- Rect<float> rf1( 10.0f, 20.0f, 200.0f, 200.0f);
- Rect<float> rf2( 10.0f, 120.0f, 200.0f, 200.0f);
- Rect<float> rf3( 10.0f, -80.0f, 200.0f, 200.0f);
- Rect<float> rf4(110.0f, 20.0f, 200.0f, 200.0f);
- Rect<float> rf5(-90.0f, 20.0f, 200.0f, 200.0f);
+ Rect<float> rf1(10.0f, 20.0f, 200.0f, 200.0f);
+ Rect<float> rf2(10.0f, 120.0f, 200.0f, 200.0f);
+ Rect<float> rf3(10.0f, -80.0f, 200.0f, 200.0f);
+ Rect<float> rf4(110.0f, 20.0f, 200.0f, 200.0f);
+ Rect<float> rf5(-90.0f, 20.0f, 200.0f, 200.0f);
Rect<float> rf6(1000.0f, 1200.0f, 10.0f, 10.0f);
- Rect<float> rf7( 50.0f, 70.0f, 50.0f, 50.0f);
- Rect<float> rf8( 10.0f, 20.0f, 100.0f, 100.0f);
- Rect<float> rf9( 110.0f, 20.0f, 100.0f, 100.0f);
- Rect<float> rf10( 110.0f, 120.0f, 100.0f, 100.0f);
- Rect<float> rf11( 10.0f, 120.0f, 100.0f, 100.0f);
+ Rect<float> rf7(50.0f, 70.0f, 50.0f, 50.0f);
+ Rect<float> rf8(10.0f, 20.0f, 100.0f, 100.0f);
+ Rect<float> rf9(110.0f, 20.0f, 100.0f, 100.0f);
+ Rect<float> rf10(110.0f, 120.0f, 100.0f, 100.0f);
+ Rect<float> rf11(10.0f, 120.0f, 100.0f, 100.0f);
DALI_TEST_CHECK(rf1 != rf2);
DALI_TEST_CHECK(rf1 != rf3);
END_TEST;
}
-
int UtcDaliRectOperatorEquals(void)
{
TestApplication application;
- Rect<float> rf1( 10.0f, 20.0f, 200.0f, 200.0f);
- Rect<float> rf1p( 10.0f, 20.0f, 200.0f, 200.0f);
+ Rect<float> rf1(10.0f, 20.0f, 200.0f, 200.0f);
+ Rect<float> rf1p(10.0f, 20.0f, 200.0f, 200.0f);
- Rect<float> rf2(110.0f, 20.0f, 200.0f, 200.0f);
- Rect<float> rf3( 10.0f, 120.0f, 200.0f, 200.0f);
- Rect<float> rf4( 10.0f, 20.0f, 300.0f, 200.0f);
- Rect<float> rf5( 10.0f, 20.0f, 200.0f, 500.0f);
+ Rect<float> rf2(110.0f, 20.0f, 200.0f, 200.0f);
+ Rect<float> rf3(10.0f, 120.0f, 200.0f, 200.0f);
+ Rect<float> rf4(10.0f, 20.0f, 300.0f, 200.0f);
+ Rect<float> rf5(10.0f, 20.0f, 200.0f, 500.0f);
- Rect<float> rf6( 0.0f, 0.0f, 9.0f, 10.0f);
+ Rect<float> rf6(0.0f, 0.0f, 9.0f, 10.0f);
DALI_TEST_CHECK(rf1 == rf1p);
DALI_TEST_CHECK(rf1 == rf1);
DALI_TEST_CHECK(!(rf1 == rf5));
DALI_TEST_CHECK(!(rf1 == rf6));
-
// integers
- Rect<int> ri1( 10, 20, 200, 200 );
- Rect<int> ri1p( 10, 20, 200, 200 );
+ Rect<int> ri1(10, 20, 200, 200);
+ Rect<int> ri1p(10, 20, 200, 200);
DALI_TEST_CHECK(ri1 == ri1p);
END_TEST;
}
+
+int UtcDaliRectOStreamOperatorP(void)
+{
+ TestApplication application;
+ std::ostringstream oss;
+
+ Rect<int> rect(1, 2, 10, 10);
+
+ oss << rect;
+
+ std::string expectedOutput = "[1, 2, 10, 10]";
+
+ DALI_TEST_EQUALS(oss.str(), expectedOutput, TEST_LOCATION);
+ END_TEST;
+}