Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/vaporyjs/vaporyjs-stub-rpc-server
stubbing of a Vapory node
https://github.com/vaporyjs/vaporyjs-stub-rpc-server
rpc vapory
Last synced: 12 days ago
JSON representation
stubbing of a Vapory node
- Host: GitHub
- URL: https://github.com/vaporyjs/vaporyjs-stub-rpc-server
- Owner: vaporyjs
- Created: 2018-03-04T04:43:01.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2023-01-11T05:04:46.000Z (about 2 years ago)
- Last Synced: 2024-11-14T17:33:16.369Z (2 months ago)
- Topics: rpc, vapory
- Language: JavaScript
- Homepage: https://vapory.org
- Size: 56.6 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 5
-
Metadata Files:
- Readme: Readme.md
Awesome Lists containing this project
README
[![npm version](https://badge.fury.io/js/vaporyjs-stub-rpc-server.svg)](https://badge.fury.io/js/vaporyjs-stub-rpc-server)
# Purpose
Allow for easy stubbing of an Vapory node when testing Vapory dApp clients. It allows you to stub out a response to any request with whatever result you like so it is easy to write tests for your dApps without having to run a full Vapory node or do actual mining. It is intended to be run inside your tests and a new server should be created/destroyed with each test case, though you could re-use across test cases if you are okay with using the same responses in each test.
This library is not intended to simulate the inner workings of a real Vapory node, only allow you to define canned responses to requests made of an Vapory node. It supports requests over HTTP, WS or IPC. It dose have some basic simulation build in (can be overriden or removed) for things like `vap_sendTransaction`, `vap_getBlock`, `net_version` (and others) and it has a `.mine()` function to allow you to simulate mining a block that includes pending transactions. PRs welcome for additional baked-in behaviors, though the goal is to keep them relatively simply with a focus on validating request payloads and returning responses that are shaped correctly.
# Usage
```javascript
describe("my vapory integration test", () => {
var server;
beforeEach(function () {
server = require('vaporyjs-stub-rpc-server').createStubServer('HTTP', 'http://localhost:1337');
});
afterEach(function () {
server.destroy();
});it("uses a stub server", () => {
server.addExpectation((requestJso) => requestJso.method === "net_version");
server.addResponder((requestJso) => (requestJso.method === "net_version") ? "apple" : undefined);
myPreferredVaporyJsLibrary.netVersion().then((version) => {
assert.strictEqual(version, "apple");
server.assertExpectations();
});
});
});
```To see the public surface area of this project in TypeScript definition format plus JSDocs (which a TypeScript aware editor will understand) check out [source/index.d.ts](source/index.d.ts). You can also see the tests for more full featured examples (in particular, see `adds sent transaction to block when mined` for an interesting one that does mining).