GitXplorerGitXplorer
i

CRDTree

public
2 stars
2 forks
5 issues

Commits

List of commits on branch main.
Unverified
6b130018f925cb2c5eed08a8fb41079fb1f2f905

Batch updates that are sent around the network

bbraxtonhall committed 3 years ago
Unverified
448347c66aa66facc748f7a562d099d4f15e9856

Add script for reading log output from experiments

bbraxtonhall committed 3 years ago
Unverified
b764183a2d7a46d9f8e2fe0afa6e4aa76bf5d6c0

Update TODO

bbraxtonhall committed 3 years ago
Unverified
310b33d28064697ad06a84c5579e22fcb866c1b9

Use recursion to build eval network slowly

bbraxtonhall committed 3 years ago
Unverified
cb7f43cdae4c2f72a3606aa0a67a20848d65b0f5

Prevent newCollect infinite loop

bbraxtonhall committed 3 years ago
Unverified
dfeda34ba3b1af7b78b363e60147147197f2cf37

[REVERT ME] Remove peer discovery

bbraxtonhall committed 3 years ago

README

The README file for this repository.

CPSC538B-Project

Milestone 1

Requirements for Milestone 1 include:

  • FR1: Should have a command line invokable test suite
    • Can be invoked via yarn test
  • FR2: Should have signature and stubs for the high level API
    • Can be seen in the files here. These files include the high level interfaces we designed during the development period of this Milestone.
  • NFR1: Should have a comprehensive test suite for CRDT as well as the CRDTree extension
    • Can be seen in the test suite written here. Each test is annotated with the behaviour it attempts to expose.
    • Some test cases were taken directly from Kleppmann et al. (and are labelled as such). This means we expect our implementation to at least match their specification of correctness.
  • NRF2: Should have a partial test suite for the CRDTree Protocol Library
    • Can be seen in the starter test suite written here. While less complete, it had us reason about how the API should be useable.

Milestone 2

Requirements for Milestone 2 include:

  • FR1: Should be able to initialize a CRDT
    • Can be seen by invoking our test suite via yarn test
  • FR2: Should be able to merge two CRDTs given their initial states are the same
    • We now enforce that every instance has the same initial state, so any two CRDT objects are mergeable. This can also be seen via our test suite
  • FR3: Should be able to render a CRDTree
    • Can be seen by invoking our test suite via yarn test
  • NFR1: Merges should terminate in a reasonable amount of time, less than a second
    • This is only kind of demonstrated through our tests, and we now realise this was underspecified. When given a list with 47347 insertions, performance degrades to an abysmal 17 seconds You know what? We did it. You can insert like 100 elements and it gets done in under a second. Please clap
  • NFR2: Memory allocation should scale at worst polynomially in operations
    • This test was born out of some scary things we saw in the original algorithm by Kleppmann et al., however by keeping our semantics simple we were able to do away with some of their requirements and maintained linear storage usage (if you don't count all the arrays we let get garbage collected). You would need to read the code to see this :(

Milestone 3

  • FR1: Should be able to make a fork
    • Can be seen by invoking our test suite via yarn test
  • FR2: Should be able to join a fork
    • Can be seen by invoking our test suite via yarn test
  • FR3: Should be able to render a history that contains forks or joins
    • Can be seen by invoking our test suite via yarn test

This milestone contained quite a few tricky bugs (including some that really should have been exposed during Milestone 2). All of them can be seen in the new tests added during this development period.

"Milestone 4"

  • FR1: Should be able to connect to other users
  • FR2: Should be able to calculate processes that are subscribed to an operation
  • FR3: Should send new operations to processes on the same fork
  • FR4: Should not send new operations to processes not on the same fork
  • NFR1: Should have a complete test suite for the CRDTree Protocol Library

The functional requirements of this milestone can be evaluated by running yarn test in the network directory

Development

Requirements

To run the tests

  1. yarn install to gather dependencies
  2. yarn test to invoke the tests