Index: mojo/public/cpp/bindings/tests/type_conversion_unittest.cc |
diff --git a/mojo/public/cpp/bindings/tests/type_conversion_unittest.cc b/mojo/public/cpp/bindings/tests/type_conversion_unittest.cc |
index bcf9e44624559b55902996edf271efcafc43d43d..ed652a1aaf579b840504b5b1f5325f2114f9d195 100644 |
--- a/mojo/public/cpp/bindings/tests/type_conversion_unittest.cc |
+++ b/mojo/public/cpp/bindings/tests/type_conversion_unittest.cc |
@@ -2,7 +2,6 @@ |
// Use of this source code is governed by a BSD-style license that can be |
// found in the LICENSE file. |
-#include "mojo/public/cpp/bindings/allocation_scope.h" |
#include "mojo/public/cpp/environment/environment.h" |
#include "mojo/public/interfaces/bindings/tests/test_structs.mojom.h" |
#include "testing/gtest/include/gtest/gtest.h" |
@@ -22,16 +21,16 @@ struct RedmondNamedRegion { |
std::vector<RedmondRect> rects; |
}; |
-bool AreEqualRectArrays(const Array<test_structs::Rect>& rects1, |
- const Array<test_structs::Rect>& rects2) { |
+bool AreEqualRectArrays(const Array<test::RectPtr>& rects1, |
+ const Array<test::RectPtr>& rects2) { |
if (rects1.size() != rects2.size()) |
return false; |
for (size_t i = 0; i < rects1.size(); ++i) { |
- if (rects1[i].x() != rects2[i].x() || |
- rects1[i].y() != rects2[i].y() || |
- rects1[i].width() != rects2[i].width() || |
- rects1[i].height() != rects2[i].height()) { |
+ if (rects1[i]->x != rects2[i]->x || |
+ rects1[i]->y != rects2[i]->y || |
+ rects1[i]->width != rects2[i]->width || |
+ rects1[i]->height != rects2[i]->height) { |
return false; |
} |
} |
@@ -42,59 +41,47 @@ bool AreEqualRectArrays(const Array<test_structs::Rect>& rects1, |
} // namespace |
template <> |
-class TypeConverter<test_structs::Rect, RedmondRect> { |
+class TypeConverter<test::RectPtr, RedmondRect> { |
public: |
- static test_structs::Rect ConvertFrom(const RedmondRect& input, Buffer* buf) { |
- test_structs::Rect::Builder rect(buf); |
- rect.set_x(input.left); |
- rect.set_y(input.top); |
- rect.set_width(input.right - input.left); |
- rect.set_height(input.bottom - input.top); |
- return rect.Finish(); |
+ static test::RectPtr ConvertFrom(const RedmondRect& input) { |
+ test::RectPtr rect(test::Rect::New()); |
+ rect->x = input.left; |
+ rect->y = input.top; |
+ rect->width = input.right - input.left; |
+ rect->height = input.bottom - input.top; |
+ return rect.Pass(); |
} |
- static RedmondRect ConvertTo(const test_structs::Rect& input) { |
+ static RedmondRect ConvertTo(const test::RectPtr& input) { |
RedmondRect rect; |
- rect.left = input.x(); |
- rect.top = input.y(); |
- rect.right = input.x() + input.width(); |
- rect.bottom = input.y() + input.height(); |
+ rect.left = input->x; |
+ rect.top = input->y; |
+ rect.right = input->x + input->width; |
+ rect.bottom = input->y + input->height; |
return rect; |
} |
- |
- MOJO_ALLOW_IMPLICIT_TYPE_CONVERSION(); |
}; |
template <> |
-class TypeConverter<test_structs::NamedRegion, RedmondNamedRegion> { |
+class TypeConverter<test::NamedRegionPtr, RedmondNamedRegion> { |
public: |
- static test_structs::NamedRegion ConvertFrom(const RedmondNamedRegion& input, |
- Buffer* buf) { |
- test_structs::NamedRegion::Builder region(buf); |
- region.set_name(String(input.name, buf)); |
- region.set_rects(mojo::Array<test_structs::Rect>(input.rects, buf)); |
- return region.Finish(); |
+ static test::NamedRegionPtr ConvertFrom(const RedmondNamedRegion& input) { |
+ test::NamedRegionPtr region(test::NamedRegion::New()); |
+ region->name = input.name; |
+ region->rects = Array<test::RectPtr>::From(input.rects); |
+ return region.Pass(); |
} |
- static RedmondNamedRegion ConvertTo(const test_structs::NamedRegion& input) { |
+ static RedmondNamedRegion ConvertTo(const test::NamedRegionPtr& input) { |
RedmondNamedRegion region; |
- region.name = input.name().To<std::string>(); |
- region.rects = input.rects().To<std::vector<RedmondRect> >(); |
+ region.name = input->name; |
+ region.rects = input->rects.To<std::vector<RedmondRect> >(); |
return region; |
} |
- |
- MOJO_ALLOW_IMPLICIT_TYPE_CONVERSION(); |
}; |
namespace test { |
namespace { |
-class TypeConversionTest : public testing::Test { |
- private: |
- Environment env_; |
-}; |
- |
-TEST_F(TypeConversionTest, String) { |
- AllocationScope scope; |
- |
+TEST(TypeConversionTest, String) { |
const char kText[6] = "hello"; |
String a = std::string(kText); |
@@ -106,18 +93,17 @@ TEST_F(TypeConversionTest, String) { |
EXPECT_EQ(std::string(kText), c.To<std::string>()); |
} |
-TEST_F(TypeConversionTest, String_Null) { |
+TEST(TypeConversionTest, String_Null) { |
String a; |
EXPECT_TRUE(a.is_null()); |
EXPECT_EQ(std::string(), a.To<std::string>()); |
- String b(static_cast<const char*>(NULL)); |
+ String b = String::From(static_cast<const char*>(NULL)); |
EXPECT_TRUE(b.is_null()); |
} |
-TEST_F(TypeConversionTest, String_Empty) { |
- AllocationScope scope; |
- String a = String::Builder(0).Finish(); |
+TEST(TypeConversionTest, String_Empty) { |
+ String a = ""; |
EXPECT_EQ(std::string(), a.To<std::string>()); |
String b = std::string(); |
@@ -125,19 +111,7 @@ TEST_F(TypeConversionTest, String_Empty) { |
EXPECT_EQ(std::string(), b.To<std::string>()); |
} |
-TEST_F(TypeConversionTest, String_ShallowCopy) { |
- AllocationScope scope; |
- |
- String a("hello"); |
- String b(a); |
- |
- EXPECT_EQ(&a[0], &b[0]); |
- EXPECT_EQ(a.To<std::string>(), b.To<std::string>()); |
-} |
- |
-TEST_F(TypeConversionTest, StringWithEmbeddedNull) { |
- AllocationScope scope; |
- |
+TEST(TypeConversionTest, StringWithEmbeddedNull) { |
const std::string kText("hel\0lo", 6); |
String a(kText); |
@@ -148,15 +122,12 @@ TEST_F(TypeConversionTest, StringWithEmbeddedNull) { |
EXPECT_EQ(std::string("hel"), b.To<std::string>()); |
} |
-TEST_F(TypeConversionTest, CustomTypeConverter) { |
- AllocationScope scope; |
- |
- test_structs::Rect::Builder rect_builder; |
- rect_builder.set_x(10); |
- rect_builder.set_y(20); |
- rect_builder.set_width(50); |
- rect_builder.set_height(45); |
- test_structs::Rect rect = rect_builder.Finish(); |
+TEST(TypeConversionTest, CustomTypeConverter) { |
+ RectPtr rect(Rect::New()); |
+ rect->x = 10; |
+ rect->y = 20; |
+ rect->width = 50; |
+ rect->height = 45; |
RedmondRect rr = rect.To<RedmondRect>(); |
EXPECT_EQ(10, rr.left); |
@@ -164,15 +135,15 @@ TEST_F(TypeConversionTest, CustomTypeConverter) { |
EXPECT_EQ(60, rr.right); |
EXPECT_EQ(65, rr.bottom); |
- test_structs::Rect rect2(rr); |
- EXPECT_EQ(rect.x(), rect2.x()); |
- EXPECT_EQ(rect.y(), rect2.y()); |
- EXPECT_EQ(rect.width(), rect2.width()); |
- EXPECT_EQ(rect.height(), rect2.height()); |
+ RectPtr rect2(Rect::From(rr)); |
+ EXPECT_EQ(rect->x, rect2->x); |
+ EXPECT_EQ(rect->y, rect2->y); |
+ EXPECT_EQ(rect->width, rect2->width); |
+ EXPECT_EQ(rect->height, rect2->height); |
} |
-TEST_F(TypeConversionTest, CustomTypeConverter_Array_Null) { |
- Array<test_structs::Rect> rects; |
+TEST(TypeConversionTest, CustomTypeConverter_Array_Null) { |
+ Array<RectPtr> rects; |
std::vector<RedmondRect> redmond_rects = |
rects.To<std::vector<RedmondRect> >(); |
@@ -180,42 +151,25 @@ TEST_F(TypeConversionTest, CustomTypeConverter_Array_Null) { |
EXPECT_TRUE(redmond_rects.empty()); |
} |
-TEST_F(TypeConversionTest, CustomTypeConverter_Array) { |
- AllocationScope scope; |
- |
+TEST(TypeConversionTest, CustomTypeConverter_Array) { |
const RedmondRect kBase = { 10, 20, 30, 40 }; |
- Array<test_structs::Rect>::Builder rects_builder(10); |
- for (size_t i = 0; i < rects_builder.size(); ++i) { |
+ Array<RectPtr> rects(10); |
+ for (size_t i = 0; i < rects.size(); ++i) { |
RedmondRect rr = kBase; |
rr.left += static_cast<int32_t>(i); |
rr.top += static_cast<int32_t>(i); |
- rects_builder[i] = test_structs::Rect(rr); |
+ rects[i] = Rect::From(rr); |
} |
- Array<test_structs::Rect> rects = rects_builder.Finish(); |
std::vector<RedmondRect> redmond_rects = |
rects.To<std::vector<RedmondRect> >(); |
- // Note: assignment broken in two lines tests default constructor with |
- // assignment operator. We will also test conversion constructor. |
- Array<test_structs::Rect> rects2; |
- rects2 = redmond_rects; |
+ Array<RectPtr> rects2 = Array<RectPtr>::From(redmond_rects); |
EXPECT_TRUE(AreEqualRectArrays(rects, rects2)); |
- |
- // Test conversion constructor. |
- Array<test_structs::Rect> rects3(redmond_rects); |
- EXPECT_TRUE(AreEqualRectArrays(rects, rects3)); |
- |
- // Test explicit conversion using From(). |
- Array<test_structs::Rect> rects4 |
- = Array<test_structs::Rect>::From(redmond_rects); |
- EXPECT_TRUE(AreEqualRectArrays(rects, rects4)); |
} |
-TEST_F(TypeConversionTest, CustomTypeConverter_Nested) { |
- AllocationScope scope; |
- |
+TEST(TypeConversionTest, CustomTypeConverter_Nested) { |
RedmondNamedRegion redmond_region; |
redmond_region.name = "foopy"; |
@@ -230,7 +184,7 @@ TEST_F(TypeConversionTest, CustomTypeConverter_Nested) { |
// Round-trip through generated struct and TypeConverter. |
- test_structs::NamedRegion copy = redmond_region; |
+ NamedRegionPtr copy = NamedRegion::From(redmond_region); |
RedmondNamedRegion redmond_region2 = copy.To<RedmondNamedRegion>(); |
EXPECT_EQ(redmond_region.name, redmond_region2.name); |