Пример #1
0
        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);
        }
Пример #2
0
        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)));
        }