js: make packages comply with ci rule

This commit is contained in:
Evan Gray 2022-10-20 17:22:29 -04:00 committed by Evan Gray
parent 32f0159319
commit 6c6661f621
23 changed files with 201 additions and 114 deletions

View File

@ -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": {

View File

@ -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",

View File

@ -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": {

View File

@ -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",

View File

@ -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": {

View File

@ -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",

View File

@ -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",

View File

@ -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": {

View File

@ -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": {

View File

@ -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": {

View File

@ -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",

View File

@ -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": {

View File

@ -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": {

View File

@ -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": {

View File

@ -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"

View File

@ -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",

View File

@ -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"

View File

@ -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";

View File

@ -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,

View File

@ -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,

View File

@ -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 {};

View File

@ -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");
} }

View File

@ -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": {