test: add brdige logic

This commit is contained in:
Dexter 2022-06-28 11:33:51 +01:00
parent 9e7802c9eb
commit 43d754f4e1

View File

@ -1,66 +1,91 @@
import wallet from '../locators/wallet.locators';
import staking from '../locators/staking.locators';
import {StakingBridge} from '@vegaprotocol/smart-contracts';
import { Vesting } from '@vegaprotocol/smart-contracts';
import { ethers, Wallet } from 'ethers';
// ----------------------------------------------------------------------
const vegaWalletName = Cypress.env("VEGA_WALLET_NAME");
const vegaWalletLocation = Cypress.env("VEGA_WALLET_LOCATION");
const vegaWalletPassphrase = Cypress.env("VEGA_WALLET_PASSPHRASE");
const vegaWalletName = Cypress.env('VEGA_WALLET_NAME');
const vegaWalletLocation = Cypress.env('VEGA_WALLET_LOCATION');
const vegaWalletPassphrase = Cypress.env('VEGA_WALLET_PASSPHRASE');
// ----------------------------------------------------------------------
const getAccount = (number = 0) => `m/44'/60'/0'/0/${number}`;
Cypress.Commands.add('vega_wallet_teardown', function () {
const token = new StakingBridge();
const vegaPubKey = '0bd8d51ac46d563af70e4c92fdc53552f800ad527109146e9dff72f6413c10c9';
cy.log(
process.env.NX_ETHEREUM_PROVIDER_URL,
process.env.NX_ETH_WALLET_MNEMONIC
);
const provider = new ethers.providers.JsonRpcProvider({
url: process.env.NX_ETHEREUM_PROVIDER_URL,
});
const privateKey = Wallet.fromMnemonic(
process.env.NX_ETH_WALLET_MNEMONIC,
getAccount(0)
).privateKey;
const signer = new Wallet(privateKey, provider);
const vesting = new Vesting(provider, signer);
const vegaPubKey =
'0bd8d51ac46d563af70e4c92fdc53552f800ad527109146e9dff72f6413c10c9';
const ethPubKey = '0xEe7D375bcB50C26d52E1A4a472D8822A2A22d94F';
token.stakeBalance(ethPubKey, vegaPubKey).then((amount => {
cy.log(amount)
token.removeStake(amount, vegaPubKey)
}))
})
return vesting.stakeBalance(ethPubKey, vegaPubKey).then((amount) => {
cy.log(amount);
vesting.removeStake(amount, vegaPubKey);
});
});
// ----------------------------------------------------------------------
Cypress.Commands.add('vega_wallet_teardown_ui', function () {
cy.log('**Tearing down associated tokens from Vega Wallet**')
cy.log('**Tearing down associated tokens from Vega Wallet**');
let vegaPresentInWallet = false;
cy.get(wallet.vegawallet).within(() => {
cy.get(wallet.vegawallet)
.within(() => {
cy.contains('Associated', { timeout: 20000 })
.parent()
.siblings()
.within(($associated) => {
if ($associated.text() != '0.000000000000000000')
vegaPresentInWallet = true;
});
})
}).then(() => {
.then(() => {
if (vegaPresentInWallet == true) {
cy.root().ethereum_wallet_disassociateAllTokens()
cy.vega_wallet_check_associatedValue_is('0.0')
cy.root().ethereum_wallet_disassociateAllTokens();
cy.vega_wallet_check_associatedValue_is('0.0');
} else {
cy.log('**No need to teardown vega wallet - wallet empty**');
}
else {cy.log('**No need to teardown vega wallet - wallet empty**')}
})
cy.log('**Tearing down associated tokens from Vega Wallet = COMPLETE**')
})
});
cy.log('**Tearing down associated tokens from Vega Wallet = COMPLETE**');
});
// ----------------------------------------------------------------------
Cypress.Commands.add('vega_wallet_create', function () {
cy.log('**Initializing Vega Wallet** ' + vegaWalletName)
cy.exec(`vegawallet init -f --home ${vegaWalletLocation}`)
cy.exec(`echo ${vegaWalletPassphrase} > ./src/fixtures/vegaWalletPassphrase.txt`)
cy.exec(`vegawallet create -w ${vegaWalletName} -p ./src/fixtures//vegaWalletPassphrase.txt --home ${vegaWalletLocation}`,
{ failOnNonZeroExit: false }).then(result => cy.log(result.stderr))
cy.exec(`vegawallet service run --network DV --automatic-consent --home ${vegaWalletLocation}`)
cy.log('**Initializing Vega Wallet** ' + vegaWalletName);
cy.exec(`vegawallet init -f --home ${vegaWalletLocation}`);
cy.exec(
`echo ${vegaWalletPassphrase} > ./src/fixtures/vegaWalletPassphrase.txt`
);
cy.exec(
`vegawallet create -w ${vegaWalletName} -p ./src/fixtures//vegaWalletPassphrase.txt --home ${vegaWalletLocation}`,
{ failOnNonZeroExit: false }
).then((result) => cy.log(result.stderr));
cy.exec(
`vegawallet service run --network DV --automatic-consent --home ${vegaWalletLocation}`
);
cy.log('**Initializing Vega Wallet = COMPLETE**')
cy.log('**Initializing Vega Wallet = COMPLETE**');
});
// ----------------------------------------------------------------------
Cypress.Commands.add('vega_wallet_connect', function () {
cy.log('**Connecting Vega Wallet**')
cy.intercept('POST', 'http://localhost:3028/query').as('vegaWalletGrab')
cy.log('**Connecting Vega Wallet**');
cy.intercept('POST', 'http://localhost:3028/query').as('vegaWalletGrab');
cy.get(wallet.vegawallet).within(() => {
cy.get('button')
.contains('Connect Vega wallet to use associated $VEGA')
@ -80,50 +105,59 @@ Cypress.Commands.add('vega_wallet_connect', function () {
cy.contains(`${vegaWalletName} key`, { timeout: 20000 }).should('be.visible');
// We have to wait for two fetchs of wallet balances to finish
// Since oddly the first fetch returns a balance of 0.0 (even if tokens present)
cy.wait('@vegaWalletGrab', {timeout : 10000}).wait('@vegaWalletGrab', {timeout : 10000});
cy.wait('@vegaWalletGrab', { timeout: 10000 }).wait('@vegaWalletGrab', {
timeout: 10000,
});
// Then we turn off our intercept - so that we can use it again in the future
cy.intercept('POST', 'http://localhost:3028/query', (req) => req.continue());
cy.log('**Connecting Vega Wallet = COMPLETE**')
cy.log('**Connecting Vega Wallet = COMPLETE**');
});
// ----------------------------------------------------------------------
Cypress.Commands.add('vega_wallet_check_validator_stakeNextEpochValue_is',
Cypress.Commands.add(
'vega_wallet_check_validator_stakeNextEpochValue_is',
function (validatorName, expectedVal) {
cy.log(`**Checking Stake Next Epoch Value for ${validatorName} is ${expectedVal}**`)
cy.log(
`**Checking Stake Next Epoch Value for ${validatorName} is ${expectedVal}**`
);
cy.get(wallet.vegawallet).within(() => {
cy.contains(`${validatorName} (Next epoch)`)
.siblings()
.contains(expectedVal, { timeout: 10000 });
});
cy.log('**Checking Stake Next Epoch Value = Complete**')
cy.log('**Checking Stake Next Epoch Value = Complete**');
}
);
// ----------------------------------------------------------------------
Cypress.Commands.add('vega_wallet_check_unstakedValue_is', function (expectedVal) {
cy.log(`**Checking Vega Wallet Unstaked Value is ${expectedVal}**`)
Cypress.Commands.add(
'vega_wallet_check_unstakedValue_is',
function (expectedVal) {
cy.log(`**Checking Vega Wallet Unstaked Value is ${expectedVal}**`);
cy.get(wallet.vegawallet).within(() => {
cy.contains('Unstaked', { timeout: 20000 })
.siblings()
.contains(expectedVal, { timeout: 10000 });
});
cy.log('**Checking Vega Wallet Unstaked Value = Complete**')
cy.log('**Checking Vega Wallet Unstaked Value = Complete**');
}
);
// ----------------------------------------------------------------------
Cypress.Commands.add('vega_wallet_check_associatedValue_is', function (expectedVal) {
cy.log(`**Checking Vega Wallet Asscoiated Value is ${expectedVal}**`)
Cypress.Commands.add(
'vega_wallet_check_associatedValue_is',
function (expectedVal) {
cy.log(`**Checking Vega Wallet Asscoiated Value is ${expectedVal}**`);
cy.get(wallet.vegawallet).within(() => {
cy.contains('Associated', { timeout: 20000 })
.parent()
.siblings()
.contains(expectedVal, { timeout: 40000 });
});
cy.log('**Checking Vega Wallet Asscoiated Value = COMPLETE**')
cy.log('**Checking Vega Wallet Asscoiated Value = COMPLETE**');
}
);
@ -134,52 +168,70 @@ Cypress.Commands.add('ethereum_wallet_connect', function () {
cy.get(wallet.ethWalletConnectToEth).within(() => {
cy.contains('Connect Ethereum wallet to associate $VEGA')
.should('be.visible')
.click()});
.click();
});
cy.get(wallet.ethWalletConnect).click();
cy.get(wallet.ethWalletConnect, {timeout : 60000}).should('not.exist')
cy.get(wallet.ethWalletConnect, { timeout: 60000 }).should('not.exist');
cy.contains('Ethereum wallet connected').should('be.visible');
cy.log('**Connecting Eth Wallet = COMPLETE**')
cy.log('**Connecting Eth Wallet = COMPLETE**');
});
// ----------------------------------------------------------------------
Cypress.Commands.add('ethereum_wallet_associateTokens', function (amount) {
cy.log(`**Associating ${amount} tokens from Eth Wallet**`)
cy.log(`**Associating ${amount} tokens from Eth Wallet**`);
cy.get(wallet.ethWallet).within(() =>
cy.get(wallet.ethWalletAssociate).click());
cy.get(wallet.ethWalletAssociate).click()
);
cy.get(staking.stakeAssociateWalletRadio, { timeout: 30000 }).click();
cy.get(staking.tokenAmountInput, { timeout: 10000 }).type(amount);
cy.get(staking.tokenInputSubmit, { timeout: 40000 }).should('be.enabled').click();
cy.contains('can now participate in governance and nominate a validator', { timeout: 60000 });
cy.log('**Associating tokens from Eth Wallet = COMPLETE**')
})
cy.get(staking.tokenInputSubmit, { timeout: 40000 })
.should('be.enabled')
.click();
cy.contains('can now participate in governance and nominate a validator', {
timeout: 60000,
});
cy.log('**Associating tokens from Eth Wallet = COMPLETE**');
});
// ----------------------------------------------------------------------
Cypress.Commands.add('ethereum_wallet_approveAndAssociateTokens', function (amount) {
cy.log(`**Associating ${amount} tokens from Eth Wallet**`)
Cypress.Commands.add(
'ethereum_wallet_approveAndAssociateTokens',
function (amount) {
cy.log(`**Associating ${amount} tokens from Eth Wallet**`);
cy.get(wallet.ethWallet).within(() =>
cy.get(wallet.ethWalletAssociate).click());
cy.get(wallet.ethWalletAssociate).click()
);
cy.get(staking.stakeAssociateWalletRadio, { timeout: 30000 }).click();
cy.get(staking.tokenAmountInput, { timeout: 10000 }).type(amount);
cy.get(staking.tokenInputApprove, { timeout: 40000 }).should('be.enabled').click();
cy.get(staking.tokenInputSubmit, { timeout: 40000 }).should('be.enabled').click();
cy.contains('can now participate in governance and nominate a validator', { timeout: 60000 });
cy.log('**Associating tokens from Eth Wallet = COMPLETE**')
})
cy.get(staking.tokenInputApprove, { timeout: 40000 })
.should('be.enabled')
.click();
cy.get(staking.tokenInputSubmit, { timeout: 40000 })
.should('be.enabled')
.click();
cy.contains('can now participate in governance and nominate a validator', {
timeout: 60000,
});
cy.log('**Associating tokens from Eth Wallet = COMPLETE**');
}
);
// ----------------------------------------------------------------------
Cypress.Commands.add('ethereum_wallet_disassociateAllTokens', function () {
cy.log('**Disassociating tokens from Eth Wallet**')
cy.log('**Disassociating tokens from Eth Wallet**');
cy.get(wallet.ethWallet).within(() =>
cy.get(wallet.ethWalletDisassociate).click());
cy.get(wallet.ethWalletDisassociate).click()
);
cy.get(staking.stakeAssociateWalletRadio, { timeout: 20000 }).click();
cy.get(staking.stakeMaximumTokens, { timeout: 60000 }).click();
cy.get(staking.tokenInputSubmit, { timeout: 10000 }).click();
cy.contains('$VEGA tokens have been returned to Ethereum wallet', { timeout: 60000 })
cy.log('**Disassociating tokens from Eth Wallet = Complete**')
})
cy.contains('$VEGA tokens have been returned to Ethereum wallet', {
timeout: 60000,
});
cy.log('**Disassociating tokens from Eth Wallet = Complete**');
});
// ----------------------------------------------------------------------