Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/halva-suite/halva
Halva is a toolchain for improving the experience of developing Decentralized Applications based on Substrate.
https://github.com/halva-suite/halva
Last synced: 2 months ago
JSON representation
Halva is a toolchain for improving the experience of developing Decentralized Applications based on Substrate.
- Host: GitHub
- URL: https://github.com/halva-suite/halva
- Owner: halva-suite
- License: mit
- Created: 2020-07-01T01:55:39.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2022-12-30T20:46:01.000Z (about 2 years ago)
- Last Synced: 2024-03-24T05:02:24.922Z (10 months ago)
- Language: TypeScript
- Size: 3.66 MB
- Stars: 34
- Watchers: 6
- Forks: 3
- Open Issues: 17
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-substrate - Halva - A toolchain for improving the experience of developing on Substrate. (Tools)
README
[![Contributors][contributors-shield]][contributors-url]
[![Forks][forks-shield]][forks-url]
[![Stargazers][stars-shield]][stars-url]
[![Issues][issues-shield]][issues-url]
[![MIT License][license-shield]][license-url]
Halva Suite
⚠️ (Work In Progress)
Docs |
Report Bug |
Request Feature
🔥 ATTENTION 🔥 The module has been tested on Substrate 2.0.0-rc6 version, work on other versions is not guaranteed
## About The Project
Inspired by [Truffle](https://github.com/trufflesuite/truffle)
Halva is a toolchain for developing Decentralized Applications based on Substrate. It provides a high-level way to configure a development environment, interact with Substrate through external API and writing your test cases. Halva targets testing extrinsics via RPC calls this allows test Substrate (or clients compatible with Substrate RPC) as a black-box.
### Built With
Halva uses [Polkadot.js](https://github.com/polkadot-js)## Getting Started
1. Install `halva-cli`
```sh
npm install -g halva-cli
```2. Configure your network in `halva.js`
```JS
const mnemonic = "bottom drive obey lake curtain smoke basket hold race lonely fit walk";module.exports = {
networks: {
test: {
mnemonic,
ws: "ws://127.0.0.1:9944",
},
},
polkadotjs: {
provider: { },
types: { }
},
}```
## Usage
To run all tests, run:
```sh
halva-cli test -p /path/to/tests/folder -n networkName
```
If you need help, use```sh
halva-cli --help
```To run REPL, simple run:
```sh
halva-cli console
```## Test global scope
You can use global variables provided by halva
```js
describe('Halva test', () => {describe('test global', () => {
it('Get global var', async () => {
console.log(halva.accounts[0].address); // halva_account global var
});
});
});
```### Variable list:
* `halva.accounts` - 10 Keyring pairs for tests
* `halva.polkadot` - ApiPromise object of polkadot
* `alicePair` - KeyringPair object of Alice
* `bobPair` - KeyringPair object of Bob
* `charliePair` - KeyringPair object of Charlie
* `networkName` - Current network name
* `chainMetadata` - Metadata object
* `mochaConfigure` - Current Mocha configuration object## Assertions
`Halva` has its own assertion for working with `extrinsic` and `contracts` (in the future)
### Assertion list:
* `passes(asyncFn, message, signer)` - Error if extrinsic call fails
* `eventEmitted(asyncFn, eventName, section, message, signer)` - Error if the event was not emitted in the transaction
* `eventNotEmitted(asyncFn, eventName, section, message, signer)` - Error if the event was emitted in a transaction
* `fails(asyncFn, errorName, module, signer, message)` - Error if the call ended without errors or with some other error## Roadmap
See the [open issues](https://github.com/halva-suite/halva/issues) for a list of proposed features (and known issues).
## Contributing
Contributions are what make the open source community such an amazing place to be learn, inspire, and create. Any contributions you make are **greatly appreciated**.
1. Fork the Project
2. Create your Feature Branch (`git checkout -b feature/AmazingFeature`)
3. Commit your Changes (`git commit -m 'Add some AmazingFeature'`)
4. Push to the Branch (`git push origin feature/AmazingFeature`)
5. Open a Pull Request## License
Distributed under the MIT License. See `LICENSE` for more information.
## Contact
Project Link: [https://github.com/halva-suite/halva](https://github.com/halva-suite/halva)
[wintex-url]: http://wintex.pro/
[wintex-logo]: https://github.com/halva-suite/assets/blob/master/wintex.png?raw=true
[contributors-shield]: https://img.shields.io/github/contributors/halva-suite/halva.svg?style=flat-square
[contributors-url]: https://github.com/halva-suite/halva/graphs/contributors
[forks-shield]: https://img.shields.io/github/forks/halva-suite/halva.svg?style=flat-square
[forks-url]: https://github.com/halva-suite/halva/network/members
[stars-shield]: https://img.shields.io/github/stars/halva-suite/halva.svg?style=flat-square
[stars-url]: https://github.com/halva-suite/halva/stargazers
[issues-shield]: https://img.shields.io/github/issues/halva-suite/halva.svg?style=flat-square
[issues-url]: https://github.com/halva-suite/halva/issues
[license-shield]: https://img.shields.io/github/license/halva-suite/halva.svg?style=flat-square
[license-url]: https://github.com/halva-suite/halva/blob/master/LICENSE.txt
[linkedin-shield]: https://img.shields.io/badge/-LinkedIn-black.svg?style=flat-square&logo=linkedin&colorB=555
[linkedin-url]: https://linkedin.com/in/othneildrew
[product-screenshot]: images/screenshot.png