# HG changeset patch # User Jacob Carlborg # Date 1312732430 -7200 # Node ID 8b940942374027a2eeec4161c3d89290d02035a6 # Parent b538d02578cb8251cac7feb62663cc80a88d1fbb Added unit tests for (de)serializing events. diff -r b538d02578cb -r 8b9409423740 .hgignore --- a/.hgignore Sat Aug 06 13:38:26 2011 +0200 +++ b/.hgignore Sun Aug 07 17:53:50 2011 +0200 @@ -17,4 +17,5 @@ kandil lib import -unittest \ No newline at end of file +unittest +*.exe \ No newline at end of file diff -r b538d02578cb -r 8b9409423740 orange/serialization/Events.d --- a/orange/serialization/Events.d Sat Aug 06 13:38:26 2011 +0200 +++ b/orange/serialization/Events.d Sun Aug 07 17:53:50 2011 +0200 @@ -41,7 +41,9 @@ } } -package const onDeserializedField = "__onDeserialized"; -package const onDeserializingField = "__onDeserializing"; -package const onSerializedField = "__onSerialized"; -package const onSerializingField = "__onSerializing"; \ No newline at end of file +package: + +const onDeserializedField = "__onDeserialized"; +const onDeserializingField = "__onDeserializing"; +const onSerializedField = "__onSerialized"; +const onSerializingField = "__onSerializing"; \ No newline at end of file diff -r b538d02578cb -r 8b9409423740 orange/serialization/Serializer.d --- a/orange/serialization/Serializer.d Sat Aug 06 13:38:26 2011 +0200 +++ b/orange/serialization/Serializer.d Sun Aug 07 17:53:50 2011 +0200 @@ -453,7 +453,7 @@ nextId; archive.unarchiveObject(keyOrId, id, val, { - triggerEvents(deserializing, value, { + triggerEvents(deserializing, cast(T) val, { value = cast(T) val; auto runtimeType = value.classinfo.name; diff -r b538d02578cb -r 8b9409423740 tests/Event.d --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/tests/Event.d Sun Aug 07 17:53:50 2011 +0200 @@ -0,0 +1,63 @@ +/** + * Copyright: Copyright (c) 2011 Jacob Carlborg. All rights reserved. + * Authors: Jacob Carlborg + * Version: Initial created: Aug 6, 2011 + * License: $(LINK2 http://www.boost.org/LICENSE_1_0.txt, Boost Software License 1.0) + */ +module tests.Event; + +import orange.core.string; +import orange.serialization.Serializer; +import orange.serialization.Events; +import orange.serialization.archives.XMLArchive; +import orange.test.UnitTester; +import tests.Util; + +Serializer serializer; +XMLArchive!(char) archive; + +int[] arr; + +class Foo +{ + + void serializing () + { + arr ~= 1; + } + + void serialized () + { + arr ~= 2; + } + + void deserializing () + { + arr ~= 3; + } + + void deserialized () + { + arr ~= 4; + } + + mixin OnSerializing!(serializing); + mixin OnSerialized!(serialized); + mixin OnDeserializing!(deserializing); + mixin OnDeserialized!(deserialized); +} + +unittest +{ + archive = new XMLArchive!(char); + serializer = new Serializer(archive); + + describe("serialization events") in { + it("all four events should be triggered when serializing and deserializing") in { + serializer.serialize(new Foo); + serializer.deserialize!(Foo)(archive.untypedData); + + assert(arr == [1, 2, 3, 4]); + }; + }; +} \ No newline at end of file diff -r b538d02578cb -r 8b9409423740 tests/_.d --- a/tests/_.d Sat Aug 06 13:38:26 2011 +0200 +++ b/tests/_.d Sun Aug 07 17:53:50 2011 +0200 @@ -13,6 +13,7 @@ import tests.AssociativeArray; import tests.AssociativeArrayReference; import tests.Enum; +import tests.Event; import tests.Object; import tests.Pointer; import tests.Primitive; diff -r b538d02578cb -r 8b9409423740 unittest.sh --- a/unittest.sh Sat Aug 06 13:38:26 2011 +0200 +++ b/unittest.sh Sun Aug 07 17:53:50 2011 +0200 @@ -30,6 +30,7 @@ tests/AssociativeArray.d \ tests/AssociativeArrayReference.d \ tests/Enum.d \ +tests/Event.d \ tests/Object.d \ tests/Pointer.d \ tests/Primitive.d \