import { fireEvent, render, screen } from '@testing-library/react'; import { MemoryRouter } from 'react-router-dom'; import { MockedProvider } from '@apollo/client/testing'; import * as Schema from '@vegaprotocol/types'; import type { MarketMaybeWithCandles, MarketMaybeWithData, MarketData, } from '@vegaprotocol/market-list'; import { SelectMarketLandingTable } from './welcome-landing-dialog'; const mockMarketClickHandler = jest.fn(); jest.mock('../../lib/hooks/use-market-click-handler', () => ({ useMarketClickHandler: () => mockMarketClickHandler, })); type Market = MarketMaybeWithCandles & MarketMaybeWithData; type PartialMarket = Partial< Omit & { data: Partial } >; const MARKET_A: PartialMarket = { __typename: 'Market', id: '1', decimalPlaces: 2, tradingMode: Schema.MarketTradingMode.TRADING_MODE_CONTINUOUS, tradableInstrument: { __typename: 'TradableInstrument', instrument: { __typename: 'Instrument', id: '1', code: 'ABCDEF', name: 'ABCDEF 1-Day', product: { __typename: 'Future', quoteName: 'ABCDEF', settlementAsset: { __typename: 'Asset', id: 'asset-ABC', name: 'asset-ABC', decimals: 2, symbol: 'ABC', }, dataSourceSpecForTradingTermination: { __typename: 'DataSourceSpec', id: 'oracleId', }, dataSourceSpecForSettlementData: { __typename: 'DataSourceSpec', id: 'oracleId', }, dataSourceSpecBinding: { __typename: 'DataSourceSpecToFutureBinding', tradingTerminationProperty: 'trading-termination-property', settlementDataProperty: 'settlement-data-property', }, }, metadata: { __typename: 'InstrumentMetadata', tags: ['ABC', 'DEF'], }, }, }, fees: { __typename: 'Fees', factors: { __typename: 'FeeFactors', infrastructureFee: '0.01', liquidityFee: '0.01', makerFee: '0.01', }, }, data: { __typename: 'MarketData', market: { __typename: 'Market', id: '1', }, markPrice: '90', trigger: Schema.AuctionTrigger.AUCTION_TRIGGER_OPENING, marketState: Schema.MarketState.STATE_PENDING, marketTradingMode: Schema.MarketTradingMode.TRADING_MODE_OPENING_AUCTION, indicativeVolume: '1000', }, candles: [ { __typename: 'Candle', high: '100', low: '10', open: '10', close: '80', volume: '1000', periodStart: '2022-11-01T15:49:00Z', }, { __typename: 'Candle', high: '10', low: '1', open: '1', close: '100', volume: '1000', periodStart: '2022-11-01T15:50:00Z', }, ], }; const MARKET_B: PartialMarket = { __typename: 'Market', id: '2', decimalPlaces: 2, positionDecimalPlaces: 0, tradingMode: Schema.MarketTradingMode.TRADING_MODE_CONTINUOUS, tradableInstrument: { __typename: 'TradableInstrument', instrument: { __typename: 'Instrument', id: '2', code: 'XYZ', name: 'XYZ 1-Day', product: { __typename: 'Future', quoteName: 'XYZ', settlementAsset: { __typename: 'Asset', id: 'asset-XYZ', name: 'asset-XYZ', decimals: 2, symbol: 'XYZ', }, dataSourceSpecForTradingTermination: { __typename: 'DataSourceSpec', id: 'oracleId', }, dataSourceSpecForSettlementData: { __typename: 'DataSourceSpec', id: 'oracleId', }, dataSourceSpecBinding: { __typename: 'DataSourceSpecToFutureBinding', tradingTerminationProperty: 'trading-termination-property', settlementDataProperty: 'settlement-data-property', }, }, metadata: { __typename: 'InstrumentMetadata', tags: ['XYZ'], }, }, }, fees: { __typename: 'Fees', factors: { __typename: 'FeeFactors', infrastructureFee: '0.01', liquidityFee: '0.01', makerFee: '0.01', }, }, data: { __typename: 'MarketData', market: { __typename: 'Market', id: '2', }, markPrice: '123.123', trigger: Schema.AuctionTrigger.AUCTION_TRIGGER_OPENING, marketState: Schema.MarketState.STATE_PENDING, marketTradingMode: Schema.MarketTradingMode.TRADING_MODE_OPENING_AUCTION, indicativeVolume: '2000', }, candles: [ { __typename: 'Candle', high: '100', low: '10', open: '10', close: '80', volume: '1000', periodStart: '2022-11-01T15:49:00Z', }, ], }; describe('WelcomeLandingDialog', () => { it('should call onSelect callback on SelectMarketLandingTable', () => { const onClose = jest.fn(); render( , { wrapper: MockedProvider } ); fireEvent.click(screen.getAllByTestId(`market-link-1`)[0]); expect(onClose).toHaveBeenCalled(); fireEvent.click(screen.getAllByTestId(`market-link-2`)[0]); expect(onClose).toHaveBeenCalled(); }); it('should not call onClose when metaKey is held', () => { const onClose = jest.fn(); render( , { wrapper: MockedProvider } ); fireEvent.click(screen.getAllByTestId(`market-link-1`)[0], { metaKey: true, }); expect(mockMarketClickHandler).toHaveBeenCalled(); expect(onClose).not.toHaveBeenCalled(); fireEvent.click(screen.getAllByTestId(`market-link-1`)[0]); expect(onClose).toHaveBeenCalled(); }); });