The Fluid Framework is a TypeScript library for building distributed, real-time collaborative web applications.
You may be here because you want to...
- Learn more about the Fluid Framework
- Build a Fluid object
Documentation and guides can be found at https://fluidframework.com/.
Hello World repo can be found at https://github.com/microsoft/FluidHelloWorld.
Core Examples repo can be found at https://github.com/microsoft/FluidExamples.
Have questions? Engage with other Fluid Framework users and developers on StackOverflow
The core code for both the Fluid client packages and the reference ordering service is contained within this repo.
The repo structure is somewhat unique because it contains two monorepos as well as several standalone packages. The monorepos are managed using Lerna and are versioned separately from one another, but internally all packages in a monorepo are versioned together. Outside the monorepos there are plenty of packages which are versioned independently.
Here's the breakdown of the repo:
- Fluid Framework Client Monorepo (lerna.json)
- Reference Fluid Ordering Service ("Routerlicious") Monorepo (dir | lerna.json)
- Common Packages
- Auxiliary Microservice Packages (supporting Routerlicious)
- Server dir (excluding Routerlicious itself)
- Internal/Misc Packages
Dependencies between packages in various layers of the system are enforced via a build step called layer-check. You can view the full list of packages and layers in docs/PACKAGES.md.
In order to build the Fluid Framework, ensure that you have installed Git and Node.js.
Note: we recommend using nvm (for Windows or MacOS/Linux) to install Node.js, in case you find yourself needing to install different versions of Node.js side-by-side.
Clone a copy of the repo and change to the repo root directory:
git clone https://github.com/microsoft/FluidFramework.git
cd FluidFramework
Run the following to build the client packages:
npm install
npm run build:fast
See also: Contributing
You can run all of our tests from the root of the repo, or you can run a scoped set of tests by running the test
command from the package you're interested in.
Note: Some of the tests depend on test collateral that lives in a submodule here: https://github.com/microsoft/FluidFrameworkTestData. You may choose to fetch that collateral into your local repository, which is required to run all the tests - otherwise some will be skipped.
First install Git LFS from https://git-lfs.github.com/. Then, from the repo root:
git lfs install
git submodule init
git submodule update
npm run test
npm run test:coverage
Note: The official build uses npm run test:full, which doesn’t work on Windows.
npm run test:coverage
npm run test:copyresults
We've checked in VS Code configuration
enabling F5 from a spec.ts
file to run those tests if you set the debug configuration to "Debug Current Test".
This will use an in-memory implementation of the Fluid server to sync between the two panes in the browser window.
- Choose an example under
/examples
- Navigate to the example's directory, e.g.
/examples/data-objects/clicker
npm run start
- Browse to http://localhost:8080 to interact with two copies of the example side-by-side
This will run the local Fluid server implementation we call "Tinylicious", so you can sync between multiple browser instances.
First, start Tinylicious by running these commands from /server/tinylicious
:
npm install
npm run build
npm run start
Then:
- Navigate to the example of your choice (same as above)
npm run start:tinylicious
- Browse to http://localhost:8080, copy the full URL you're redirected to, and open in a second window to collaborate
There are many ways to contribute to Fluid.
- Participate in Q&A on StackOverflow
- Submit bugs and help us verify fixes as they are checked in.
- Review the source code changes.
- Contribute bug fixes.
Detailed instructions for working in the repo can be found in the Wiki.
This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.
This project may contain Microsoft trademarks or logos for Microsoft projects, products, or services. Use of these trademarks or logos must follow Microsoft’s Trademark & Brand Guidelines. Use of Microsoft trademarks or logos in modified versions of this project must not cause confusion or imply Microsoft sponsorship.