Today I needed to create a sequential GUid in .Net to test if my Compareto function worked as expected.
The problem is that Guid.NewGuid
produces a random Guid duh. which isn’t sequential. Of course in my unittests I want to know what value I’m giving to the guid.
.Net doesn’t have a SequentialGuid function as far as I know So went for a little Google. And I found this site.
[Generate Sequential GUIDs for SQL Server 2005 in C#][1]
Which has an interesting concept. But I needed no such difficult things for my unittests.
The following would prove my point just as well.
ObjectThatHasGuid1 = New ObjectThatHasGuid()
ObjectThatHasGuid1.GetType.GetField("_id",Reflection.BindingFlags.NonPublic or Reflection.BindingFlags.Instance).SetValue(ObjectThatHasGuid1,new Guid("00000000-0000-0000-0000-000000000001"))
ObjectThatHasGuid2 = New ObjectThatHasGuid()
ObjectThatHasGuid2.GetType.GetField("_id",Reflection.BindingFlags.NonPublic or Reflection.BindingFlags.Instance).SetValue(ObjectThatHasGuid2,new Guid("00000000-0000-0000-0000-000000000002"))```
Life can be so easy sometimes if you know how. I totaly forgot that GUID was an object and that you can instantiate it.
[1]: http://developmenttips.blogspot.com/2008/03/generate-sequential-guids-for-sql.html