public void Add_WithExistingValues_AddsElementToTheRepository(HashSet <OUR_OptimizedSetWithVCElement <TestType> > adds, TestType value, Guid tag, Node node) { var clock = ImmutableSortedDictionary <Node, long> .Empty; _repository.PersistElements(adds.ToImmutableHashSet()); _ourSetService.DownstreamAdd(value, tag, new VectorClock(clock.Add(node, 0))); var repositoryValues = _repository.GetElements(); var actualValues = repositoryValues.Where(v => Equals(v.Value, value) && v.Tag == tag && v.VectorClock.Equals(new VectorClock(clock.Add(node, 0)))); Assert.Single(actualValues); }
public void MergeAdds_UpdatedElementWithHigherTimestamp_ReplacesElementsInRepository(TestType value, Guid tag, Node node) { var clock = ImmutableSortedDictionary <Node, long> .Empty; var element = new OUR_OptimizedSetWithVCElement <TestType>(value, tag, new VectorClock(clock.Add(node, 0)), false); _repository.PersistElements(new HashSet <OUR_OptimizedSetWithVCElement <TestType> > { element }.ToImmutableHashSet()); var newElement = new OUR_OptimizedSetWithVCElement <TestType>(_builder.Build(value.Id), tag, new VectorClock(clock.Add(node, 1)), false); _ourSetService.LocalAdd(newElement.Value, newElement.Tag, newElement.VectorClock); var repositoryValues = _repository.GetElements(); Assert.Equal(0, repositoryValues.Count(x => Equals(x, element))); Assert.Equal(1, repositoryValues.Count(x => Equals(x, newElement))); }