10 KiB
Contributing
High Level Process to Contribute Code
- You should open a PR against
mainand ensure that all CI passes. - Your changes should have unit and/or integration tests.
- Your changes should pass the linter.
- You should get a full code review from two of the maintainers.
- Then you can merge your changes. (Which will then be included in the next release)
Set up your dev environment
Requirements
We use Node v14 for development - that is the version that our linters require.
You must also use npm v7. You can check your npm version with:
npm -v
If your npm version is too old, use this command to update it:
npm -g i npm@7
Set up
- Clone the repository
cdinto the repository- Install dependencies with
npm install
Build
npm run build
Run the linter
npm install
npm run build
npm run lint
Running Tests
For integration and browser tests, we use a rippled node in standalone mode to test xrpl.js code against. To set this up, you can either run rippled locally, or set up the Docker container natenichols/rippled-standalone:latest for this purpose. The latter will require you to install Docker.
Unit Tests
npm install
npm run build
npm test
Integration Tests
npm install
# sets up the rippled standalone Docker container - you can skip this step if you already have it set up
docker run -p 6006:6006 -it natenichols/rippled-standalone:latest
npm run build
npm run test:integration
Browser Tests
There are two ways to run browser tests.
One is in the browser - run npm run build:browserTests and open test/localIntegrationRunner.html in your browser.
The other is in the command line (this is what we use for CI) -
npm run build
# sets up the rippled standalone Docker container - you can skip this step if you already have it set up
docker run -p 6006:6006 -it natenichols/rippled-standalone:latest
npm run test:browser
High Level Architecture
This is a monorepo, which means that there are multiple packages in a single GitHub repository using Lerna.
The 4 packages currently here are:
- xrpl.js - The client library for interacting with the ledger.
- ripple-binary-codec - A library for serializing and deserializing transactions for the ledger.
- ripple-keypairs - A library for generating and using cryptographic keypairs.
- ripple-address-codec - A library for encoding and decoding XRP Ledger addresses and seeds.
Each package has it's own README which dives deeper into what it's main purpose is, and the core functionality it offers. They also run tests independently as they were originally in separate repositories.
These are managed in a monorepo because often a change in a lower-level library will also require a change in xrpl.js, and so it makes sense to be able to allow for modifications of all packages at once without coordinating versions across multiple repositories.
Let's dive a bit into how xrpl.js is structured!
The File Structure
Within the xrpl package, each folder has a specific purpose:
Client - This contains logic for handling the websocket connection to rippled servers.
Models - These types model LedgerObjects, Requests/Methods, and Transactions in order to give type hints and nice errors for users.
Sugar - This is where handy helper functions end up, like submit, autofill, and getXRPBalance amongst others.
Utils - These are shared functions which are useful for conversions, or internal implementation details within the library.
Wallet - This logic handles managing keys, addresses, and signing within xrpl.js
Writing Tests for xrpl.js
For every file in src, we try to have a corresponding file in test with unit tests.
The goal is to maintain above 80% code coverage, and generally any new feature or bug fix should be accompanied by unit tests, and integration tests if applicable.
For an example of a unit test, check out the autofill tests here.
If your code connects to the ledger (ex. Adding a new transaction type) it's handy to write integration tests to ensure that you can successfully interact with the ledger. Integration tests are generally run against a docker instance of rippled which contains the latest updates. Since standalone mode allows us to manually close ledgers, this allows us to run integration tests at a much faster rate than if we had to wait 4-5 seconds per transaction for the ledger to validate the transaction. See above for how to start up the docker container to run integration tests.
All integration tests should be written in the test/integration folder, with new Requests and Transactions tests being in their respective folders.
For an example of how to write an integration test for xrpl.js, you can look at the Payment integration test.
Generate reference docs
You can see the complete reference documentation at xrpl.js docs. You can also generate them locally using typedoc:
npm run docgen
This updates docs/ at the top level, where GitHub Pages looks for the docs.
Update definitions.json
Use this repo to generate a new definitions.json file from the rippled source code. Instructions are available in that README.
Adding and removing packages
xrpl.js uses lerna and npm's workspaces features to manage a monorepo.
Adding and removing packages requires a slightly different process than normal
as a result.
Adding or removing development dependencies
xrpl.js strives to use the same development dependencies in all packages.
You may add and remove dev dependencies like normal:
### adding a new dependency
npm install --save-dev abbrev
### removing a dependency
npm uninstall --save-dev abbrev
Adding or removing runtime dependencies
You need to specify which package is changing using the -w flag:
### adding a new dependency to `xrpl`
npm install abbrev -w xrpl
### adding a new dependency to `ripple-keypairs`
npm install abbrev -w ripple-keypairs
### removing a dependency
npm uninstall abbrev -w xrpl
Release process + checklist
PR process
- Your changes should be on a branch.
- Your changes should have unit tests.
- Lint the code with
npm lint - Build your code with
npm build - Run the unit tests with
npm test - Get a full code review.
- Merge your branch into
mainand push to github. - Ensure that all tests passed on the last CI that ran on
main.
Release
-
Checkout
main(or your beta branch) andgit pull. -
Create a new branch (
git checkout -b <BRANCH_NAME>) to capture updates that take place during this process. -
Update
HISTORY.mdto reflect release changes.- Update the version number and release date, and ensure it lists the changes since the previous release.
-
Run
npm run docgenif the docs were modified in this release to update them (skip this step for a beta). -
Run
npm run buildto triple check the build still works -
Run
npx lerna version --no-git-tag-version- This creates a draft PR and bumps the versions of the packages.- For each changed package, pick what the new version should be. Lerna will bump the versions, commit version bumps to
main, and create a new git tag for each published package. - If publishing a beta, make sure that the versions are all of the form
a.b.c-beta.d, wherea,b, andcare identical to the last normal release except for one, which has been incremented by 1.
- For each changed package, pick what the new version should be. Lerna will bump the versions, commit version bumps to
-
Run
npm ito update the package-lock with the updated versions. -
Create a new PR from this branch into
mainand merge it (you can directly merge into the beta branch for a beta). -
Checkout
mainandgit pull(you can skip this step for a beta since you already have the latest version of the beta branch). -
Actually publish the packages with one of the following:
- Stable release: Run
npx lerna publish from-package --yes - Beta release: Run
npx lerna publish from-package --dist-tag beta --yes
Notice this allows developers to install the package withnpm add xrpl@beta
- Stable release: Run
-
If requested, enter your npmjs.com OTP (one-time password) to complete publication.
-
If not a beta release: Create a new branch (
git checkout -b <BRANCH_NAME>) to capture the updated packages from the release. Merge those changes intomain.NOW YOU HAVE PUBLISHED! But you're not done; we have to notify people!
-
Pull the most recent changes to
mainlocally. -
Run
git tag <tagname> -m <tagname>, where<tagname>is the new package and version (e.g.xrpl@2.1.1), for each version released. -
Run
git push --follow-tags, to push the tags to Github. -
On GitHub, click the "Releases" link on the right-hand side of the page.
-
Repeat for each release:
- Click "Draft a new release"
- Click "Choose a tag", and choose a tag that you just created.
- Edit the name of the release to match the tag (IE <package>@<version>) and edit the description as you see fit.
-
Lastly, send an email to xrpl-announce.
ripple-lib 1.x releases
-
Publish the release to npm.
-
If you are publishing a 1.x release to the
xrplpackage, use:npm publish --tag ripple-libThis prevents the release from taking the
latesttag.
-
For ripple-lib:
-
Have one of the ripple-lib package maintainers push to
ripple-lib(npm package name). You can contact @intelliot to request the npm publish. -
For ripple-lib releases, cross-publish the package to
xrplwith--tag ripple-lib
Mailing Lists
We have a low-traffic mailing list for announcements of new xrpl.js releases. (About 1 email every couple of weeks)
If you're using the XRP Ledger in production, you should run a rippled server and subscribe to the ripple-server mailing list as well.