js: make packages comply with ci rule
This commit is contained in:
parent
32f0159319
commit
6c6661f621
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "scripts",
|
"name": "@wormhole-foundation/scripts-aptos",
|
||||||
"version": "1.0.0",
|
"version": "0.0.1",
|
||||||
"main": "index.js",
|
"main": "index.js",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "wormhole-client",
|
"name": "@wormhole-foundation/wormhole-client",
|
||||||
"version": "1.0.0",
|
"version": "0.0.1",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@celo-tools/celo-ethers-wrapper": "^0.1.0",
|
"@celo-tools/celo-ethers-wrapper": "^0.1.0",
|
||||||
"@certusone/wormhole-sdk": "^0.7.1",
|
"@certusone/wormhole-sdk": "^0.7.1",
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "test",
|
"name": "@wormhole-foundation/tests-cosmwasm",
|
||||||
"version": "0.1.0",
|
"version": "0.0.1",
|
||||||
"description": "",
|
"description": "",
|
||||||
"type": "module",
|
"type": "module",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "tools",
|
"name": "@wormhole-foundation/tools-cosmwasm",
|
||||||
"version": "1.0.0",
|
"version": "0.0.1",
|
||||||
"description": "",
|
"description": "",
|
||||||
"main": "deploy.js",
|
"main": "deploy.js",
|
||||||
"type": "module",
|
"type": "module",
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "wormhole",
|
"name": "@wormhole-foundation/contracts-ethereum",
|
||||||
"version": "1.0.0",
|
"version": "0.0.1",
|
||||||
"description": "",
|
"description": "",
|
||||||
"main": "networks.js",
|
"main": "networks.js",
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "lp_ui",
|
"name": "@wormhole-foundation/ui-lp",
|
||||||
"version": "0.1.0",
|
"version": "0.0.1",
|
||||||
"private": true,
|
"private": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@certusone/wormhole-sdk": "^0.1.1",
|
"@certusone/wormhole-sdk": "^0.1.1",
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
{
|
{
|
||||||
"private": true,
|
"private": true,
|
||||||
"name": "wormhole-near",
|
"name": "@wormhole-foundation/scripts-near",
|
||||||
"version": "1.0.0",
|
"version": "0.0.1",
|
||||||
"description": "Wormhole near support code",
|
"description": "Wormhole near support code",
|
||||||
"keywords": [
|
"keywords": [
|
||||||
"near-protocol",
|
"near-protocol",
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "cgov_token_gen",
|
"name": "@wormhole-foundation/scripts-governor-token-generation",
|
||||||
"version": "1.0.0",
|
"version": "0.0.1",
|
||||||
"description": "Chain Governor Token Generator",
|
"description": "Chain Governor Token Generator",
|
||||||
"main": "index.ts",
|
"main": "index.ts",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "spy_relay",
|
"name": "@wormhole-foundation/spy-relay",
|
||||||
"version": "1.0.0",
|
"version": "0.0.1",
|
||||||
"description": "Spy listener and relayer",
|
"description": "Spy listener and relayer",
|
||||||
"main": "spy_relay.js",
|
"main": "spy_relay.js",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "test",
|
"name": "@wormhole-foundation/tests-terra",
|
||||||
"version": "0.1.0",
|
"version": "0.0.1",
|
||||||
"description": "",
|
"description": "",
|
||||||
"type": "module",
|
"type": "module",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "tools",
|
"name": "@wormhole-foundation/tools-terra",
|
||||||
"version": "1.0.0",
|
"version": "0.0.1",
|
||||||
"description": "",
|
"description": "",
|
||||||
"main": "deploy.js",
|
"main": "deploy.js",
|
||||||
"type": "module",
|
"type": "module",
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "contract-integration-tests",
|
"name": "@wormhole-foundation/tests-contract-integration",
|
||||||
"version": "1.0.0",
|
"version": "0.0.1",
|
||||||
"description": "",
|
"description": "",
|
||||||
"main": "index.js",
|
"main": "index.js",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
{
|
{
|
||||||
"name": "rollback-test",
|
"name": "@wormhole-foundation/tests-rollback",
|
||||||
"version": "0.0.1",
|
"version": "0.0.1",
|
||||||
"private": true,
|
"private": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
{
|
{
|
||||||
"name": "rollback-test",
|
"name": "@wormhole-foundation/tests-weth-switch",
|
||||||
"version": "0.0.1",
|
"version": "0.0.1",
|
||||||
"private": true,
|
"private": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "tools",
|
"name": "@wormhole-foundation/tools-protobuf",
|
||||||
"version": "1.0.0",
|
"version": "0.0.1",
|
||||||
"description": "tooling for building web code from protobufs",
|
"description": "tooling for building web code from protobufs",
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"ts-proto": "^1.82.3"
|
"ts-proto": "^1.82.3"
|
||||||
|
|
|
@ -1,12 +1,12 @@
|
||||||
{
|
{
|
||||||
"name": "wormhole-chain-tests",
|
"name": "@wormhole-foundation/tests-wormhole-chain",
|
||||||
"version": "0.0.0",
|
"version": "0.0.1",
|
||||||
"lockfileVersion": 2,
|
"lockfileVersion": 2,
|
||||||
"requires": true,
|
"requires": true,
|
||||||
"packages": {
|
"packages": {
|
||||||
"": {
|
"": {
|
||||||
"name": "wormhole-chain-tests",
|
"name": "@wormhole-foundation/tests-wormhole-chain",
|
||||||
"version": "0.0.0",
|
"version": "0.0.1",
|
||||||
"license": "ISC",
|
"license": "ISC",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@certusone/wormhole-sdk": "^0.2.0",
|
"@certusone/wormhole-sdk": "^0.2.0",
|
||||||
|
@ -15,6 +15,7 @@
|
||||||
"@cosmjs/proto-signing": "^0.27.1",
|
"@cosmjs/proto-signing": "^0.27.1",
|
||||||
"@cosmjs/stargate": "^0.27.1",
|
"@cosmjs/stargate": "^0.27.1",
|
||||||
"@cosmjs/tendermint-rpc": "^0.27.1",
|
"@cosmjs/tendermint-rpc": "^0.27.1",
|
||||||
|
"@wormhole-foundation/wormhole-chain-sdk": "file:../../ts-sdk",
|
||||||
"axios": "^0.26.0",
|
"axios": "^0.26.0",
|
||||||
"bech32": "^2.0.0",
|
"bech32": "^2.0.0",
|
||||||
"elliptic": "^6.5.4",
|
"elliptic": "^6.5.4",
|
||||||
|
@ -23,16 +24,15 @@
|
||||||
"ts-jest": "^27.1.3",
|
"ts-jest": "^27.1.3",
|
||||||
"ts-node": "^10.7.0",
|
"ts-node": "^10.7.0",
|
||||||
"tslint": "^6.1.3",
|
"tslint": "^6.1.3",
|
||||||
"typescript": "^4.5.5",
|
"typescript": "^4.5.5"
|
||||||
"wormhole-chain-sdk": "file:../../ts-sdk"
|
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"jest": "^27.5.1"
|
"jest": "^27.5.1"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"../../ts-sdk": {
|
"../../ts-sdk": {
|
||||||
"name": "wormhole-chain-sdk",
|
"name": "@wormhole-foundation/wormhole-chain-sdk",
|
||||||
"version": "0.0.0",
|
"version": "0.0.1",
|
||||||
"license": "ISC",
|
"license": "ISC",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@certusone/wormhole-sdk": "^0.2.0",
|
"@certusone/wormhole-sdk": "^0.2.0",
|
||||||
|
@ -2242,6 +2242,10 @@
|
||||||
"resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-20.2.1.tgz",
|
"resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-20.2.1.tgz",
|
||||||
"integrity": "sha512-7tFImggNeNBVMsn0vLrpn1H1uPrUBdnARPTpZoitY37ZrdJREzf7I16tMrlK3hen349gr1NYh8CmZQa7CTG6Aw=="
|
"integrity": "sha512-7tFImggNeNBVMsn0vLrpn1H1uPrUBdnARPTpZoitY37ZrdJREzf7I16tMrlK3hen349gr1NYh8CmZQa7CTG6Aw=="
|
||||||
},
|
},
|
||||||
|
"node_modules/@wormhole-foundation/wormhole-chain-sdk": {
|
||||||
|
"resolved": "../../ts-sdk",
|
||||||
|
"link": true
|
||||||
|
},
|
||||||
"node_modules/abab": {
|
"node_modules/abab": {
|
||||||
"version": "2.0.5",
|
"version": "2.0.5",
|
||||||
"resolved": "https://registry.npmjs.org/abab/-/abab-2.0.5.tgz",
|
"resolved": "https://registry.npmjs.org/abab/-/abab-2.0.5.tgz",
|
||||||
|
@ -6124,10 +6128,6 @@
|
||||||
"node": ">=0.10.0"
|
"node": ">=0.10.0"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/wormhole-chain-sdk": {
|
|
||||||
"resolved": "../../ts-sdk",
|
|
||||||
"link": true
|
|
||||||
},
|
|
||||||
"node_modules/wrap-ansi": {
|
"node_modules/wrap-ansi": {
|
||||||
"version": "7.0.0",
|
"version": "7.0.0",
|
||||||
"resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz",
|
"resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz",
|
||||||
|
@ -7888,6 +7888,29 @@
|
||||||
"resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-20.2.1.tgz",
|
"resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-20.2.1.tgz",
|
||||||
"integrity": "sha512-7tFImggNeNBVMsn0vLrpn1H1uPrUBdnARPTpZoitY37ZrdJREzf7I16tMrlK3hen349gr1NYh8CmZQa7CTG6Aw=="
|
"integrity": "sha512-7tFImggNeNBVMsn0vLrpn1H1uPrUBdnARPTpZoitY37ZrdJREzf7I16tMrlK3hen349gr1NYh8CmZQa7CTG6Aw=="
|
||||||
},
|
},
|
||||||
|
"@wormhole-foundation/wormhole-chain-sdk": {
|
||||||
|
"version": "file:../../ts-sdk",
|
||||||
|
"requires": {
|
||||||
|
"@certusone/wormhole-sdk": "^0.2.0",
|
||||||
|
"@cosmjs/cosmwasm-stargate": "^0.27.1",
|
||||||
|
"@cosmjs/launchpad": "^0.27.1",
|
||||||
|
"@cosmjs/math": "^0.27.1",
|
||||||
|
"@cosmjs/proto-signing": "^0.27.1",
|
||||||
|
"@cosmjs/stargate": "^0.27.1",
|
||||||
|
"@cosmjs/tendermint-rpc": "^0.27.1",
|
||||||
|
"axios": "^0.26.0",
|
||||||
|
"bech32": "^2.0.0",
|
||||||
|
"elliptic": "^6.5.4",
|
||||||
|
"ethers": "^5.5.4",
|
||||||
|
"jest": "^27.5.1",
|
||||||
|
"keccak256": "^1.0.6",
|
||||||
|
"node-fetch": "^2.6.7",
|
||||||
|
"protobufjs": "^6.11.2",
|
||||||
|
"ts-jest": "^27.1.3",
|
||||||
|
"tslint": "^6.1.3",
|
||||||
|
"typescript": "^4.5.5"
|
||||||
|
}
|
||||||
|
},
|
||||||
"abab": {
|
"abab": {
|
||||||
"version": "2.0.5",
|
"version": "2.0.5",
|
||||||
"resolved": "https://registry.npmjs.org/abab/-/abab-2.0.5.tgz",
|
"resolved": "https://registry.npmjs.org/abab/-/abab-2.0.5.tgz",
|
||||||
|
@ -10800,29 +10823,6 @@
|
||||||
"resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz",
|
"resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz",
|
||||||
"integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ=="
|
"integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ=="
|
||||||
},
|
},
|
||||||
"wormhole-chain-sdk": {
|
|
||||||
"version": "file:../../ts-sdk",
|
|
||||||
"requires": {
|
|
||||||
"@certusone/wormhole-sdk": "^0.2.0",
|
|
||||||
"@cosmjs/cosmwasm-stargate": "^0.27.1",
|
|
||||||
"@cosmjs/launchpad": "^0.27.1",
|
|
||||||
"@cosmjs/math": "^0.27.1",
|
|
||||||
"@cosmjs/proto-signing": "^0.27.1",
|
|
||||||
"@cosmjs/stargate": "^0.27.1",
|
|
||||||
"@cosmjs/tendermint-rpc": "^0.27.1",
|
|
||||||
"axios": "^0.26.0",
|
|
||||||
"bech32": "^2.0.0",
|
|
||||||
"elliptic": "^6.5.4",
|
|
||||||
"ethers": "^5.5.4",
|
|
||||||
"jest": "^27.5.1",
|
|
||||||
"keccak256": "^1.0.6",
|
|
||||||
"node-fetch": "^2.6.7",
|
|
||||||
"protobufjs": "^6.11.2",
|
|
||||||
"ts-jest": "^27.1.3",
|
|
||||||
"tslint": "^6.1.3",
|
|
||||||
"typescript": "^4.5.5"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"wrap-ansi": {
|
"wrap-ansi": {
|
||||||
"version": "7.0.0",
|
"version": "7.0.0",
|
||||||
"resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz",
|
"resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz",
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "wormhole-chain-tests",
|
"name": "@wormhole-foundation/tests-wormhole-chain",
|
||||||
"version": "0.0.0",
|
"version": "0.0.1",
|
||||||
"description": "testing project for wormhole chain",
|
"description": "testing project for wormhole chain",
|
||||||
"main": "index.js",
|
"main": "index.js",
|
||||||
"type": "module",
|
"type": "module",
|
||||||
|
@ -30,6 +30,7 @@
|
||||||
"@cosmjs/proto-signing": "^0.27.1",
|
"@cosmjs/proto-signing": "^0.27.1",
|
||||||
"@cosmjs/stargate": "^0.27.1",
|
"@cosmjs/stargate": "^0.27.1",
|
||||||
"@cosmjs/tendermint-rpc": "^0.27.1",
|
"@cosmjs/tendermint-rpc": "^0.27.1",
|
||||||
|
"@wormhole-foundation/wormhole-chain-sdk": "file:../../ts-sdk",
|
||||||
"axios": "^0.26.0",
|
"axios": "^0.26.0",
|
||||||
"bech32": "^2.0.0",
|
"bech32": "^2.0.0",
|
||||||
"elliptic": "^6.5.4",
|
"elliptic": "^6.5.4",
|
||||||
|
@ -38,8 +39,7 @@
|
||||||
"ts-jest": "^27.1.3",
|
"ts-jest": "^27.1.3",
|
||||||
"ts-node": "^10.7.0",
|
"ts-node": "^10.7.0",
|
||||||
"tslint": "^6.1.3",
|
"tslint": "^6.1.3",
|
||||||
"typescript": "^4.5.5",
|
"typescript": "^4.5.5"
|
||||||
"wormhole-chain-sdk": "file:../../ts-sdk"
|
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"jest": "^27.5.1"
|
"jest": "^27.5.1"
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
import { expect, jest, test } from "@jest/globals";
|
import { expect, jest, test } from "@jest/globals";
|
||||||
import { getAddress, getWallet } from "wormhole-chain-sdk";
|
import { getAddress, getWallet } from "@wormhole-foundation/wormhole-chain-sdk";
|
||||||
import { TEST_WALLET_MNEMONIC_1, TEST_WALLET_MNEMONIC_2 } from "../consts";
|
import { TEST_WALLET_MNEMONIC_1, TEST_WALLET_MNEMONIC_2 } from "../consts";
|
||||||
import { getBalance, sendTokens } from "../utils/walletHelpers";
|
import { getBalance, sendTokens } from "../utils/walletHelpers";
|
||||||
|
|
||||||
|
|
|
@ -9,7 +9,7 @@ import {
|
||||||
toAccAddress,
|
toAccAddress,
|
||||||
toBase64,
|
toBase64,
|
||||||
toValAddress,
|
toValAddress,
|
||||||
} from "wormhole-chain-sdk";
|
} from "@wormhole-foundation/wormhole-chain-sdk";
|
||||||
import {
|
import {
|
||||||
GUARDIAN_VALIDATOR_BASE64_VALADDR,
|
GUARDIAN_VALIDATOR_BASE64_VALADDR,
|
||||||
GUARDIAN_VALIDATOR_VALADDR,
|
GUARDIAN_VALIDATOR_VALADDR,
|
||||||
|
|
|
@ -4,7 +4,7 @@ import {
|
||||||
getWallet,
|
getWallet,
|
||||||
getWormchainSigningClient,
|
getWormchainSigningClient,
|
||||||
toValAddress,
|
toValAddress,
|
||||||
} from "wormhole-chain-sdk";
|
} from "@wormhole-foundation/wormhole-chain-sdk";
|
||||||
import { getZeroFee } from "../bootstrap";
|
import { getZeroFee } from "../bootstrap";
|
||||||
import {
|
import {
|
||||||
DEVNET_GUARDIAN_PRIVATE_KEY,
|
DEVNET_GUARDIAN_PRIVATE_KEY,
|
||||||
|
|
|
@ -3,13 +3,13 @@ import { DeliverTxResponse, StdFee } from "@cosmjs/stargate";
|
||||||
import axios from "axios";
|
import axios from "axios";
|
||||||
import pkg from "protobufjs";
|
import pkg from "protobufjs";
|
||||||
const { Field, Type } = pkg;
|
const { Field, Type } = pkg;
|
||||||
import * as sdk from "wormhole-chain-sdk";
|
import * as sdk from "@wormhole-foundation/wormhole-chain-sdk";
|
||||||
import {
|
import {
|
||||||
fromAccAddress,
|
fromAccAddress,
|
||||||
fromValAddress,
|
fromValAddress,
|
||||||
toBase64,
|
toBase64,
|
||||||
toValAddress,
|
toValAddress,
|
||||||
} from "wormhole-chain-sdk";
|
} from "@wormhole-foundation/wormhole-chain-sdk";
|
||||||
import {
|
import {
|
||||||
DEVNET_GUARDIAN2_PRIVATE_KEY,
|
DEVNET_GUARDIAN2_PRIVATE_KEY,
|
||||||
DEVNET_GUARDIAN2_PUBLIC_KEY,
|
DEVNET_GUARDIAN2_PUBLIC_KEY,
|
||||||
|
@ -26,7 +26,7 @@ import {
|
||||||
} from "./consts.js";
|
} from "./consts.js";
|
||||||
import { signValidatorAddress } from "./utils/walletHelpers.js";
|
import { signValidatorAddress } from "./utils/walletHelpers.js";
|
||||||
|
|
||||||
import fs from 'fs';
|
import fs from "fs";
|
||||||
|
|
||||||
const {
|
const {
|
||||||
getAddress,
|
getAddress,
|
||||||
|
@ -59,37 +59,61 @@ async function fullBootstrapProcess() {
|
||||||
|
|
||||||
//verify that guardian 1 is the only bonded validator
|
//verify that guardian 1 is the only bonded validator
|
||||||
const validators = await queryClient.staking.queryValidators({});
|
const validators = await queryClient.staking.queryValidators({});
|
||||||
expectEqual("Initial bonded validators", validators.data.validators?.map((x) => x.operator_address), [GUARDIAN_VALIDATOR_VALADDR])
|
expectEqual(
|
||||||
|
"Initial bonded validators",
|
||||||
|
validators.data.validators?.map((x) => x.operator_address),
|
||||||
|
[GUARDIAN_VALIDATOR_VALADDR]
|
||||||
|
);
|
||||||
|
|
||||||
const Guardian1ValidatorAddress: string = getValidatorAddressBase64('../../validators/first_validator/config/priv_validator_key.json')
|
const Guardian1ValidatorAddress: string = getValidatorAddressBase64(
|
||||||
const Guardian2ValidatorAddress: string = getValidatorAddressBase64('../../validators/second_validator/config/priv_validator_key.json')
|
"../../validators/first_validator/config/priv_validator_key.json"
|
||||||
|
);
|
||||||
|
const Guardian2ValidatorAddress: string = getValidatorAddressBase64(
|
||||||
|
"../../validators/second_validator/config/priv_validator_key.json"
|
||||||
|
);
|
||||||
|
|
||||||
//verify that guardian 1 is producing blocks
|
//verify that guardian 1 is producing blocks
|
||||||
let latestBlock = await getLatestBlock();
|
let latestBlock = await getLatestBlock();
|
||||||
let validatorSet = latestBlock.block.last_commit.signatures;
|
let validatorSet = latestBlock.block.last_commit.signatures;
|
||||||
|
|
||||||
expectEqual("Signers on first block", validatorSet.map((sig: any) => sig.validator_address), [Guardian1ValidatorAddress])
|
expectEqual(
|
||||||
|
"Signers on first block",
|
||||||
|
validatorSet.map((sig: any) => sig.validator_address),
|
||||||
|
[Guardian1ValidatorAddress]
|
||||||
|
);
|
||||||
|
|
||||||
//verify that guardian 1 is registered to test wallet 1.
|
//verify that guardian 1 is registered to test wallet 1.
|
||||||
let response = await queryClient.core.queryGuardianValidatorAll();
|
let response = await queryClient.core.queryGuardianValidatorAll();
|
||||||
const guardianValidators = response.data.guardianValidator || [];
|
const guardianValidators = response.data.guardianValidator || [];
|
||||||
const tiltnetGuardian = {guardianKey: TILTNET_GUARDIAN_PUBKEY, validatorAddr: toBase64(fromValAddress(GUARDIAN_VALIDATOR_VALADDR))}
|
const tiltnetGuardian = {
|
||||||
expectEqual("Initial guardian validators", guardianValidators.map((x) => ({guardianKey: x.guardianKey, validatorAddr: x.validatorAddr})), [tiltnetGuardian] )
|
guardianKey: TILTNET_GUARDIAN_PUBKEY,
|
||||||
|
validatorAddr: toBase64(fromValAddress(GUARDIAN_VALIDATOR_VALADDR)),
|
||||||
|
};
|
||||||
|
expectEqual(
|
||||||
|
"Initial guardian validators",
|
||||||
|
guardianValidators.map((x) => ({
|
||||||
|
guardianKey: x.guardianKey,
|
||||||
|
validatorAddr: x.validatorAddr,
|
||||||
|
})),
|
||||||
|
[tiltnetGuardian]
|
||||||
|
);
|
||||||
|
|
||||||
//verify that the latest guardian set is 1
|
//verify that the latest guardian set is 1
|
||||||
const response2 = await queryClient.core.queryLatestGuardianSetIndex();
|
const response2 = await queryClient.core.queryLatestGuardianSetIndex();
|
||||||
let index = response2.data.latestGuardianSetIndex;
|
let index = response2.data.latestGuardianSetIndex;
|
||||||
expectEqual("Initial \"latest\" guardian set", index, 0)
|
expectEqual('Initial "latest" guardian set', index, 0);
|
||||||
|
|
||||||
//verify that the consensus guardian set is 1
|
//verify that the consensus guardian set is 1
|
||||||
const response3 = await queryClient.core.queryConsensusGuardianSetIndex();
|
const response3 = await queryClient.core.queryConsensusGuardianSetIndex();
|
||||||
index = response3.data.ConsensusGuardianSetIndex?.index;
|
index = response3.data.ConsensusGuardianSetIndex?.index;
|
||||||
expectEqual("Initial consensus guardian set", index, 0)
|
expectEqual("Initial consensus guardian set", index, 0);
|
||||||
|
|
||||||
//verify that the only guardian public key is guardian public key 1.
|
//verify that the only guardian public key is guardian public key 1.
|
||||||
const response4 = await queryClient.core.queryGuardianSet(0);
|
const response4 = await queryClient.core.queryGuardianSet(0);
|
||||||
const guardianSet = response4.data || null;
|
const guardianSet = response4.data || null;
|
||||||
expectEqual("Guardian set 0", guardianSet.GuardianSet?.keys, [TILTNET_GUARDIAN_PUBKEY])
|
expectEqual("Guardian set 0", guardianSet.GuardianSet?.keys, [
|
||||||
|
TILTNET_GUARDIAN_PUBKEY,
|
||||||
|
]);
|
||||||
|
|
||||||
//process upgrade VAA
|
//process upgrade VAA
|
||||||
const msg = signingClient.core.msgExecuteGovernanceVAA({
|
const msg = signingClient.core.msgExecuteGovernanceVAA({
|
||||||
|
@ -101,7 +125,7 @@ async function fullBootstrapProcess() {
|
||||||
[msg],
|
[msg],
|
||||||
getZeroFee()
|
getZeroFee()
|
||||||
);
|
);
|
||||||
expectTxSuccess("guardian set upgrade VAA", receipt)
|
expectTxSuccess("guardian set upgrade VAA", receipt);
|
||||||
|
|
||||||
const guardianKey2base64 = Buffer.from(
|
const guardianKey2base64 = Buffer.from(
|
||||||
DEVNET_GUARDIAN2_PUBLIC_KEY,
|
DEVNET_GUARDIAN2_PUBLIC_KEY,
|
||||||
|
@ -111,22 +135,28 @@ async function fullBootstrapProcess() {
|
||||||
//verify only guardian 2 is in guardian set 1.
|
//verify only guardian 2 is in guardian set 1.
|
||||||
const response7 = await queryClient.core.queryGuardianSet(1);
|
const response7 = await queryClient.core.queryGuardianSet(1);
|
||||||
const guardianSet7 = response7.data || null;
|
const guardianSet7 = response7.data || null;
|
||||||
expectEqual("Guardian set 1", guardianSet7.GuardianSet?.keys, [guardianKey2base64])
|
expectEqual("Guardian set 1", guardianSet7.GuardianSet?.keys, [
|
||||||
|
guardianKey2base64,
|
||||||
|
]);
|
||||||
|
|
||||||
//verify latest guardian set is 1
|
//verify latest guardian set is 1
|
||||||
const response5 = await queryClient.core.queryLatestGuardianSetIndex();
|
const response5 = await queryClient.core.queryLatestGuardianSetIndex();
|
||||||
let index5 = response5.data.latestGuardianSetIndex || null;
|
let index5 = response5.data.latestGuardianSetIndex || null;
|
||||||
expectEqual("Latest guardian set after upgrade", index5, 1)
|
expectEqual("Latest guardian set after upgrade", index5, 1);
|
||||||
|
|
||||||
//verify consensus guardian set is 0
|
//verify consensus guardian set is 0
|
||||||
const response6 = await queryClient.core.queryConsensusGuardianSetIndex();
|
const response6 = await queryClient.core.queryConsensusGuardianSetIndex();
|
||||||
let index6 = response6.data.ConsensusGuardianSetIndex?.index;
|
let index6 = response6.data.ConsensusGuardianSetIndex?.index;
|
||||||
expectEqual("Consensus guardian set after upgrade", index6, 0)
|
expectEqual("Consensus guardian set after upgrade", index6, 0);
|
||||||
|
|
||||||
//verify guardian 1 is still producing blocks
|
//verify guardian 1 is still producing blocks
|
||||||
let latestBlock2 = await getLatestBlock();
|
let latestBlock2 = await getLatestBlock();
|
||||||
let validatorSet2 = latestBlock2.block.last_commit.signatures;
|
let validatorSet2 = latestBlock2.block.last_commit.signatures;
|
||||||
expectEqual("Validators after upgrade", validatorSet2.map((sig: any) => sig.validator_address), [Guardian1ValidatorAddress])
|
expectEqual(
|
||||||
|
"Validators after upgrade",
|
||||||
|
validatorSet2.map((sig: any) => sig.validator_address),
|
||||||
|
[Guardian1ValidatorAddress]
|
||||||
|
);
|
||||||
|
|
||||||
//TODO attempt to register guardian2 to validator2, exception because validator2 is not bonded.
|
//TODO attempt to register guardian2 to validator2, exception because validator2 is not bonded.
|
||||||
|
|
||||||
|
@ -163,15 +193,26 @@ async function fullBootstrapProcess() {
|
||||||
[bondMsg],
|
[bondMsg],
|
||||||
getZeroFee()
|
getZeroFee()
|
||||||
);
|
);
|
||||||
expectTxSuccess("second validator registration", createValidatorReceipt)
|
expectTxSuccess("second validator registration", createValidatorReceipt);
|
||||||
|
|
||||||
//confirm validator2 is bonded
|
//confirm validator2 is bonded
|
||||||
const validators2 = await queryClient.staking.queryValidators({});
|
const validators2 = await queryClient.staking.queryValidators({});
|
||||||
expectEqual("Second bonded validators", validators2.data.validators?.map((x) => x.operator_address).sort(), [GUARDIAN_VALIDATOR_VALADDR, toValAddress(fromAccAddress(TEST_WALLET_ADDRESS_2))].sort())
|
expectEqual(
|
||||||
|
"Second bonded validators",
|
||||||
|
validators2.data.validators?.map((x) => x.operator_address).sort(),
|
||||||
|
[
|
||||||
|
GUARDIAN_VALIDATOR_VALADDR,
|
||||||
|
toValAddress(fromAccAddress(TEST_WALLET_ADDRESS_2)),
|
||||||
|
].sort()
|
||||||
|
);
|
||||||
|
|
||||||
let latestBlock3 = await getLatestBlock();
|
let latestBlock3 = await getLatestBlock();
|
||||||
let validatorSet3 = latestBlock3.block.last_commit.signatures;
|
let validatorSet3 = latestBlock3.block.last_commit.signatures;
|
||||||
expectEqual("Signers after second validator bonded", validatorSet3.map((sig: any) => sig.validator_address), [Guardian1ValidatorAddress])
|
expectEqual(
|
||||||
|
"Signers after second validator bonded",
|
||||||
|
validatorSet3.map((sig: any) => sig.validator_address),
|
||||||
|
[Guardian1ValidatorAddress]
|
||||||
|
);
|
||||||
|
|
||||||
//attempt to register guardian2 to validator2
|
//attempt to register guardian2 to validator2
|
||||||
//TODO what encoding for the guardian key & how to sign the validator address?
|
//TODO what encoding for the guardian key & how to sign the validator address?
|
||||||
|
@ -188,27 +229,45 @@ async function fullBootstrapProcess() {
|
||||||
[registerMsg],
|
[registerMsg],
|
||||||
getZeroFee()
|
getZeroFee()
|
||||||
);
|
);
|
||||||
expectTxSuccess("second guardian registration", registerMsgReceipe)
|
expectTxSuccess("second guardian registration", registerMsgReceipe);
|
||||||
|
|
||||||
//confirm validator2 is also now registered as a guardian validator
|
//confirm validator2 is also now registered as a guardian validator
|
||||||
let guardianValResponse =
|
let guardianValResponse =
|
||||||
await queryClient.core.queryGuardianValidatorAll();
|
await queryClient.core.queryGuardianValidatorAll();
|
||||||
const guardianValidators2 =
|
const guardianValidators2 =
|
||||||
guardianValResponse.data.guardianValidator || [];
|
guardianValResponse.data.guardianValidator || [];
|
||||||
const secondGuardian = {guardianKey: Buffer.from(DEVNET_GUARDIAN2_PUBLIC_KEY, "hex").toString( "base64"), validatorAddr: toBase64(fromAccAddress(TEST_WALLET_ADDRESS_2))}
|
const secondGuardian = {
|
||||||
expectEqual("Updated guardian validators", guardianValidators2.map((x) => ({guardianKey: x.guardianKey, validatorAddr: x.validatorAddr})).sort(), [secondGuardian, tiltnetGuardian].sort())
|
guardianKey: Buffer.from(DEVNET_GUARDIAN2_PUBLIC_KEY, "hex").toString(
|
||||||
|
"base64"
|
||||||
|
),
|
||||||
|
validatorAddr: toBase64(fromAccAddress(TEST_WALLET_ADDRESS_2)),
|
||||||
|
};
|
||||||
|
expectEqual(
|
||||||
|
"Updated guardian validators",
|
||||||
|
guardianValidators2
|
||||||
|
.map((x) => ({
|
||||||
|
guardianKey: x.guardianKey,
|
||||||
|
validatorAddr: x.validatorAddr,
|
||||||
|
}))
|
||||||
|
.sort(),
|
||||||
|
[secondGuardian, tiltnetGuardian].sort()
|
||||||
|
);
|
||||||
|
|
||||||
//confirm consensus guardian set is now 2
|
//confirm consensus guardian set is now 2
|
||||||
const conResponse = await queryClient.core.queryConsensusGuardianSetIndex();
|
const conResponse = await queryClient.core.queryConsensusGuardianSetIndex();
|
||||||
index = conResponse.data.ConsensusGuardianSetIndex?.index;
|
index = conResponse.data.ConsensusGuardianSetIndex?.index;
|
||||||
expectEqual("Updated consensus guardian set", index, 1)
|
expectEqual("Updated consensus guardian set", index, 1);
|
||||||
|
|
||||||
//confirm blocks are only signed by validator2
|
//confirm blocks are only signed by validator2
|
||||||
console.log("Waiting 4 seconds for latest block...")
|
console.log("Waiting 4 seconds for latest block...");
|
||||||
await new Promise((resolve) => setTimeout(resolve, 4000));
|
await new Promise((resolve) => setTimeout(resolve, 4000));
|
||||||
latestBlock = await getLatestBlock();
|
latestBlock = await getLatestBlock();
|
||||||
validatorSet = latestBlock.block.last_commit.signatures;
|
validatorSet = latestBlock.block.last_commit.signatures;
|
||||||
expectEqual("Signing validators on final block", validatorSet.map((sig: any) => sig.validator_address), [Guardian2ValidatorAddress])
|
expectEqual(
|
||||||
|
"Signing validators on final block",
|
||||||
|
validatorSet.map((sig: any) => sig.validator_address),
|
||||||
|
[Guardian2ValidatorAddress]
|
||||||
|
);
|
||||||
|
|
||||||
console.log("Successfully completed bootstrap process.");
|
console.log("Successfully completed bootstrap process.");
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
|
@ -253,52 +312,77 @@ const wait = async () => {
|
||||||
wait();
|
wait();
|
||||||
|
|
||||||
function getValidatorAddressBase64(file: string): string {
|
function getValidatorAddressBase64(file: string): string {
|
||||||
const validator_key_file = fs.readFileSync(file)
|
const validator_key_file = fs.readFileSync(file);
|
||||||
return Buffer.from(JSON.parse(validator_key_file.toString()).address, "hex").toString("base64")
|
return Buffer.from(
|
||||||
|
JSON.parse(validator_key_file.toString()).address,
|
||||||
|
"hex"
|
||||||
|
).toString("base64");
|
||||||
}
|
}
|
||||||
|
|
||||||
function equal<T>(actual: T, expected: T): boolean {
|
function equal<T>(actual: T, expected: T): boolean {
|
||||||
if (Array.isArray(actual) && Array.isArray(expected)) {
|
if (Array.isArray(actual) && Array.isArray(expected)) {
|
||||||
return actual.length === expected.length && actual.every((val, index) => equal(val, expected[index]));
|
return (
|
||||||
|
actual.length === expected.length &&
|
||||||
|
actual.every((val, index) => equal(val, expected[index]))
|
||||||
|
);
|
||||||
} else if (typeof actual === "object" && typeof expected === "object") {
|
} else if (typeof actual === "object" && typeof expected === "object") {
|
||||||
return JSON.stringify(actual) === JSON.stringify(expected)
|
return JSON.stringify(actual) === JSON.stringify(expected);
|
||||||
} else {
|
} else {
|
||||||
return actual === expected
|
return actual === expected;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function expectEqual<T>(msg: string, actual: T, expected: T): void {
|
function expectEqual<T>(msg: string, actual: T, expected: T): void {
|
||||||
if (!equal(actual, expected)) {
|
if (!equal(actual, expected)) {
|
||||||
eject(msg + ":\nExpected: " + green(stringify(expected)) + ", got: " + red(stringify(actual)))
|
eject(
|
||||||
|
msg +
|
||||||
|
":\nExpected: " +
|
||||||
|
green(stringify(expected)) +
|
||||||
|
", got: " +
|
||||||
|
red(stringify(actual))
|
||||||
|
);
|
||||||
} else {
|
} else {
|
||||||
console.log(msg + ": " + green("PASS"))
|
console.log(msg + ": " + green("PASS"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function expectTxSuccess(msg: string, receipt: DeliverTxResponse): void {
|
function expectTxSuccess(msg: string, receipt: DeliverTxResponse): void {
|
||||||
if (receipt.code !== 0) {
|
if (receipt.code !== 0) {
|
||||||
eject("Transaction " + msg + " failed. Transaction hash: " + red(receipt.transactionHash))
|
eject(
|
||||||
|
"Transaction " +
|
||||||
|
msg +
|
||||||
|
" failed. Transaction hash: " +
|
||||||
|
red(receipt.transactionHash)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
console.log("Transaction " + msg + ": " + green("PASS") + " (" + receipt.transactionHash + ")")
|
console.log(
|
||||||
|
"Transaction " +
|
||||||
|
msg +
|
||||||
|
": " +
|
||||||
|
green("PASS") +
|
||||||
|
" (" +
|
||||||
|
receipt.transactionHash +
|
||||||
|
")"
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
function stringify<T>(x: T): string {
|
function stringify<T>(x: T): string {
|
||||||
if (Array.isArray(x)) {
|
if (Array.isArray(x)) {
|
||||||
return "["+ x.map((x) => stringify(x)) + "]"
|
return "[" + x.map((x) => stringify(x)) + "]";
|
||||||
} else if (typeof x === "object") {
|
} else if (typeof x === "object") {
|
||||||
return JSON.stringify(x)
|
return JSON.stringify(x);
|
||||||
} else {
|
} else {
|
||||||
return "" + x
|
return "" + x;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function red(str: string): string {
|
function red(str: string): string {
|
||||||
return '\x1b[31m' + str + '\x1b[0m'
|
return "\x1b[31m" + str + "\x1b[0m";
|
||||||
}
|
}
|
||||||
|
|
||||||
function green(str: string): string {
|
function green(str: string): string {
|
||||||
return '\x1b[32m' + str + '\x1b[0m'
|
return "\x1b[32m" + str + "\x1b[0m";
|
||||||
}
|
}
|
||||||
|
|
||||||
export default {};
|
export default {};
|
||||||
|
|
|
@ -7,7 +7,7 @@ import {
|
||||||
getWallet,
|
getWallet,
|
||||||
getWormchainSigningClient,
|
getWormchainSigningClient,
|
||||||
getWormholeQueryClient,
|
getWormholeQueryClient,
|
||||||
} from "wormhole-chain-sdk";
|
} from "@wormhole-foundation/wormhole-chain-sdk";
|
||||||
import {
|
import {
|
||||||
WORM_DENOM,
|
WORM_DENOM,
|
||||||
NODE_URL,
|
NODE_URL,
|
||||||
|
@ -75,6 +75,9 @@ export function signValidatorAddress(valAddr: string, privKey: string) {
|
||||||
Buffer.from(fromValAddress(valAddr).bytes)
|
Buffer.from(fromValAddress(valAddr).bytes)
|
||||||
).toString("hex");
|
).toString("hex");
|
||||||
const signature = key.sign(valAddrHash, { canonical: true });
|
const signature = key.sign(valAddrHash, { canonical: true });
|
||||||
const hexString = signature.r.toString("hex").padStart(64, "0") + signature.s.toString("hex").padStart(64, "0") + signature.recoveryParam.toString(16).padStart(2, "0");
|
const hexString =
|
||||||
|
signature.r.toString("hex").padStart(64, "0") +
|
||||||
|
signature.s.toString("hex").padStart(64, "0") +
|
||||||
|
signature.recoveryParam.toString(16).padStart(2, "0");
|
||||||
return Buffer.from(hexString, "hex");
|
return Buffer.from(hexString, "hex");
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "wormhole-chain-sdk",
|
"name": "@wormhole-foundation/wormhole-chain-sdk",
|
||||||
"version": "0.0.0",
|
"version": "0.0.1",
|
||||||
"description": "Typescript SDK for interating with the Wormhole chain",
|
"description": "Typescript SDK for interating with the Wormhole chain",
|
||||||
"main": "lib/index.js",
|
"main": "lib/index.js",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
|
|
Loading…
Reference in New Issue