Commit d4ac0550 authored by Kenton Varda's avatar Kenton Varda

Fixes #59 -- Apparently hadExplicitDefault was never implemented.

parent de95af09
...@@ -1203,6 +1203,7 @@ private: ...@@ -1203,6 +1203,7 @@ private:
if (member.hasDefaultValue) { if (member.hasDefaultValue) {
translator.compileBootstrapValue(member.fieldDefaultValue, translator.compileBootstrapValue(member.fieldDefaultValue,
typeBuilder, slot.initDefaultValue()); typeBuilder, slot.initDefaultValue());
slot.setHadExplicitDefault(true);
} else { } else {
translator.compileDefaultDefaultValue(typeBuilder, slot.initDefaultValue()); translator.compileDefaultDefaultValue(typeBuilder, slot.initDefaultValue());
} }
......
...@@ -52,6 +52,12 @@ TEST(Schema, Structs) { ...@@ -52,6 +52,12 @@ TEST(Schema, Structs) {
StructSchema::Field lookup = schema.getFieldByName("voidField"); StructSchema::Field lookup = schema.getFieldByName("voidField");
EXPECT_TRUE(lookup == field); EXPECT_TRUE(lookup == field);
EXPECT_TRUE(lookup != schema.getFields()[1]); EXPECT_TRUE(lookup != schema.getFields()[1]);
EXPECT_FALSE(lookup.getProto().getSlot().getHadExplicitDefault());
EXPECT_FALSE(schema.getFieldByName("int32Field").getProto().getSlot().getHadExplicitDefault());
EXPECT_TRUE(Schema::from<TestDefaults>().getFieldByName("int32Field")
.getProto().getSlot().getHadExplicitDefault());
EXPECT_TRUE(schema.findFieldByName("noSuchField") == nullptr); EXPECT_TRUE(schema.findFieldByName("noSuchField") == nullptr);
...@@ -262,6 +268,47 @@ TEST(Schema, NullSchemas) { ...@@ -262,6 +268,47 @@ TEST(Schema, NullSchemas) {
EXPECT_EQ(InterfaceSchema().getProto().getId(), typeId<Capability>()); EXPECT_EQ(InterfaceSchema().getProto().getId(), typeId<Capability>());
} }
TEST(Schema, Interfaces) {
InterfaceSchema schema = Schema::from<test::TestMoreStuff>();
EXPECT_EQ(typeId<test::TestMoreStuff>(), schema.getProto().getId());
EXPECT_TRUE(schema.getDependency(typeId<test::TestCallOrder>()) ==
Schema::from<test::TestCallOrder>());
EXPECT_TRUE(schema.getDependency(typeId<test::TestCallOrder>()) != schema);
EXPECT_ANY_THROW(schema.getDependency(typeId<TestDefaults>()));
EXPECT_TRUE(schema.asInterface() == schema);
EXPECT_NONFATAL_FAILURE(schema.asStruct());
EXPECT_NONFATAL_FAILURE(schema.asEnum());
ASSERT_EQ(schema.getMethods().size(), schema.getProto().getInterface().getMethods().size());
InterfaceSchema::Method method = schema.getMethods()[0];
EXPECT_EQ("callFoo", method.getProto().getName());
EXPECT_TRUE(method.getContainingInterface() == schema);
InterfaceSchema::Method lookup = schema.getMethodByName("callFoo");
EXPECT_TRUE(lookup == method);
EXPECT_TRUE(lookup != schema.getMethods()[1]);
EXPECT_TRUE(Schema::from<TestDefaults>().getFieldByName("int32Field")
.getProto().getSlot().getHadExplicitDefault());
EXPECT_TRUE(schema.findMethodByName("noSuchMethod") == nullptr);
EXPECT_TRUE(schema.findMethodByName("callFooWhenResolved") != nullptr);
EXPECT_TRUE(schema.findMethodByName("neverReturn") != nullptr);
EXPECT_TRUE(schema.findMethodByName("hold") != nullptr);
EXPECT_TRUE(schema.findMethodByName("callHeld") != nullptr);
EXPECT_TRUE(schema.findMethodByName("getHeld") != nullptr);
auto params = schema.getDependency(schema.getMethodByName("methodWithDefaults")
.getProto().getParamStructType()).asStruct();
EXPECT_FALSE(params.getFieldByName("a").getProto().getSlot().getHadExplicitDefault());
EXPECT_TRUE(params.getFieldByName("b").getProto().getSlot().getHadExplicitDefault());
EXPECT_TRUE(params.getFieldByName("c").getProto().getSlot().getHadExplicitDefault());
}
} // namespace } // namespace
} // namespace _ (private) } // namespace _ (private)
} // namespace capnp } // namespace capnp
...@@ -657,6 +657,8 @@ interface TestMoreStuff extends(TestCallOrder) { ...@@ -657,6 +657,8 @@ interface TestMoreStuff extends(TestCallOrder) {
expectCancel @7 (cap :TestInterface) -> (); expectCancel @7 (cap :TestInterface) -> ();
# evalLater()-loops forever, holding `cap`. Must be canceled. # evalLater()-loops forever, holding `cap`. Must be canceled.
methodWithDefaults @8 (a :Text, b :UInt32 = 123, c :Text = "foo") -> (d :Text, e :Text = "bar");
} }
struct TestSturdyRefHostId { struct TestSturdyRefHostId {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment