From ed5aa06890061e75cb40195cbb3d9b8a3666b772 Mon Sep 17 00:00:00 2001 From: Isha Venikar <145848618+IshaVenikar@users.noreply.github.com> Date: Wed, 10 Jul 2024 18:43:52 +0530 Subject: [PATCH] Add onboarding disabled test (#9) * Add test for onboarding disabled flag * Add onboardingDisabled test * Modify test message * Add test for onboarding disabled to query participants * Modify test messages * Use participants array type * Remove unnecessary describe block * Remove describe statement --- src/onboarding.test.ts | 85 ++++++++++++++++++++++++++++++------------ 1 file changed, 61 insertions(+), 24 deletions(-) diff --git a/src/onboarding.test.ts b/src/onboarding.test.ts index a6c86e6..772f81b 100644 --- a/src/onboarding.test.ts +++ b/src/onboarding.test.ts @@ -4,12 +4,13 @@ import { DirectSecp256k1Wallet } from '@cosmjs/proto-signing'; import { Registry, Account } from './index'; import { getConfig } from './testing/helper'; +import { Participant } from './proto/cerc/onboarding/v1/onboarding'; const { chainId, rpcEndpoint, gqlEndpoint, privateKey, fee } = getConfig(); jest.setTimeout(90 * 1000); -const onboardingTests = () => { +const onboardingEnabledTests = () => { let registry: Registry; let ethWallet: Wallet; @@ -35,35 +36,71 @@ const onboardingTests = () => { }, privateKey, fee); }); - describe('With participants enrolled', () => { - test('Query participants.', async () => { - const account = new Account(Buffer.from(privateKey, 'hex')); - const cosmosAccount = await DirectSecp256k1Wallet.fromKey(account._privateKey, 'laconic'); - const [cosmosWallet] = await cosmosAccount.getAccounts(); + test('Query participants.', async () => { + const account = new Account(Buffer.from(privateKey, 'hex')); + const cosmosAccount = await DirectSecp256k1Wallet.fromKey(account._privateKey, 'laconic'); + const [cosmosWallet] = await cosmosAccount.getAccounts(); - const expectedParticipants = [ - { - cosmos_address: cosmosWallet.address, - ethereum_address: ethWallet.address - } - ]; - const participants = await registry.getParticipants(); - expect(participants).toEqual(expectedParticipants); - }); + const expectedParticipants = [ + { + cosmos_address: cosmosWallet.address, + ethereum_address: ethWallet.address + } + ]; + const participants = await registry.getParticipants(); + expect(participants).toEqual(expectedParticipants); }); }; -if (!process.env.ONBOARDING_ENABLED) { - // Required as jest complains if file has no tests. - test('skipping onboarding tests', () => {}); +const onboardingDisabledTests = () => { + let registry: Registry; + let ethWallet: Wallet; + + beforeAll(async () => { + registry = new Registry(gqlEndpoint, rpcEndpoint, chainId); + }); + + test('Error on onboarding attempt.', async () => { + const errorMsg = 'Validator onboarding is disabled: invalid request'; + const mnemonic = Account.generateMnemonic(); + ethWallet = Wallet.fromMnemonic(mnemonic); + + const ethPayload = { + address: ethWallet.address, + msg: 'Message signed by ethereum private key' + }; + + const message = JSON.stringify(ethPayload); + const ethSignature = await ethWallet.signMessage(message); + + try { + await registry.onboardParticipant({ + ethPayload, + ethSignature + }, privateKey, fee); + } catch (error: any) { + expect(error.toString()).toContain(errorMsg); + } + }); + + test('No participants onboarded.', async () => { + const expectedParticipants: Participant[] = []; + const participants = await registry.getParticipants(); + expect(participants).toMatchObject(expectedParticipants); + }); +}; + +if (process.env.ONBOARDING_ENABLED !== '1') { + describe('Onboarding disabled', onboardingDisabledTests); } else { /** - In laconic2d repo run: - TEST_REGISTRY_EXPIRY=true ./init.sh + Running this test requires participants onboarding enabled. In laconic2d repo run: + + ONBOARDING_ENABLED=true ./init.sh + + Run test: - Run tests: yarn test:onboarding - */ - - describe('Onboarding', onboardingTests); + */ + describe('Onboarding enabled', onboardingEnabledTests); }