From fc543b7cb2d9339722fa33ed757ab49cd7ef5946 Mon Sep 17 00:00:00 2001
From: Fuxing Loh <4266087+fuxingloh@users.noreply.github.com>
Date: Fri, 10 Sep 2021 12:20:40 +0800
Subject: [PATCH] initial jellyfish ecosystem consolidation PR (#650)
---
.codeclimate.yml | 1 +
.eslintrc | 15 ++++--
.github/CODEOWNERS | 9 ++--
.github/workflows/release-drafter.yml | 4 ++
.gitignore | 4 ++
.idea/dictionaries/fuxing.xml | 4 ++
CONTRIBUTING.md | 19 ++++++--
README.md | 67 ++++++++++++++++++++-------
8 files changed, 95 insertions(+), 28 deletions(-)
diff --git a/.codeclimate.yml b/.codeclimate.yml
index cc81ba5889..af7a77a2fe 100644
--- a/.codeclimate.yml
+++ b/.codeclimate.yml
@@ -11,4 +11,5 @@ exclude_patterns:
- "**/node_modules/"
- "**/*.test.ts"
- "**/*.test.tsx"
+ - "**/*.e2e.ts"
- "**/*.d.ts"
diff --git a/.eslintrc b/.eslintrc
index 5c12de911a..b7123b6f6b 100644
--- a/.eslintrc
+++ b/.eslintrc
@@ -12,9 +12,18 @@
"website"
],
"rules": {
- "curly": ["error", "all"],
- "brace-style": ["error", "1tbs"],
- "func-style": [2, "declaration"],
+ "curly": [
+ "error",
+ "all"
+ ],
+ "brace-style": [
+ "error",
+ "1tbs"
+ ],
+ "func-style": [
+ 2,
+ "declaration"
+ ],
"import/no-default-export": "error"
},
"overrides": [
diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS
index 893ef0c089..b1c8d1ff50 100644
--- a/.github/CODEOWNERS
+++ b/.github/CODEOWNERS
@@ -1,8 +1,8 @@
# Define individuals that are responsible for code in this repository.
# More details are here: https://help.github.com/articles/about-codeowners/
-/.github/ @fuxingloh
-/.husky/ @fuxingloh
+/.github/ @fuxingloh @monstrobishi
+/.husky/ @fuxingloh @monstrobishi
/packages/jellyfish/ @fuxingloh @canonbrother
/packages/jellyfish-address/ @fuxingloh @ivan-zynesis
@@ -39,7 +39,10 @@ tsconfig.build.json @fuxingloh @canonbrother @ivan-z
jest.config.js @fuxingloh @canonbrother @ivan-zynesis
package.json @fuxingloh
package-lock.json @fuxingloh
+.codeclimate.yml @fuxingloh
+.eslintrc @fuxingloh
+netlify.toml @fuxingloh
-CONTRIBUTING.md @fuxingloh @canonbrother @jingyi2811
+CONTRIBUTING.md @fuxingloh
README.md @fuxingloh
LICENSE @fuxingloh
diff --git a/.github/workflows/release-drafter.yml b/.github/workflows/release-drafter.yml
index 2b9a939f94..98d53ae278 100644
--- a/.github/workflows/release-drafter.yml
+++ b/.github/workflows/release-drafter.yml
@@ -4,6 +4,10 @@ on:
push:
branches: [ main ]
+concurrency:
+ group: ${{ github.workflow }}-${{ github.event_name }}-${{ github.ref }}
+ cancel-in-progress: true
+
jobs:
main:
runs-on: ubuntu-latest
diff --git a/.gitignore b/.gitignore
index 2f2c9a6edd..9691c01704 100644
--- a/.gitignore
+++ b/.gitignore
@@ -38,3 +38,7 @@ coverage
# typescript
tsconfig.build.tsbuildinfo
+
+# Level
+.level
+.leveldb
diff --git a/.idea/dictionaries/fuxing.xml b/.idea/dictionaries/fuxing.xml
index e7dd0b2595..bdc9082528 100644
--- a/.idea/dictionaries/fuxing.xml
+++ b/.idea/dictionaries/fuxing.xml
@@ -32,6 +32,7 @@
checksig
checksigverify
clarkequayheight
+ codeclimate
codeseparator
createmasternode
createpoolpair
@@ -44,6 +45,7 @@
dakotaheight
debugexclude
defi
+ defich
defichain
defid
descendantcount
@@ -52,6 +54,7 @@
devnet
dftx
dockerode
+ dogfooding
dummypos
dumpprivkey
emissionburn
@@ -83,6 +86,7 @@
gettxout
getunconfirmedbalance
getwalletinfo
+ ghcr
greaterthan
greaterthanorequal
hdkeypath
diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md
index 9bcaf3103d..1009540bf4 100644
--- a/CONTRIBUTING.md
+++ b/CONTRIBUTING.md
@@ -2,6 +2,13 @@
## All features must be unit tested with accepted coverage. (Target 100%)
+```txt
+packages/
+├─ jellyfish-*/
+│ ├─ __tests__/following-src-structure.test.ts
+│ └─ src/following-src-structure.ts
+```
+
Each package or functionality must be accompanied by full coverage testing.
Due to Javascript type coercion, all test assertions must use strict equality checking.
@@ -30,23 +37,25 @@ Each pull request with feature change should have accompanying documentations un
## Explicit over implicit
-Each package, feature, code and decision should be explicit and well documented over implicitly guessing.
+- Each package, feature, code and decision should be explicit and well documented over implicitly guessing.
+- Each test must be written explicitly as clear as possible with no implicit guessing.
## TypeScript
TypeScript must be used for all code written in this project.
-> Heavily adapted from [deno style guide](https://github.com/denoland/deno/blob/main/docs/contributing/style_guide.md).
-
### Document and maintain browser compatibility.
### Minimize dependencies (target zero)
### Do not depend on external code. (never if possible)
-### Use underscores, not dashes in filenames.
+### Use PascalCase and period, not underscores, or dashes in filenames.
+
+Example: Use `FooBar.ts` instead of `foo-bar.ts` or `foo_bar.ts`.
-Example: Use `foo_bar.ts` instead of `foo-bar.ts`.
+> Previously the preferred method is underscores (`foo_bar.ts`), this has be deprecated in favour of PascalCase.
+> PascalCase follows the natural class naming pattern while underscores or dashes doesn't.
### Exported functions: max 2 args, put the rest into an options object.
diff --git a/README.md b/README.md
index 05d0b1c038..8662bb80bc 100644
--- a/README.md
+++ b/README.md
@@ -1,20 +1,31 @@
[data:image/s3,"s3://crabby-images/8c7f6/8c7f6075374bb195cf7f15d72de94cf72914540f" alt="CI"](https://github.com/DeFiCh/jellyfish/actions/workflows/ci.yml)
[data:image/s3,"s3://crabby-images/ec4e4/ec4e4076b925925965229f64573f28c85bd9cf14" alt="codecov"](https://codecov.io/gh/DeFiCh/jellyfish)
[data:image/s3,"s3://crabby-images/13c40/13c400437d31c701d5b24e3c3dc9beec1a3c6b1e" alt="Maintainability"](https://codeclimate.com/github/DeFiCh/jellyfish/maintainability)
-[data:image/s3,"s3://crabby-images/b48ab/b48abdad97835871b70ab3a09ac6b8f0645ce16f" alt="TS-Standard"](https://github.com/standard/ts-standard)
[data:image/s3,"s3://crabby-images/1f6a5/1f6a51ad2e9beef52ce54152c00f395cd839dee4" alt="npm"](https://www.npmjs.com/package/@defichain/jellyfish)
# [@defichain/jellyfish](https://jellyfish.defichain.com)
-DeFiChain SDK. A collection of TypeScript + JavaScript tools and libraries for DeFi Blockchain developers to build
-decentralized finance on Bitcoin.
+> https://jellyfish.defichain.com
-> 🚧 @defichain/jellyfish is considered BETA SOFTWARE with frequent minor breaking releases. Used in production at
-> @defichain. This is a free software, @defichain assumes no responsibility nor liability if there is a bug in the
-> implementation.
+DeFiChain Jellyfish SDK. A collection of TypeScript + JavaScript tools and libraries to build Native DeFi products.
+
+
+Watch this space!
+
+We are consolidating all jellyfish ecosystem projects ocean, whale, playground, and salmon into this repository.
+
+- For better synergy of DeFiChain open source development across all concerns.
+- Consistent versioning for all ecosystem releases with a single source of truth.
+- Documentation for the entirety of the jellyfish ecosystem via `jellyfish.defichain.com`. Incorporating sample and
+ playground.
+- Early regression detection upstream to downstream changes with monolithic repo structure.
+
+
## Installation
+> We are deprecating the CJS/UMD bundle in `@defichain/jellyfish`, please use individual packages (`@defichain/jellyfish-*`) for better control of what you need.
+
### Node
```shell
@@ -39,7 +50,7 @@ client.mining.getMiningInfo().then((info) => {
### ES6 Modules
```js
-import {Client} from '@defichain/jellyfish'
+import { Client } from '@defichain/jellyfish'
const client = new Client('http://localhost:8554')
const info = await client.mining.getMiningInfo()
@@ -48,7 +59,7 @@ const info = await client.mining.getMiningInfo()
### Providers
```js
-import {Client, HttpProvider} from '@defichain/jellyfish'
+import { Client, HttpProvider } from '@defichain/jellyfish'
const options = {} // optional
@@ -77,7 +88,6 @@ version tag.
Package | Description
---------------------------------------------------|-------------
-`@defichain/jellyfish` | Library bundled usage entrypoint with conventional defaults for 4 bundles: umd, esm, cjs and d.ts
`@defichain/jellyfish-address` | Provide address builder, parser, validator utility library for DeFi Blockchain.
`@defichain/jellyfish-api-core` | A protocol agnostic DeFi Blockchain client interfaces, with a "foreign function interface" design.
`@defichain/jellyfish-api-jsonrpc` | Implements the [JSON-RPC 1.0](https://www.jsonrpc.org/specification_v1) specification for api-core.
@@ -91,10 +101,11 @@ Package | Description
`@defichain/jellyfish-transaction-signature` | Stateless utility library to perform transaction signing.
`@defichain/jellyfish-wallet` | Jellyfish wallet is a managed wallet, where account can get discovered from an HD seed.
`@defichain/jellyfish-wallet-classic` | WalletClassic implements a simple, single elliptic pair wallet.
-`@defichain/jellyfish-wallet-encrypted` | Library to encrypt MnemonicHdNode as EncryptedMnemonicHdNode. Able to perform as MnemonicHdNode with passphrase known.
+`@defichain/jellyfish-wallet-encrypted` | Library to encrypt MnemonicHdNode as EncryptedMnemonicHdNode. Able to perform as MnemonicHdNode with passphrase known.
`@defichain/jellyfish-wallet-mnemonic` | MnemonicHdNode implements the WalletHdNode from jellyfish-wallet; a CoinType-agnostic HD Wallet for noncustodial DeFi.
`@defichain/testcontainers` | Provides a lightweight, throw away instances for DeFiD node provisioned automatically in a Docker container.
-~~@defichain/testing~~ | Provides rich test fixture setup functions for effective and effortless testing.
+~~@defichain/jellyfish~~ | (deprecated) ~~Library bundled usage entrypoint with conventional defaults for 4 bundles: umd, esm, cjs and d.ts~~
+~~@defichain/testing~~ | (deprecated) ~~Provides rich test fixture setup functions for effective and effortless testing.~~
## Developing & Contributing
@@ -132,11 +143,30 @@ jest `--maxConcurrency` count. Test are known to be flaky due to the usage of mu
concurrency. Although testcontainers cleans up after itself, there are cases where the tests fail exceptionally you
might need to occasionally: `docker system prune --volumes`.
-Coverage is collected at each pull request to main with `codecov`; more testing 🚀 less 🐛 = 😎
+#### Unit Testing
-```shell
-jest
-```
+Unit testing are created to test each individual units/components of a software. As they are unit tests, they should
+accompany each unitized component or module. They follow the naming semantic of `*.test.ts` and are placed together in
+the same directory structure in `/__tests__` of the code you are testing. Code coverage is collected for this.
+
+#### End-to-end Testing
+
+On top of unit tests, this provides additional testing that tests the entire lifecycle. All dependencies and modules are
+integrated together as expected. They follow the naming semantic of `*.e2e.ts`. Code coverage is collected for this.
+
+For API service endpoints that are meant to be consumed by developer, the testing should also be done in the `*-cient`
+packages. Dogfooding at its finest.
+
+#### Sanity Testing
+
+On top of end-to-end testing, sanity testing is done after the docker image is build. This kind of testing is performed
+to ascertain the possibility of bugs within the workflow that generate the builds. To identify and determine whether a
+build artifact (docker) should be rejected. This is only done on CI and you are not expected to perform them manually.
+
+#### Code coverage
+
+Coverage is collected for all applicable tests at each pull request to main branch with `codecov`. The more testing 🚀
+less 🐛 = 😎
### Publishing
@@ -145,8 +175,11 @@ by [GitHub releases](https://github.com/DeFiCh/jellyfish/releases) with connecte
release `types: [ published, prereleased ]`, GitHub Action will automatically build all packages in this repo and
publish it into npm.
-* release are tagged as `@latest`
-* prerelease are tagged as `@next` (please use this cautiously)
+For packages with accompanying docker images, they are published automatically to GitHub Container Registry
+(ghcr.io/defich). When a new [GitHub releases](https://github.com/DeFiCh/whale/releases) is triggered, GitHub Action
+will automatically build the docker image in this repo and publish it. Two images are created for each release
+targeting `linux/amd64` and `linux/arm64`. The latest tag will always be updated with the last release and semantic
+release is enforced for each release.
### IntelliJ IDEA