summaryrefslogtreecommitdiff
path: root/Xamarin.Forms.Core.UnitTests/AnimatableKeyTests.cs
diff options
context:
space:
mode:
authorJason Smith <jason.smith@xamarin.com>2016-03-22 13:02:25 -0700
committerJason Smith <jason.smith@xamarin.com>2016-03-22 16:13:41 -0700
commit17fdde66d94155fc62a034fa6658995bef6fd6e5 (patch)
treeb5e5073a2a7b15cdbe826faa5c763e270a505729 /Xamarin.Forms.Core.UnitTests/AnimatableKeyTests.cs
downloadxamarin-forms-17fdde66d94155fc62a034fa6658995bef6fd6e5.tar.gz
xamarin-forms-17fdde66d94155fc62a034fa6658995bef6fd6e5.tar.bz2
xamarin-forms-17fdde66d94155fc62a034fa6658995bef6fd6e5.zip
Initial import
Diffstat (limited to 'Xamarin.Forms.Core.UnitTests/AnimatableKeyTests.cs')
-rw-r--r--Xamarin.Forms.Core.UnitTests/AnimatableKeyTests.cs72
1 files changed, 72 insertions, 0 deletions
diff --git a/Xamarin.Forms.Core.UnitTests/AnimatableKeyTests.cs b/Xamarin.Forms.Core.UnitTests/AnimatableKeyTests.cs
new file mode 100644
index 00000000..385ab1fc
--- /dev/null
+++ b/Xamarin.Forms.Core.UnitTests/AnimatableKeyTests.cs
@@ -0,0 +1,72 @@
+using System;
+using System.Collections.Generic;
+using NUnit.Framework;
+
+namespace Xamarin.Forms.Core.UnitTests
+{
+ [TestFixture]
+ public class AnimatableKeyTests
+ {
+ class FakeAnimatable : IAnimatable
+ {
+ public void BatchBegin ()
+ {
+
+ }
+
+ public void BatchCommit ()
+ {
+
+ }
+ }
+
+ [Test]
+ public void KeysWithDifferentHandlesAreNotEqual ()
+ {
+ var animatable = new FakeAnimatable();
+
+ var key1 = new AnimatableKey(animatable, "handle1");
+ var key2 = new AnimatableKey(animatable, "handle2");
+
+ Assert.AreNotEqual (key1, key2);
+ }
+
+ [Test]
+ public void KeysWithDifferentAnimatablesAreNotEqual ()
+ {
+ var animatable1 = new FakeAnimatable();
+ var animatable2 = new FakeAnimatable();
+
+ var key1 = new AnimatableKey(animatable1, "handle");
+ var key2 = new AnimatableKey(animatable2, "handle");
+
+ Assert.AreNotEqual (key1, key2);
+ }
+
+ [Test]
+ public void KeysWithSameAnimatableAndHandleAreEqual ()
+ {
+ var animatable = new FakeAnimatable();
+
+ var key1 = new AnimatableKey(animatable, "handle");
+ var key2 = new AnimatableKey(animatable, "handle");
+
+ Assert.AreEqual (key1, key2);
+ }
+
+ [Test]
+ public void ThrowsWhenKeysWithSameAnimatableAdded ()
+ {
+ var animatable = new FakeAnimatable();
+
+ var key1 = new AnimatableKey(animatable, "handle");
+ var key2 = new AnimatableKey(animatable, "handle");
+
+ var dict = new Dictionary<AnimatableKey, object> { { key1, new object () } };
+
+ Assert.Throws<ArgumentException> (() => {
+ dict.Add (key2, new object ());
+ });
+ }
+ }
+} \ No newline at end of file