GitXplorerGitXplorer
i

CRDTree

public
2 stars
2 forks
5 issues

Commits

List of commits on branch main.
Verified
65a1d154755773a0f4bdbb9d3f7dc8f401b6f45b

Merge pull request #33 from Haotian-Yang/m4

bbraxtonhall committed 3 years ago
Verified
2091d1978387754e53d74bb6761ffb03d4602ef1

Merge pull request #32 from Haotian-Yang/tree-chat

bbraxtonhall committed 3 years ago
Unverified
0794cb1c02232de4e11d27a337430552e4714afb

Deliver Milestone 4

bbraxtonhall committed 3 years ago
Unverified
79b4d3e3c8d4716c8998b9f14ea7a0639f6e1a6f

Implement TreeChat

bbraxtonhall committed 3 years ago
Unverified
5ec4fd3362c9c31509b57dc877e1f9765f964a43

Revert "[DON'T MERGE] Break bootstrapping"

bbraxtonhall committed 3 years ago
Unverified
f4ac2daa8de5878cef5c390d22ae330ea17e4806

Revert "[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