public void GiveTakeMergeExceptInvertIntersectRangeRandomTest() { var random = new Random(); var set = new HashSet <uint>(); IUniqueIdentificationSet uidSet = new UniqueIdentificationSet(false); for (var it = 0; it < 20000; it++) { var low = (uint)(random.NextDouble() * (long)100000); var high = low + (uint)(random.NextDouble() * (long)100); if (random.Next() % 2 == 0) { for (var val = low; val <= high; val++) { AssertEquals(set.Add(val), !uidSet.Contains(val)); } if (random.Next() % 2 == 0) { uidSet.GiveRange(low, high); } else { uidSet = uidSet.Merge(new UniqueIdentificationSet(low, high).Invert().Invert()); } for (var val = low; val <= high; val++) { AssertTrue(uidSet.Contains(val)); } } else { for (var val = low; val <= high; val++) { AssertEquals(set.Remove(val), uidSet.Contains(val)); } var rand = random.Next() % 3; if (rand == 0) { uidSet.TakeRange(low, high); } else if (rand == 1) { uidSet = uidSet.Except(new UniqueIdentificationSet(low, high).Invert().Invert()); } else { uidSet = uidSet.Intersect(new UniqueIdentificationSet(low, high).Invert()); } for (var val = low; val <= high; val++) { AssertFalse(uidSet.Contains(val)); } } } }
public void GiveTakeMergeExceptInvertIntersectRangeRandomTest() { var random = new Random(); var set = new HashSet<uint>(); IUniqueIdentificationSet uidSet = new UniqueIdentificationSet(false); for (var it = 0; it < 20000; it++) { var low = (uint)(random.NextDouble() * (long)100000); var high = low + (uint)(random.NextDouble() * (long)100); if (random.Next() % 2 == 0) { for (var val = low; val <= high; val++) { AssertEquals(set.Add(val), !uidSet.Contains(val)); } if (random.Next() % 2 == 0) { uidSet.GiveRange(low, high); } else { uidSet = uidSet.Merge(new UniqueIdentificationSet(low, high).Invert().Invert()); } for (var val = low; val <= high; val++) { AssertTrue(uidSet.Contains(val)); } } else { for (var val = low; val <= high; val++) { AssertEquals(set.Remove(val), uidSet.Contains(val)); } var rand = random.Next() % 3; if (rand == 0) { uidSet.TakeRange(low, high); } else if (rand == 1) { uidSet = uidSet.Except(new UniqueIdentificationSet(low, high).Invert().Invert()); } else { uidSet = uidSet.Intersect(new UniqueIdentificationSet(low, high).Invert()); } for (var val = low; val <= high; val++) { AssertFalse(uidSet.Contains(val)); } } } }