test(trading): #3505 add test coverage to 6002-MDET-market-details (#4060)

This commit is contained in:
Radosław Szpiech 2023-06-08 15:47:23 +02:00 committed by GitHub
parent d6f39049bd
commit 7b8f654906
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 144 additions and 74 deletions

View File

@ -1,15 +1,18 @@
import { MarketTradingModeMapping } from '@vegaprotocol/types'; import { MarketTradingModeMapping } from '@vegaprotocol/types';
import { MarketState } from '@vegaprotocol/types'; import { MarketState } from '@vegaprotocol/types';
const marketInfoBtn = 'Info';
const row = 'key-value-table-row';
const marketTitle = 'accordion-title';
const externalLink = 'external-link';
const accordionContent = 'accordion-content'; const accordionContent = 'accordion-content';
const blockExplorerLink = 'block-explorer-link';
const dialogClose = 'dialog-close';
const dialogContent = 'dialog-content';
const externalLink = 'external-link';
const githubLink = 'github-link';
const liquidityLink = 'view-liquidity-link';
const marketInfoBtn = 'Info';
const marketTitle = 'accordion-title';
const providerName = 'provider-name'; const providerName = 'provider-name';
const oracleBannerStatus = 'oracle-banner-status'; const row = 'key-value-table-row';
const oracleBannerDialogTrigger = 'oracle-banner-dialog-trigger'; const verifiedProofs = 'verified-proofs';
const oracleFullProfile = 'oracle-full-profile';
describe('market info is displayed', { tags: '@smoke' }, () => { describe('market info is displayed', { tags: '@smoke' }, () => {
beforeEach(() => { beforeEach(() => {
@ -17,12 +20,7 @@ describe('market info is displayed', { tags: '@smoke' }, () => {
}); });
before(() => { before(() => {
cy.mockTradingPage( cy.mockTradingPage(MarketState.STATE_ACTIVE);
MarketState.STATE_ACTIVE,
undefined,
undefined,
'COMPROMISED'
);
cy.mockSubscription(); cy.mockSubscription();
cy.visit('/#/markets/market-0'); cy.visit('/#/markets/market-0');
cy.wait('@Markets'); cy.wait('@Markets');
@ -30,16 +28,8 @@ describe('market info is displayed', { tags: '@smoke' }, () => {
cy.wait('@MarketInfo'); cy.wait('@MarketInfo');
}); });
it('show oracle banner', () => {
cy.getByTestId(marketTitle).contains('Oracle').click();
cy.getByTestId(oracleBannerStatus).should('contain.text', 'COMPROMISED');
cy.getByTestId(oracleBannerDialogTrigger)
.should('contain.text', 'Show more')
.click();
cy.getByTestId(oracleFullProfile).should('exist');
});
it('current fees displayed', () => { it('current fees displayed', () => {
// 6002-MDET-101
cy.getByTestId(marketTitle).contains('Current fees').click(); cy.getByTestId(marketTitle).contains('Current fees').click();
validateMarketDataRow(0, 'Maker Fee', '0.02%'); validateMarketDataRow(0, 'Maker Fee', '0.02%');
validateMarketDataRow(1, 'Infrastructure Fee', '0.05%'); validateMarketDataRow(1, 'Infrastructure Fee', '0.05%');
@ -48,6 +38,7 @@ describe('market info is displayed', { tags: '@smoke' }, () => {
}); });
it('market price', () => { it('market price', () => {
// 6002-MDET-102
cy.getByTestId(marketTitle).contains('Market price').click(); cy.getByTestId(marketTitle).contains('Market price').click();
validateMarketDataRow(0, 'Mark Price', '46,126.90058'); validateMarketDataRow(0, 'Mark Price', '46,126.90058');
validateMarketDataRow(1, 'Best Bid Price', '44,126.90058 '); validateMarketDataRow(1, 'Best Bid Price', '44,126.90058 ');
@ -56,6 +47,7 @@ describe('market info is displayed', { tags: '@smoke' }, () => {
}); });
it('market volume displayed', () => { it('market volume displayed', () => {
// 6002-MDET-103
cy.getByTestId(marketTitle).contains('Market volume').click(); cy.getByTestId(marketTitle).contains('Market volume').click();
validateMarketDataRow(1, 'Open Interest', '-'); validateMarketDataRow(1, 'Open Interest', '-');
validateMarketDataRow(2, 'Best Bid Volume', '1'); validateMarketDataRow(2, 'Best Bid Volume', '1');
@ -65,11 +57,13 @@ describe('market info is displayed', { tags: '@smoke' }, () => {
}); });
it('insurance pool displayed', () => { it('insurance pool displayed', () => {
// 6002-MDET-104
cy.getByTestId(marketTitle).contains('Insurance pool').click(); cy.getByTestId(marketTitle).contains('Insurance pool').click();
validateMarketDataRow(0, 'Balance', '0'); validateMarketDataRow(0, 'Balance', '0');
}); });
it('key details displayed', () => { it('key details displayed', () => {
// 6002-MDET-201
cy.getByTestId(marketTitle).contains('Key details').click(); cy.getByTestId(marketTitle).contains('Key details').click();
validateMarketDataRow(0, 'Name', 'BTCUSD Monthly (30 Jun 2022)'); validateMarketDataRow(0, 'Name', 'BTCUSD Monthly (30 Jun 2022)');
@ -85,6 +79,7 @@ describe('market info is displayed', { tags: '@smoke' }, () => {
}); });
it('instrument displayed', () => { it('instrument displayed', () => {
// 6002-MDET-202
cy.getByTestId(marketTitle).contains('Instrument').click(); cy.getByTestId(marketTitle).contains('Instrument').click();
validateMarketDataRow(0, 'Market Name', 'BTCUSD Monthly (30 Jun 2022)'); validateMarketDataRow(0, 'Market Name', 'BTCUSD Monthly (30 Jun 2022)');
@ -93,7 +88,30 @@ describe('market info is displayed', { tags: '@smoke' }, () => {
validateMarketDataRow(3, 'Quote Name', 'BTC'); validateMarketDataRow(3, 'Quote Name', 'BTC');
}); });
it('oracle displayed', () => {
// 6002-MDET-203
cy.getByTestId(marketTitle).contains('Oracle').click();
cy.getByTestId(accordionContent)
.getByTestId(providerName)
.and('contain', 'Another oracle');
cy.getByTestId(providerName).should('be.visible').click();
cy.getByTestId(dialogContent)
.eq(1)
.within(() => {
cy.getByTestId(blockExplorerLink).contains('Block explorer');
cy.getByTestId(githubLink).contains('Oracle repository');
});
cy.getByTestId(dialogClose).click();
cy.getByTestId(accordionContent)
.getByTestId(verifiedProofs)
.and('contain', '1');
});
it('settlement asset displayed', () => { it('settlement asset displayed', () => {
// 6002-MDET-206
cy.getByTestId(marketTitle).contains('Settlement asset').click(); cy.getByTestId(marketTitle).contains('Settlement asset').click();
cy.window().then((win) => { cy.window().then((win) => {
cy.stub(win, 'prompt').returns('DISABLED WINDOW PROMPT'); cy.stub(win, 'prompt').returns('DISABLED WINDOW PROMPT');
@ -112,9 +130,12 @@ describe('market info is displayed', { tags: '@smoke' }, () => {
); );
validateMarketDataRow(8, 'Withdrawal threshold', '0.0005'); validateMarketDataRow(8, 'Withdrawal threshold', '0.0005');
validateMarketDataRow(9, 'Lifetime limit', '1,230'); validateMarketDataRow(9, 'Lifetime limit', '1,230');
validateMarketDataRow(10, 'Infrastructure fee account balance', '0.00001');
validateMarketDataRow(11, 'Global reward pool account balance', '0.00002');
}); });
it('metadata displayed', () => { it('metadata displayed', () => {
// 6002-MDET-207
cy.getByTestId(marketTitle).contains('Metadata').click(); cy.getByTestId(marketTitle).contains('Metadata').click();
validateMarketDataRow(0, 'Formerly', '076BB86A5AA41E3E'); validateMarketDataRow(0, 'Formerly', '076BB86A5AA41E3E');
@ -125,18 +146,21 @@ describe('market info is displayed', { tags: '@smoke' }, () => {
}); });
it('risk model displayed', () => { it('risk model displayed', () => {
// 6002-MDET-208
cy.getByTestId(marketTitle).contains('Risk model').click(); cy.getByTestId(marketTitle).contains('Risk model').click();
validateMarketDataRow(0, 'Tau', '0.0001140771161'); validateMarketDataRow(0, 'Tau', '0.0001140771161');
validateMarketDataRow(1, 'Risk Aversion Parameter', '0.01'); validateMarketDataRow(1, 'Risk Aversion Parameter', '0.01');
}); });
it('risk parameters displayed', () => { it('risk parameters displayed', () => {
// 6002-MDET-209
cy.getByTestId(marketTitle).contains('Risk parameters').click(); cy.getByTestId(marketTitle).contains('Risk parameters').click();
validateMarketDataRow(0, 'R', '0.016'); validateMarketDataRow(0, 'R', '0.016');
validateMarketDataRow(1, 'Sigma', '0.3'); validateMarketDataRow(1, 'Sigma', '0.3');
}); });
it('risk factors displayed', () => { it('risk factors displayed', () => {
// 6002-MDET-210
cy.getByTestId(marketTitle).contains('Risk factors').click(); cy.getByTestId(marketTitle).contains('Risk factors').click();
validateMarketDataRow(0, 'Short', '0.008571790367285281'); validateMarketDataRow(0, 'Short', '0.008571790367285281');
@ -144,6 +168,7 @@ describe('market info is displayed', { tags: '@smoke' }, () => {
}); });
it('price monitoring bounds displayed', () => { it('price monitoring bounds displayed', () => {
// 6002-MDET-211
cy.getByTestId(marketTitle).contains('Price monitoring bounds 1').click(); cy.getByTestId(marketTitle).contains('Price monitoring bounds 1').click();
cy.get('p.col-span-1').contains('99.99999% probability price bounds'); cy.get('p.col-span-1').contains('99.99999% probability price bounds');
cy.get('p.col-span-1').contains('Within 43,200 seconds'); cy.get('p.col-span-1').contains('Within 43,200 seconds');
@ -152,6 +177,7 @@ describe('market info is displayed', { tags: '@smoke' }, () => {
}); });
it('liquidity monitoring parameters displayed', () => { it('liquidity monitoring parameters displayed', () => {
// 6002-MDET-212
cy.getByTestId(marketTitle) cy.getByTestId(marketTitle)
.contains('Liquidity monitoring parameters') .contains('Liquidity monitoring parameters')
.click(); .click();
@ -162,6 +188,7 @@ describe('market info is displayed', { tags: '@smoke' }, () => {
}); });
it('liquidity displayed', () => { it('liquidity displayed', () => {
// 6002-MDET-213
cy.getByTestId(marketTitle) cy.getByTestId(marketTitle)
.contains(/Liquidity(?! m)/) .contains(/Liquidity(?! m)/)
.click(); .click();
@ -169,14 +196,14 @@ describe('market info is displayed', { tags: '@smoke' }, () => {
validateMarketDataRow(0, 'Target Stake', '10.00 tBTC'); validateMarketDataRow(0, 'Target Stake', '10.00 tBTC');
validateMarketDataRow(1, 'Supplied Stake', '0.01 tBTC'); validateMarketDataRow(1, 'Supplied Stake', '0.01 tBTC');
validateMarketDataRow(2, 'Market Value Proxy', '20.00 tBTC'); validateMarketDataRow(2, 'Market Value Proxy', '20.00 tBTC');
cy.getByTestId(liquidityLink).should(
cy.getByTestId('view-liquidity-link').should(
'have.text', 'have.text',
'View liquidity provision table' 'View liquidity provision table'
); );
}); });
it('liquidity price range displayed', () => { it('liquidity price range displayed', () => {
// 6002-MDET-214
cy.getByTestId(marketTitle).contains('Liquidity price range').click(); cy.getByTestId(marketTitle).contains('Liquidity price range').click();
validateMarketDataRow(0, 'Liquidity Price Range', '2.00% of mid price'); validateMarketDataRow(0, 'Liquidity Price Range', '2.00% of mid price');
@ -184,29 +211,8 @@ describe('market info is displayed', { tags: '@smoke' }, () => {
validateMarketDataRow(2, 'Highest Price', '47,049.438 BTC'); validateMarketDataRow(2, 'Highest Price', '47,049.438 BTC');
}); });
it('oracle displayed', () => {
cy.getByTestId(marketTitle).contains('Oracle').click();
cy.getByTestId(accordionContent)
.getByTestId(providerName)
.and('contain', 'Another oracle');
cy.getByTestId(providerName).should('be.visible').click();
cy.getByTestId('dialog-content')
.eq(1)
.within(() => {
cy.getByTestId('block-explorer-link').contains('Block explorer');
cy.getByTestId('github-link').contains('Oracle repository');
});
cy.getByTestId('dialog-close').click();
cy.getByTestId(accordionContent)
.getByTestId('verified-proofs')
.and('contain', '1');
});
it('proposal displayed', () => { it('proposal displayed', () => {
// 6002-MDET-301
cy.getByTestId(marketTitle).contains('Proposal').click(); cy.getByTestId(marketTitle).contains('Proposal').click();
cy.getByTestId(accordionContent) cy.getByTestId(accordionContent)

View File

@ -1,17 +1,25 @@
import * as Schema from '@vegaprotocol/types'; import * as Schema from '@vegaprotocol/types';
const marketSummaryBlock = 'header-summary'; const expirtyTooltip = 'expiry-tooltip';
const marketExpiry = 'market-expiry'; const externalLink = 'external-link';
const marketPrice = 'market-price';
const marketChange = 'market-change';
const marketVolume = 'market-volume';
const marketMode = 'market-trading-mode';
const marketState = 'market-state';
const marketSettlement = 'market-settlement-asset';
const percentageValue = 'price-change-percentage';
const priceChangeValue = 'price-change';
const itemHeader = 'item-header'; const itemHeader = 'item-header';
const itemValue = 'item-value'; const itemValue = 'item-value';
const link = 'link';
const liquidityLink = 'view-liquidity-link';
const liquiditySupplied = 'liquidity-supplied';
const liquiditySuppliedTooltip = 'liquidity-supplied-tooltip';
const marketChange = 'market-change';
const marketExpiry = 'market-expiry';
const marketMode = 'market-trading-mode';
const marketName = 'header-title';
const marketPrice = 'market-price';
const marketSettlement = 'market-settlement-asset';
const marketState = 'market-state';
const marketSummaryBlock = 'header-summary';
const marketVolume = 'market-volume';
const percentageValue = 'price-change-percentage';
const priceChangeValue = 'price-change';
const tradingModeTooltip = 'trading-mode-tooltip';
describe('Market trading page', () => { describe('Market trading page', () => {
before(() => { before(() => {
@ -31,10 +39,12 @@ describe('Market trading page', () => {
// 7002-SORD-001 // 7002-SORD-001
// 7002-SORD-002 // 7002-SORD-002
it('must display market name', () => { it('must display market name', () => {
cy.getByTestId('header-title').should('not.be.empty'); // 6002-MDET-001
cy.getByTestId(marketName).should('not.be.empty');
}); });
it('must see market expiry', () => { it('must see market expiry', () => {
// 6002-MDET-002
cy.getByTestId(marketSummaryBlock).within(() => { cy.getByTestId(marketSummaryBlock).within(() => {
cy.getByTestId(marketExpiry).within(() => { cy.getByTestId(marketExpiry).within(() => {
cy.getByTestId(itemHeader).should('have.text', 'Expiry'); cy.getByTestId(itemHeader).should('have.text', 'Expiry');
@ -44,6 +54,7 @@ describe('Market trading page', () => {
}); });
it('must see market price', () => { it('must see market price', () => {
// 6002-MDET-003
cy.getByTestId(marketSummaryBlock).within(() => { cy.getByTestId(marketSummaryBlock).within(() => {
cy.getByTestId(marketPrice).within(() => { cy.getByTestId(marketPrice).within(() => {
cy.getByTestId(itemHeader).should('have.text', 'Price'); cy.getByTestId(itemHeader).should('have.text', 'Price');
@ -53,6 +64,7 @@ describe('Market trading page', () => {
}); });
it('must see market change', () => { it('must see market change', () => {
// 6002-MDET-004
cy.getByTestId(marketSummaryBlock).within(() => { cy.getByTestId(marketSummaryBlock).within(() => {
cy.getByTestId(marketChange).within(() => { cy.getByTestId(marketChange).within(() => {
cy.getByTestId(itemHeader).should('have.text', 'Change (24h)'); cy.getByTestId(itemHeader).should('have.text', 'Change (24h)');
@ -63,6 +75,7 @@ describe('Market trading page', () => {
}); });
it('must see market volume', () => { it('must see market volume', () => {
// 6002-MDET-005
cy.getByTestId(marketSummaryBlock).within(() => { cy.getByTestId(marketSummaryBlock).within(() => {
cy.getByTestId(marketVolume).within(() => { cy.getByTestId(marketVolume).within(() => {
cy.getByTestId(itemHeader).should('have.text', 'Volume (24h)'); cy.getByTestId(itemHeader).should('have.text', 'Volume (24h)');
@ -72,16 +85,21 @@ describe('Market trading page', () => {
}); });
it('must see market mode', () => { it('must see market mode', () => {
// 6002-MDET-006
cy.getByTestId(marketSummaryBlock).within(() => { cy.getByTestId(marketSummaryBlock).within(() => {
cy.getByTestId(marketMode).within(() => { cy.getByTestId(marketMode).within(() => {
cy.getByTestId(itemHeader).should('have.text', 'Trading mode'); cy.getByTestId(itemHeader).should('have.text', 'Trading mode');
cy.getByTestId(itemValue).should('not.be.empty'); cy.getByTestId(itemValue).should(
'have.text',
'Monitoring auction - liquidity (target not met)'
);
}); });
}); });
}); });
it('must see market state', () => { it('must see market status', () => {
//7002-SORD-061 // 6002-MDET-007
// 7002-SORD-061
cy.getByTestId(marketSummaryBlock).within(() => { cy.getByTestId(marketSummaryBlock).within(() => {
cy.getByTestId(marketState).within(() => { cy.getByTestId(marketState).within(() => {
cy.getByTestId(itemHeader).should('have.text', 'Status'); cy.getByTestId(itemHeader).should('have.text', 'Status');
@ -91,6 +109,7 @@ describe('Market trading page', () => {
}); });
it('must see market settlement', () => { it('must see market settlement', () => {
// 6002-MDET-008
cy.getByTestId(marketSummaryBlock).within(() => { cy.getByTestId(marketSummaryBlock).within(() => {
cy.getByTestId(marketSettlement).within(() => { cy.getByTestId(marketSettlement).within(() => {
cy.getByTestId(itemHeader).should('have.text', 'Settlement asset'); cy.getByTestId(itemHeader).should('have.text', 'Settlement asset');
@ -98,15 +117,12 @@ describe('Market trading page', () => {
}); });
}); });
}); });
it('must see market liquidity supplied', () => {
it('must see market mode', () => { // 6002-MDET-009
cy.getByTestId(marketSummaryBlock).within(() => { cy.getByTestId(marketSummaryBlock).within(() => {
cy.getByTestId(marketMode).within(() => { cy.getByTestId(liquiditySupplied).within(() => {
cy.getByTestId(itemHeader).should('have.text', 'Trading mode'); cy.getByTestId(itemHeader).should('have.text', 'Liquidity supplied');
cy.getByTestId(itemValue).should( cy.getByTestId(itemValue).should('not.be.empty');
'have.text',
'Monitoring auction - liquidity (target not met)'
);
}); });
}); });
}); });
@ -121,14 +137,14 @@ describe('Market trading page', () => {
.realHover(); .realHover();
}); });
}); });
cy.getByTestId('expiry-tooltip') cy.getByTestId(expirtyTooltip)
.eq(0) .eq(0)
.should( .should(
'contain.text', 'contain.text',
'This market expires when triggered by its oracle, not on a set date.' 'This market expires when triggered by its oracle, not on a set date.'
) )
.within(() => { .within(() => {
cy.getByTestId('link') cy.getByTestId(link)
.should('have.attr', 'href') .should('have.attr', 'href')
.and('include', Cypress.env('EXPLORER_URL')); .and('include', Cypress.env('EXPLORER_URL'));
}); });
@ -154,15 +170,14 @@ describe('Market trading page', () => {
.realHover(); .realHover();
}); });
}); });
cy.getByTestId(tradingModeTooltip)
cy.getByTestId('trading-mode-tooltip')
.should( .should(
'contain.text', 'contain.text',
'This market is in auction until it reaches sufficient liquidity.' 'This market is in auction until it reaches sufficient liquidity.'
) )
.eq(0) .eq(0)
.within(() => { .within(() => {
cy.getByTestId('external-link') cy.getByTestId(externalLink)
.should('have.attr', 'href') .should('have.attr', 'href')
.and('include', Cypress.env('TRADING_MODE_LINK')); .and('include', Cypress.env('TRADING_MODE_LINK'));
@ -174,5 +189,27 @@ describe('Market trading page', () => {
} }
}); });
}); });
it('should see liquidity supplied tooltip', () => {
cy.getByTestId(marketSummaryBlock).within(() => {
cy.getByTestId(liquiditySupplied).within(() => {
cy.getByTestId(itemValue).realHover();
});
});
cy.getByTestId(liquiditySuppliedTooltip)
.should('contain.text', 'Supplied stake')
.and('contain.text', 'Target stake')
.first()
.within(() => {
cy.getByTestId(liquidityLink).should(
'have.text',
'View liquidity provision table'
);
cy.getByTestId(externalLink).should(
'have.text',
'Learn about providing liquidity'
);
});
});
}); });
}); });

View File

@ -0,0 +1,27 @@
import { MarketState } from '@vegaprotocol/types';
const oracleBannerDialogTrigger = 'oracle-banner-dialog-trigger';
const oracleBannerStatus = 'oracle-banner-status';
const oracleFullProfile = 'oracle-full-profile';
describe('oracle information', { tags: '@smoke' }, () => {
before(() => {
cy.mockTradingPage(
MarketState.STATE_ACTIVE,
undefined,
undefined,
'COMPROMISED'
);
cy.mockSubscription();
cy.visit('/#/markets/market-0');
cy.wait('@Markets');
});
it('show oracle banner', () => {
cy.getByTestId(oracleBannerStatus).should('contain.text', 'COMPROMISED');
cy.getByTestId(oracleBannerDialogTrigger)
.should('contain.text', 'Show more')
.click();
cy.getByTestId(oracleFullProfile).should('exist');
});
});

View File

@ -99,7 +99,7 @@ export const MarketLiquiditySupplied = ({
AuctionTrigger.AUCTION_TRIGGER_UNABLE_TO_DEPLOY_LP_ORDERS; AuctionTrigger.AUCTION_TRIGGER_UNABLE_TO_DEPLOY_LP_ORDERS;
const description = marketId ? ( const description = marketId ? (
<section> <section data-testid="liquidity-supplied-tooltip">
<KeyValueTable> <KeyValueTable>
<KeyValueTableRow> <KeyValueTableRow>
<span>{t('Supplied stake')}</span> <span>{t('Supplied stake')}</span>