2023-07-07 07:44:06 +03:00
|
|
|
import { ChainId, WETH9 } from '@uniswap/sdk-core'
|
2023-05-09 20:33:55 +03:00
|
|
|
|
2023-07-06 06:23:03 +03:00
|
|
|
import { ARB, UNI } from '../../src/constants/tokens'
|
2023-05-02 21:39:44 +03:00
|
|
|
import { getTestSelector } from '../utils'
|
2023-04-20 23:00:43 +03:00
|
|
|
|
2023-07-07 07:44:06 +03:00
|
|
|
const UNI_MAINNET = UNI[ChainId.MAINNET]
|
2023-05-09 20:33:55 +03:00
|
|
|
|
2023-04-20 23:00:43 +03:00
|
|
|
const UNI_ADDRESS = '0x1f9840a85d5aF5bf1D1762F925BDADdC4201F984'
|
2023-01-18 21:36:30 +03:00
|
|
|
|
|
|
|
describe('Token details', () => {
|
2023-05-02 21:39:44 +03:00
|
|
|
beforeEach(() => {
|
|
|
|
cy.viewport(1440, 900)
|
2023-01-18 21:36:30 +03:00
|
|
|
})
|
|
|
|
|
|
|
|
it('Uniswap token should have all information populated', () => {
|
|
|
|
// Uniswap token
|
2023-04-20 23:00:43 +03:00
|
|
|
cy.visit(`/tokens/ethereum/${UNI_ADDRESS}`)
|
2023-01-18 21:36:30 +03:00
|
|
|
|
|
|
|
// Price chart should be filled in
|
|
|
|
cy.get('[data-cy="chart-header"]').should('include.text', '$')
|
|
|
|
cy.get('[data-cy="price-chart"]').should('exist')
|
|
|
|
|
|
|
|
// Stats should have: TVL, 24H Volume, 52W low, 52W high
|
|
|
|
cy.get(getTestSelector('token-details-stats')).should('exist')
|
|
|
|
cy.get(getTestSelector('token-details-stats')).within(() => {
|
|
|
|
cy.get('[data-cy="tvl"]').should('include.text', '$')
|
|
|
|
cy.get('[data-cy="volume-24h"]').should('include.text', '$')
|
|
|
|
cy.get('[data-cy="52w-low"]').should('include.text', '$')
|
|
|
|
cy.get('[data-cy="52w-high"]').should('include.text', '$')
|
|
|
|
})
|
|
|
|
|
|
|
|
// About section should have description of token
|
|
|
|
cy.get(getTestSelector('token-details-about-section')).should('exist')
|
|
|
|
cy.contains('UNI is the governance token for Uniswap').should('exist')
|
|
|
|
|
|
|
|
// Links section should link out to Etherscan, More analytics, Website, Twitter
|
|
|
|
cy.get('[data-cy="resources-container"]').within(() => {
|
2023-04-20 23:00:43 +03:00
|
|
|
cy.contains('Etherscan').should('have.attr', 'href').and('include', `etherscan.io/address/${UNI_ADDRESS}`)
|
2023-01-18 21:36:30 +03:00
|
|
|
cy.contains('More analytics')
|
|
|
|
.should('have.attr', 'href')
|
2023-04-20 23:00:43 +03:00
|
|
|
.and('include', `info.uniswap.org/#/tokens/${UNI_ADDRESS}`)
|
2023-01-18 21:36:30 +03:00
|
|
|
cy.contains('Website').should('have.attr', 'href').and('include', 'uniswap.org')
|
|
|
|
cy.contains('Twitter').should('have.attr', 'href').and('include', 'twitter.com/Uniswap')
|
|
|
|
})
|
|
|
|
|
|
|
|
// Contract address should be displayed
|
2023-04-20 23:00:43 +03:00
|
|
|
cy.contains(UNI_ADDRESS).should('exist')
|
2023-01-18 21:36:30 +03:00
|
|
|
})
|
|
|
|
|
|
|
|
it('token with warning and low trading volume should have all information populated', () => {
|
|
|
|
// Shiba predator token, low trading volume and also has warning modal
|
|
|
|
cy.visit('/tokens/ethereum/0xa71d0588EAf47f12B13cF8eC750430d21DF04974')
|
|
|
|
|
2023-03-14 21:37:58 +03:00
|
|
|
// Should have missing price chart when price unavailable (expected for this token)
|
2023-09-27 19:46:09 +03:00
|
|
|
if (cy.get('[data-cy="chart-header"]').contains('Price unavailable')) {
|
2023-03-14 21:37:58 +03:00
|
|
|
cy.get('[data-cy="missing-chart"]').should('exist')
|
|
|
|
}
|
2023-09-22 21:35:54 +03:00
|
|
|
|
|
|
|
// Stats should not exist
|
|
|
|
cy.get(getTestSelector('token-details-stats')).should('not.exist')
|
2023-01-18 21:36:30 +03:00
|
|
|
|
|
|
|
// About section should have description of token
|
|
|
|
cy.get(getTestSelector('token-details-about-section')).should('exist')
|
|
|
|
cy.contains('QOM is the Shiba Predator').should('exist')
|
|
|
|
|
|
|
|
// Links section should link out to Etherscan, More analytics, Website, Twitter
|
|
|
|
cy.get('[data-cy="resources-container"]').within(() => {
|
|
|
|
cy.contains('Etherscan')
|
|
|
|
.should('have.attr', 'href')
|
|
|
|
.and('include', 'etherscan.io/address/0xa71d0588EAf47f12B13cF8eC750430d21DF04974')
|
|
|
|
cy.contains('More analytics')
|
|
|
|
.should('have.attr', 'href')
|
|
|
|
.and('include', 'info.uniswap.org/#/tokens/0xa71d0588EAf47f12B13cF8eC750430d21DF04974')
|
|
|
|
cy.contains('Website').should('have.attr', 'href').and('include', 'qom')
|
|
|
|
cy.contains('Twitter').should('have.attr', 'href').and('include', 'twitter.com/ShibaPredator1')
|
|
|
|
})
|
|
|
|
|
|
|
|
// Contract address should be displayed
|
|
|
|
cy.contains('0xa71d0588EAf47f12B13cF8eC750430d21DF04974').should('exist')
|
|
|
|
|
|
|
|
// Warning label should show if relevant ([spec](https://www.notion.so/3f7fce6f93694be08a94a6984d50298e))
|
|
|
|
cy.get('[data-cy="token-safety-message"]')
|
|
|
|
.should('include.text', 'Warning')
|
|
|
|
.and('include.text', "This token isn't traded on leading U.S. centralized exchanges")
|
|
|
|
})
|
2023-05-09 20:33:55 +03:00
|
|
|
|
|
|
|
describe('swapping', () => {
|
|
|
|
beforeEach(() => {
|
|
|
|
// On mobile widths, we just link back to /swap instead of rendering the swap component.
|
|
|
|
cy.viewport(1200, 800)
|
2023-08-02 08:13:19 +03:00
|
|
|
cy.visit(`/tokens/ethereum/${UNI_MAINNET.address}`).then(() => {
|
2023-05-09 20:33:55 +03:00
|
|
|
cy.wait('@eth_blockNumber')
|
|
|
|
cy.scrollTo('top')
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should have the expected output for a tokens detail page', () => {
|
|
|
|
cy.get(`#swap-currency-input .token-amount-input`).should('have.value', '')
|
|
|
|
cy.get(`#swap-currency-input .token-symbol-container`).should('contain.text', 'Select token')
|
|
|
|
cy.get(`#swap-currency-output .token-amount-input`).should('not.have.value')
|
|
|
|
cy.get(`#swap-currency-output .token-symbol-container`).should('contain.text', 'UNI')
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should automatically navigate to the new TDP', () => {
|
|
|
|
cy.get(`#swap-currency-output .open-currency-select-button`).click()
|
2023-08-25 06:14:24 +03:00
|
|
|
cy.get('[data-reach-dialog-content]').contains('WETH').click()
|
2023-05-09 20:33:55 +03:00
|
|
|
cy.url().should('include', `${WETH9[1].address}`)
|
|
|
|
cy.url().should('not.include', `${UNI_MAINNET.address}`)
|
|
|
|
})
|
|
|
|
|
2023-06-06 23:28:21 +03:00
|
|
|
it('should not share swap state with the main swap page', () => {
|
2023-05-09 20:33:55 +03:00
|
|
|
cy.get(`#swap-currency-output .token-symbol-container`).should('contain.text', 'UNI')
|
|
|
|
cy.get(`#swap-currency-input .open-currency-select-button`).click()
|
|
|
|
cy.contains('WETH').click()
|
2023-05-12 18:05:22 +03:00
|
|
|
cy.visit('/swap')
|
2023-05-09 20:33:55 +03:00
|
|
|
cy.contains('UNI').should('not.exist')
|
|
|
|
cy.contains('WETH').should('not.exist')
|
|
|
|
})
|
|
|
|
|
|
|
|
it('can enter an amount into input', () => {
|
|
|
|
cy.get('#swap-currency-input .token-amount-input').clear().type('0.001').should('have.value', '0.001')
|
|
|
|
})
|
|
|
|
|
|
|
|
it('zero swap amount', () => {
|
|
|
|
cy.get('#swap-currency-input .token-amount-input').clear().type('0.0').should('have.value', '0.0')
|
|
|
|
})
|
|
|
|
|
|
|
|
it('invalid swap amount', () => {
|
|
|
|
cy.get('#swap-currency-input .token-amount-input').clear().type('\\').should('have.value', '')
|
|
|
|
})
|
|
|
|
|
|
|
|
it('can enter an amount into output', () => {
|
|
|
|
cy.get('#swap-currency-output .token-amount-input').clear().type('0.001').should('have.value', '0.001')
|
|
|
|
})
|
|
|
|
|
|
|
|
it('zero output amount', () => {
|
|
|
|
cy.get('#swap-currency-output .token-amount-input').clear().type('0.0').should('have.value', '0.0')
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should show a L2 token even if the user is connected to a different network', () => {
|
2023-08-02 08:13:19 +03:00
|
|
|
cy.visit('/tokens')
|
2023-05-09 20:33:55 +03:00
|
|
|
cy.get(getTestSelector('tokens-network-filter-selected')).click()
|
|
|
|
cy.get(getTestSelector('tokens-network-filter-option-arbitrum')).click()
|
|
|
|
cy.get(getTestSelector('tokens-network-filter-selected')).should('contain', 'Arbitrum')
|
2023-07-06 06:23:03 +03:00
|
|
|
cy.get(getTestSelector(`token-table-row-${ARB.address.toLowerCase()}`)).click()
|
2023-05-09 20:33:55 +03:00
|
|
|
cy.get(`#swap-currency-output .token-symbol-container`).should('contain.text', 'ARB')
|
2023-06-06 23:28:21 +03:00
|
|
|
cy.get(getTestSelector('open-settings-dialog-button')).should('be.disabled')
|
2023-05-09 20:33:55 +03:00
|
|
|
cy.contains('Connect to Arbitrum').should('exist')
|
|
|
|
})
|
|
|
|
})
|
2023-01-18 21:36:30 +03:00
|
|
|
})
|