-
Notifications
You must be signed in to change notification settings - Fork 134
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[develop] Add mina as a git submodule for o1js #1318
Merged
Merged
Changes from all commits
Commits
Show all changes
24 commits
Select commit
Hold shift + click to select a range
0a823ec
feat: add ocaml build directory to gitignore
MartinMinkov 0fe99ff
feat: add dune-project file to build bindings from o1js root directory
MartinMinkov 9864ffb
chore(bindings): update subproject commit
MartinMinkov 3fcaa65
fix(package.json): update 'make' script to use local script
MartinMinkov b278770
fix(tsconfig.json): add './src/mina' to exclude list to prevent unnec…
MartinMinkov 750451f
feat(jest.config.js): add 'src/mina/' to modulePathIgnorePatterns to …
MartinMinkov 0c24203
feat(run-jest-tests.sh): add condition to exclude 'src/mina' from jes…
MartinMinkov db7ccba
feat(README-dev): first draft
MartinMinkov 96d0734
docs(README-dev.md): clarify bindings
MartinMinkov 7e9529c
refactor(run-jest-tests.sh): remove condition excluding 'src/mina' fr…
MartinMinkov a7aec5a
refactor: rename npm script 'make' to 'build:bindings' in package.jso…
MartinMinkov 11d8a64
fix(.prettierignore): update path for kimchi js files to reflect new …
MartinMinkov b6ecded
docs(README-dev.md): update build instructions and add details about …
MartinMinkov ccc927b
fix(README-dev.md): specify info for installing deps
MartinMinkov f3c5a81
feat(README-dev.md): spelling mistake
MartinMinkov 74e2d59
Update README-dev.md
MartinMinkov f410f1d
refactor(package.json): streamline script commands for better readabi…
MartinMinkov 9b6561a
feat(mina): add new submodule 'mina' to enhance project functionality
MartinMinkov acb2f8d
refactor(package.json): remove merge conflict markers and redundant s…
MartinMinkov 702042e
Merge branch 'develop' into feat/add-mina-submodule-develop
MartinMinkov 097fb2e
chore(bindings, mina): update submodules to latest commits for up-to-…
MartinMinkov 78452c4
Update package.json
MartinMinkov 0977ace
style(run-jest-tests.sh): add newline at end of file to comply with P…
MartinMinkov 244924a
Revert "Update package.json"
MartinMinkov File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -7,3 +7,4 @@ tests/test-artifacts/ | |
profiling.md | ||
o1js-reference | ||
*.tmp.js | ||
_build/ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,6 @@ | ||
[submodule "src/snarkyjs-bindings"] | ||
path = src/bindings | ||
url = https://github.com/o1-labs/snarkyjs-bindings.git | ||
[submodule "src/mina"] | ||
path = src/mina | ||
url = https://github.com/MinaProtocol/mina.git |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,74 +1,146 @@ | ||
# How to contribute to the o1js codebase | ||
# o1js README-dev | ||
|
||
This README includes information that is helpful for o1js core contributors. | ||
o1js is a TypeScript framework designed for zk-SNARKs and zkApps on the Mina blockchain. | ||
|
||
## Run examples using Node.js | ||
- [zkApps Overview](https://docs.minaprotocol.com/zkapps) | ||
- [Mina README](/src/mina/README.md) | ||
|
||
For more information on our development process and how to contribute, see [CONTRIBUTING.md](https://github.com/o1-labs/o1js/blob/main/CONTRIBUTING.md). This document is meant to guide you through building o1js from source and understanding the development workflow. | ||
|
||
## Prerequisites | ||
|
||
Before starting, ensure you have the following tools installed: | ||
|
||
- [Git](https://git-scm.com/) | ||
- [Node.js and npm](https://nodejs.org/) | ||
- [Dune](https://github.com/ocaml/dune) (only needed when compiling o1js from source) | ||
- [Cargo](https://www.rust-lang.org/learn/get-started) (only needed when compiling o1js from source) | ||
|
||
After cloning the repository, you need to fetch the submodules: | ||
|
||
```sh | ||
git submodule update --init --recursive | ||
``` | ||
|
||
## Building o1js | ||
|
||
For most users, building o1js is as simple as running: | ||
|
||
```sh | ||
npm install | ||
npm run build | ||
|
||
./run src/examples/api_exploration.ts | ||
``` | ||
|
||
## Build and run the web version | ||
This will compile the TypeScript source files, making it ready for use. The compiled OCaml and WebAssembly artifacts are version-controlled to simplify the build process for end-users. These artifacts are stored under `src/bindings/compiled`, and contain the artifacts needed for both node and web builds. These files do not have to be regenerated unless there are changes to the OCaml or Rust source files. | ||
|
||
## Building Bindings | ||
|
||
If you need to regenerate the OCaml and WebAssembly artifacts, you can do so within the o1js repo. The [bindings](https://github.com/o1-labs/o1js-bindings) and [Mina](https://github.com/MinaProtocol/mina) repos are both submodules of o1js, so you can build them from within the o1js repo. | ||
|
||
o1js depends on OCaml code that is transpiled to JavaScript using [Js_of_ocaml](https://github.com/ocsigen/js_of_ocaml), and Rust code that is transpiled to WebAssembly using [wasm-pack](https://github.com/rustwasm/wasm-pack). These artifacts allow o1js to call into [Pickles](https://github.com/o1-labs/snarkyhttps://github.com/MinaProtocol/mina/blob/develop/src/lib/pickles/README.md), [snarky](https://github.com/o1-labs/snarky), and [Kimchi](https://github.com/o1-labs/proof-systems) to write zk-SNARKs and zkApps. | ||
|
||
The compiled artifacts are stored under `src/bindings/compiled`, and are version-controlled to simplify the build process for end-users. | ||
|
||
If you wish to rebuild the OCaml and Rust artifacts, you must be able to build the Mina repo before building the bindings. See the [Mina Dev Readme](https://github.com/MinaProtocol/mina/blob/develop/README-dev.md) for more information. Once you have configured your environment to build Mina, you can build the bindings: | ||
|
||
```sh | ||
npm install | ||
npm run build:web | ||
npm run serve:web | ||
npm run build:update-bindings | ||
``` | ||
|
||
To see the test running in a web browser, go to `http://localhost:8000/`. | ||
This will build the OCaml and Rust artifacts, and copy them to the `src/bindings/compiled` directory. | ||
|
||
### Build Scripts | ||
|
||
The root build script which kicks off the build process is under `src/bindings/scripts/update-snarkyjs-bindings.sh`. This script is responsible for building the Node.js and web artifacts for o1js, and places them under `src/bindings/compiled`, to be used by o1js. | ||
|
||
### OCaml Bindings | ||
|
||
o1js depends on Pickles, snarky, and parts of the Mina transaction logic, all of which are compiled to JavaScript and stored as artifacts to be used by o1js natively. The OCaml bindings are located under `src/bindings`. See the [OCaml Bindings README](https://github.com/o1-labs/o1js-bindings/blob/main/README.md) for more information. | ||
|
||
To compile the OCaml code, a build tool called Dune is used. Dune is a build system for OCaml projects, and is used in addition with Js_of_ocaml to compile the OCaml code to JavaScript. The dune file that is responsible for compiling the OCaml code is located under `src/bindings/ocaml/dune`. There are two build targets: `snarky_js_node` and `snarky_js_web`, which compile the Mina dependencies as well as link the wasm artifacts to build the Node.js and web artifacts, respectively. The output file is `snark_js_node.bc.js`, which is used by o1js. | ||
|
||
### WebAssembly Bindings | ||
|
||
o1js additionally depends on Kimchi, which is compiled to WebAssembly. Kimchi is located in the Mina repo, under `src/mina`. See the [Kimchi README](https://github.com/o1-labs/proof-systems/blob/master/README.md) for more information. | ||
|
||
## Run tests | ||
To compile the wasm code, a combination of Cargo and Dune is used. Both build files are located under `src/mina/src/lib/crypto/kimchi`, where the `wasm` folder contains the Rust code which is compiled to wasm, and the `js` folder which contains a wrapper around the wasm code which allows Js_of_ocaml to compile against the wasm backend. | ||
|
||
- Unit tests | ||
For the wasm build, the output files are: | ||
|
||
```sh | ||
npm run test | ||
npm run test:unit | ||
``` | ||
- `plonk_wasm_bg.wasm`: The compiled WebAssembly binary. | ||
- `plonk_wasm_bg.wasm.d.ts`: TypeScript definition files describing the types of .wasm or .js files. | ||
- `plonk_wasm.js`: JavaScript file that wraps the WASM code for use in Node.js. | ||
- `plonk_wasm.d.ts`: TypeScript definition file for plonk_wasm.js. | ||
|
||
- Integration tests | ||
### Generated Constant Types | ||
|
||
```sh | ||
npm run test:integration | ||
``` | ||
In addition to building the OCaml and Rust code, the build script also generates TypeScript types for constants used in the Mina protocol. These types are generated from the OCaml source files, and are located under `src/bindings/crypto/constants.ts` and `src/bindings/mina-transaction/gen`. When building the bindings, these constants are auto-generated by Dune. If you wish to add a new constant, you can edit the `src/bindings/ocaml/snarky_js_constants` file, and then run `npm run build:bindings` to regenerate the TypeScript files. | ||
|
||
- E2E tests | ||
These types are used by o1js to ensure that the constants used in the protocol are consistent with the OCaml source files. | ||
|
||
```sh | ||
npm install | ||
npm run e2e:install | ||
npm run build:web | ||
## Development | ||
|
||
npm run e2e:prepare-server | ||
npm run test:e2e | ||
npm run e2e:show-report | ||
``` | ||
### Branch Compatibility | ||
|
||
## Branch Compatibility | ||
If you work on o1js, create a feature branch off of one of these base branches. It's encouraged to submit your work-in-progress as a draft PR to raise visibility! When working with submodules and various interconnected parts of the stack, ensure you are on the correct branches that are compatible with each other. | ||
|
||
o1js is mostly used to write Mina Smart Contracts and must be compatible with the latest Berkeley Testnet, or soon Mainnet. | ||
#### How to Use the Branches | ||
|
||
The OCaml code is in the o1js-bindings repository, not directly in o1js. | ||
**Default to `main` as the base branch**. | ||
|
||
To maintain compatibility between the repositories and build o1js from the [Mina repository](https://github.com/MinaProtocol/mina), make changes to its core, such as the OCaml-bindings in the [o1js-bindings repository](https://github.com/o1-labs/o1js-bindings), you must follow a certain branch compatibility pattern: | ||
The other base branches (`berkeley`, `develop`) are only used in specific scenarios where you want to adapt o1js to changes in the sibling repos on those other branches. Even then, consider whether it is feasible to land your changes to `main` and merge to `berkeley` and `develop` afterwards. Only changes in `main` will ever be released, so anything in the other branches has to be backported and reconciled with `main` eventually. | ||
|
||
The following branches are compatible: | ||
| Repository | mina -> o1js -> o1js-bindings | | ||
| ---------- | -------------------------------- | | ||
| Branches | o1js-main -> main -> main | | ||
| | berkeley -> berkeley -> berkeley | | ||
| | develop -> develop -> develop | | ||
|
||
| repository | mina -> o1js -> o1js-bindings | | ||
| ---------- | ------------------------------------- | | ||
| branches | rampup -> main -> main | | ||
| | berkeley -> berkeley -> berkeley | | ||
| | develop -> develop -> develop | | ||
- `o1js-main`: The o1js-main branch in the Mina repository corresponds to the main branch in both o1js and o1js-bindings repositories. This is where stable releases and ramp-up features are maintained. | ||
|
||
## Run the GitHub actions locally | ||
- `berkeley`: The berkeley branch is maintained across all three repositories. This branch is used for features and updates specific to the Berkeley release of the project. | ||
|
||
- `develop`: The develop branch is also maintained across all three repositories. It is used for ongoing development, testing new features, and integration work. | ||
|
||
### Running Tests | ||
|
||
To ensure your changes don't break existing functionality, run the test suite: | ||
|
||
```sh | ||
npm run test | ||
npm run test:unit | ||
``` | ||
|
||
This will run all the unit tests and provide you with a summary of the test results. | ||
|
||
You can additionally run integration tests by running: | ||
|
||
```sh | ||
npm run test:integration | ||
``` | ||
|
||
Finally, we have a set of end-to-end tests that run against the browser. These tests are not run by default, but you can run them by running: | ||
|
||
```sh | ||
npm install | ||
npm run e2e:install | ||
npm run build:web | ||
|
||
npm run e2e:prepare-server | ||
npm run test:e2e | ||
npm run e2e:show-report | ||
``` | ||
|
||
### Run the GitHub actions locally | ||
|
||
<!-- The test example should stay in sync with a real value set in .github/workflows/build-actions.yml --> | ||
|
||
You can execute the CI locally by using [act](https://github.com/nektos/act). First generate a GitHub token and use: | ||
``` | ||
|
||
```sh | ||
act -j Build-And-Test-Server --matrix test_type:"Simple integration tests" -s $GITHUB_TOKEN | ||
``` | ||
to execute the job "Build-And-Test-Server for the test type `Simple integration tests`. | ||
|
||
### Releasing | ||
|
||
To release a new version of o1js, you must first update the version number in `package.json`. Then, you can create a new pull request to merge your changes into the main branch. Once the pull request is merged, a CI job will automatically publish the new version to npm. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
(lang dune 3.3) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Submodule bindings
updated
from 6d5cdb to f5fa4c
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
broken link to Pickles