Beispiel #1
0
        public void MergeAdds_IsCommutative(Guid firstTag, Guid secondTag, long timestamp)
        {
            var firstElement  = new OUR_OptimizedSetElement <TestType>(_builder.Build(), firstTag, timestamp, false);
            var secondElement = new OUR_OptimizedSetElement <TestType>(_builder.Build(), secondTag, timestamp, false);
            var thirdElement  = new OUR_OptimizedSetElement <TestType>(_builder.Build(), secondTag, timestamp, false);
            var fourthElement = new OUR_OptimizedSetElement <TestType>(_builder.Build(), firstTag, timestamp, false);
            var fifthElement  = new OUR_OptimizedSetElement <TestType>(_builder.Build(), firstTag, timestamp, false);

            var firstRepository = new OUR_OptimizedSetRepository();
            var firstService    = new OUR_OptimizedSetService <TestType>(firstRepository);

            _repository.PersistElements(new HashSet <OUR_OptimizedSetElement <TestType> > {
                firstElement, secondElement, thirdElement
            }.ToImmutableHashSet());
            firstService.Merge(new HashSet <OUR_OptimizedSetElement <TestType> > {
                fourthElement, fifthElement
            }.ToImmutableHashSet());

            var firstRepositoryValues = firstRepository.GetElements();

            var secondRepository = new OUR_OptimizedSetRepository();
            var secondService    = new OUR_OptimizedSetService <TestType>(secondRepository);

            _repository.PersistElements(new HashSet <OUR_OptimizedSetElement <TestType> > {
                fourthElement, fifthElement
            }.ToImmutableHashSet());
            secondService.Merge(new HashSet <OUR_OptimizedSetElement <TestType> > {
                firstElement, secondElement, thirdElement
            }.ToImmutableHashSet());

            var secondRepositoryValues = firstRepository.GetElements();

            Assert.Equal(firstRepositoryValues, secondRepositoryValues);
        }
        private Dictionary <Node, CRDT.Application.Commutative.Set.OUR_OptimizedSetService <TestType> > CreateCommutativeReplicas(List <Node> nodes)
        {
            var dictionary = new Dictionary <Node, CRDT.Application.Commutative.Set.OUR_OptimizedSetService <TestType> >();

            foreach (var node in nodes)
            {
                var repository = new OUR_OptimizedSetRepository();
                var service    = new CRDT.Application.Commutative.Set.OUR_OptimizedSetService <TestType>(repository);

                dictionary.Add(node, service);
            }

            return(dictionary);
        }