private Dictionary <Node, CRDT.Application.Commutative.Set.OUR_OptimizedSetWithVCService <TestType> > CreateCommutativeReplicas(List <Node> nodes) { var dictionary = new Dictionary <Node, CRDT.Application.Commutative.Set.OUR_OptimizedSetWithVCService <TestType> >(); foreach (var node in nodes) { var repository = new OUR_OptimizedSetWithVCRepository(); var service = new CRDT.Application.Commutative.Set.OUR_OptimizedSetWithVCService <TestType>(repository); dictionary.Add(node, service); } return(dictionary); }
public void MergeAdds_IsCommutative(Guid firstTag, Guid secondTag, Node node) { var clock = ImmutableSortedDictionary <Node, long> .Empty; var firstElement = new OUR_OptimizedSetWithVCElement <TestType>(_builder.Build(), firstTag, new VectorClock(clock.Add(node, 0)), false); var secondElement = new OUR_OptimizedSetWithVCElement <TestType>(_builder.Build(), secondTag, new VectorClock(clock.Add(node, 0)), false); var thirdElement = new OUR_OptimizedSetWithVCElement <TestType>(_builder.Build(), secondTag, new VectorClock(clock.Add(node, 0)), false); var fourthElement = new OUR_OptimizedSetWithVCElement <TestType>(_builder.Build(), firstTag, new VectorClock(clock.Add(node, 0)), false); var fifthElement = new OUR_OptimizedSetWithVCElement <TestType>(_builder.Build(), firstTag, new VectorClock(clock.Add(node, 0)), false); var firstRepository = new OUR_OptimizedSetWithVCRepository(); var firstService = new OUR_OptimizedSetWithVCService <TestType>(firstRepository); _repository.PersistElements(new HashSet <OUR_OptimizedSetWithVCElement <TestType> > { firstElement, secondElement, thirdElement }.ToImmutableHashSet()); firstService.Merge(new HashSet <OUR_OptimizedSetWithVCElement <TestType> > { fourthElement, fifthElement }.ToImmutableHashSet()); var firstRepositoryValues = firstRepository.GetElements(); var secondRepository = new OUR_OptimizedSetWithVCRepository(); var secondService = new OUR_OptimizedSetWithVCService <TestType>(secondRepository); _repository.PersistElements(new HashSet <OUR_OptimizedSetWithVCElement <TestType> > { fourthElement, fifthElement }.ToImmutableHashSet()); secondService.Merge(new HashSet <OUR_OptimizedSetWithVCElement <TestType> > { firstElement, secondElement, thirdElement }.ToImmutableHashSet()); var secondRepositoryValues = firstRepository.GetElements(); Assert.Equal(firstRepositoryValues, secondRepositoryValues); }