Skip to content

Commit

Permalink
Improve connect (#18)
Browse files Browse the repository at this point in the history
* step 1 of improving connect

* further improvement of connect

* minor ux improvements

* fix improve button do not wrap

* fix no wallet tests

* fix specs

* fix Donation/approve

* finish improving connect

* remove only test

* fix specs for connect walletconnect
  • Loading branch information
spape authored Oct 11, 2021
1 parent 63f1eea commit 6b69951
Show file tree
Hide file tree
Showing 34 changed files with 8,339 additions and 8,500 deletions.
14 changes: 13 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -1192,6 +1192,18 @@ let { account, accounts, wallet } = await DePayWidgets.Connect()
See [depay-web3-wallets](https://github.com/depayfi/depay-web3-wallets) for more details about the returned `wallet`.
### Rejections
1. Rejects if user just closes the dialog without connecting any wallet:
```javascript

DePayWidgets.Connect().then(()=>{}).catch((error)=>{
error // "USER_CLOSED_DIALOG"
})

```
## Development
### Quick start
Expand All @@ -1214,7 +1226,7 @@ test:cypress:debug
Test and debug single cypress file:
```
yarn test:cypress:debug --spec "cypress/integration/Payment/pay-smart-contracts.js"
yarn test:cypress:debug --spec "cypress/integration/Payment/nowallet.js"
```
### Release new versions to npm
Expand Down
97 changes: 91 additions & 6 deletions cypress/integration/Connect/main.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,27 +3,112 @@ import React from 'react'
import ReactDOM from 'react-dom'
import { mock, resetMocks } from 'depay-web3-mock'

describe('execute Payment', () => {
describe('Connect wallet', () => {

const blockchain = 'ethereum'
const accounts = ['0xd8dA6BF26964aF9D7eEd9e03E53415D37aA96045']
beforeEach(resetMocks)
beforeEach(()=>mock({ blockchain, accounts: { return: accounts } }))

it('opens a connect widget ', () => {
afterEach(()=>{
cy.wait(1000).then(()=>{
cy.get('body').then((body) => {
if (body.find('.ReactShadowDOMOutsideContainer').length > 0) {
cy.get('.ReactShadowDOMOutsideContainer').shadow().find('button[title="Close dialog"]').click()
}
cy.wait(1000)
})
})
})

it('directly resolves if a wallet is already connected', () => {
cy.document().then(async (document)=>{
let accountsReturned, accountReturned, walletReturned
mock({ blockchain, wallet: 'metamask', accounts: { return: accounts } })
DePayWidgets.Connect({ document }).then(({ accounts, account, wallet })=>{
accountsReturned = accounts
accountReturned = account
walletReturned = wallet
})
cy.get('.ReactShadowDOMOutsideContainer').shadow().contains('.DialogHeader h1', 'Select a wallet')
cy.get('.ReactShadowDOMOutsideContainer').shadow().find('.Card[title="Connect MetaMask"]').click().then(()=>{
}).catch(()=>{})
cy.wait(1000).then(()=>{
expect(accountsReturned).to.eq(accounts)
expect(accountReturned).to.eq(accounts[0])
expect(walletReturned.name).to.eq('MetaMask')
})
})
})

it('opens a dialog indicating connection is in progress when wallet connection has been initiated automatically and connection can be reinitalized by clicking connect', () => {
cy.document().then(async (document)=>{
let accountsReturned, accountReturned, walletReturned
mock({ blockchain, wallet: 'metamask', accounts: { return: [] } }) // initialy no accounts connected
DePayWidgets.Connect({ document }).then(({ accounts, account, wallet })=>{
accountsReturned = accounts
accountReturned = account
walletReturned = wallet
}).catch(()=>{})
cy.get('.ReactShadowDOMOutsideContainer').shadow().contains('h1', 'Connect Wallet')
cy.get('.ReactShadowDOMOutsideContainer').shadow().contains('p', 'Access to your wallet is required. Please login and authorize access to your account to continue.')
cy.wait(2000).then(()=>{
mock({ blockchain, wallet: 'metamask', accounts: { return: accounts } }) // now connected
cy.wait(1000).then(()=>{
cy.get('.ReactShadowDOMOutsideContainer').shadow().contains('.ButtonPrimary', 'Connect').click().then(()=>{
expect(accountsReturned).to.eq(accounts)
expect(accountReturned).to.eq(accounts[0])
expect(walletReturned.name).to.eq('MetaMask')
cy.get('.ReactShadowDOMOutsideContainer').shadow().contains('h1', 'Connect Wallet').should('not.exist')
})
})
})
})
})

it('opens wallet connect if widget was not able to autodetect any wallet', () => {
cy.document().then(async (document)=>{
let accountsReturned, accountReturned, walletReturned
DePayWidgets.Connect({ document }).then(({ accounts, account, wallet })=>{
accountsReturned = accounts
accountReturned = account
walletReturned = wallet
}).catch(()=>{})
cy.get('.ReactShadowDOMOutsideContainer').shadow().contains('.DialogHeader h1', 'Select a wallet')
cy.get('.ReactShadowDOMOutsideContainer').shadow().find('.Card[title="Connect WalletConnect"]')
})
})

it('rejects if user just closes the dialog', () => {
cy.document().then(async (document)=>{
let rejectionReason
DePayWidgets.Connect({ document }).catch((error)=>{
rejectionReason = error
}).catch(()=>{})
cy.get('.ReactShadowDOMOutsideContainer').shadow().contains('.DialogHeader h1', 'Select a wallet')
cy.wait(1000).then(()=>{
cy.get('.ReactShadowDOMOutsideContainer').shadow().find('button[title="Close dialog"]').click().then(()=>{
cy.wait(1000).then(()=>{
expect(rejectionReason).to.eq('USER_CLOSED_DIALOG')
})
})
})
})
})

it('allows you to return to the list of available wallets even if it autodetected one (and still suggests the autodetected one)', () => {
cy.document().then(async (document)=>{
let accountsReturned, accountReturned, walletReturned
mock({ blockchain, wallet: 'metamask', accounts: { return: [] } }) // initialy no accounts connected
DePayWidgets.Connect({ document }).then(({ accounts, account, wallet })=>{
accountsReturned = accounts
accountReturned = account
walletReturned = wallet
}).catch(()=>{})
cy.get('.ReactShadowDOMOutsideContainer').shadow().contains('h1', 'Connect Wallet')
cy.get('.ReactShadowDOMOutsideContainer').shadow().contains('p', 'Access to your wallet is required. Please login and authorize access to your account to continue.')
cy.get('.ReactShadowDOMOutsideContainer').shadow().find('button[title="Go back"]').click()
cy.get('.ReactShadowDOMOutsideContainer').shadow().contains('.DialogHeader h1', 'Select a wallet')
cy.get('.ReactShadowDOMOutsideContainer').shadow().find('.Card[title="Connect WalletConnect"]')
cy.get('.ReactShadowDOMOutsideContainer').shadow().find('.Card[title="Connect MetaMask"]').click()
cy.get('.ReactShadowDOMOutsideContainer').shadow().contains('button', 'Connect with another wallet').click()
cy.get('.ReactShadowDOMOutsideContainer').shadow().contains('.DialogHeader h1', 'Select a wallet')
})
})
})
39 changes: 39 additions & 0 deletions cypress/integration/Connect/walletconnect.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
import DePayWidgets from '../../../src'
import React from 'react'
import ReactDOM from 'react-dom'
import { mock, resetMocks } from 'depay-web3-mock'
import { wallets } from 'depay-web3-wallets'

describe('WalletConnect Payment', () => {

const blockchain = 'ethereum'
const accounts = ['0xd8dA6BF26964aF9D7eEd9e03E53415D37aA96045']
beforeEach(resetMocks)

it('allows to connect wallet via WalletConnect', () => {
cy.visit('cypress/test.html').then((contentWindow) => {
cy.document().then((document)=>{
let connectedAccount, connectedWallet
DePayWidgets.Connect({ document }).then(({ account, wallet })=>{
connectedAccount = account
connectedWallet = wallet
})
cy.get('.ReactShadowDOMOutsideContainer').shadow().contains('.DialogHeader h1', 'Select a wallet').then(()=>{
mock({
blockchain,
accounts: { return: accounts },
wallet: 'walletconnect',
connector: wallets.WalletConnect.connector
})

cy.get('.ReactShadowDOMOutsideContainer').shadow().find('.Card[title="Connect WalletConnect"]').click().then(()=>{
cy.wait(1000).then(()=>{
expect(connectedAccount).to.equal(accounts[0])
expect(connectedWallet.name).to.equal('WalletConnect')
})
})
})
})
})
})
})
2 changes: 1 addition & 1 deletion cypress/integration/Donation/amount.js
Original file line number Diff line number Diff line change
Expand Up @@ -228,7 +228,7 @@ describe('change Donation amount', () => {
})
})

it.only('allows me to submit a changed amount for a token sale', ()=> {
it('allows me to submit a changed amount for a token sale', ()=> {

let fromAddress = accounts[0]

Expand Down
4 changes: 2 additions & 2 deletions cypress/integration/Donation/approve.js
Original file line number Diff line number Diff line change
Expand Up @@ -104,7 +104,7 @@ describe('approve Donation payment', () => {
}))
})

it('forces me to approve the token for the payment router before I can execute it', () => {
it('asks me to approve the token for the payment router before I can execute it', () => {
let mockedTransaction = mock({
blockchain,
transaction: {
Expand All @@ -121,7 +121,7 @@ describe('approve Donation payment', () => {
DePayWidgets.Donation({ ...defaultArguments, document })
cy.get('.ReactShadowDOMOutsideContainer').shadow().find('.Card[title="Change payment"]').click()
cy.get('.ReactShadowDOMOutsideContainer').shadow().find('.Card[title="Select DAI as payment"]').click()
cy.get('.ReactShadowDOMOutsideContainer').shadow().contains('.ButtonPrimary', 'Allow DAI to be used as payment').click()
cy.get('.ReactShadowDOMOutsideContainer').shadow().contains('.ButtonPrimary[title="Allow DAI to be used as payment"]', 'Allow DAI to be used as payment').click()
cy.get('button[title="Close dialog"]', { includeShadowDom: true }).should('not.exist')
cy.get('.ReactShadowDOMOutsideContainer').shadow().find('.Card.disabled')
cy.get('.ReactShadowDOMOutsideContainer').shadow().find('.ButtonPrimary.wide').should('contain.text', 'Approving...').then(()=>{
Expand Down
4 changes: 2 additions & 2 deletions cypress/integration/Donation/nowallet.js
Original file line number Diff line number Diff line change
Expand Up @@ -35,8 +35,8 @@ describe('having no wallet and opening the Donation widget', () => {
cy.document().then((document)=>{
DePayWidgets.Donation({ ...defaultArguments, document })
cy.get('.ReactShadowDOMOutsideContainer').shadow().contains('.DialogHeader h1', 'Select a wallet')
cy.get('.ReactShadowDOMOutsideContainer').shadow().contains('.CardText', 'MetaMask')
cy.get('.ReactShadowDOMOutsideContainer').shadow().find('.Card[title="Connect MetaMask"]').find('.CardImage img').invoke('attr', 'src').should('eq', '')
cy.get('.ReactShadowDOMOutsideContainer').shadow().contains('.CardText', 'WalletConnect')
cy.get('.ReactShadowDOMOutsideContainer').shadow().find('.Card[title="Connect WalletConnect"]').find('.CardImage img')
})
})
})
Expand Down
2 changes: 1 addition & 1 deletion cypress/integration/Payment/approve.js
Original file line number Diff line number Diff line change
Expand Up @@ -103,7 +103,7 @@ describe('approve Payment', () => {
}))
})

it('forces me to approve the token for the payment router before I can execute it', () => {
it('asks me to approve the token for the payment router before I can execute it', () => {
let mockedTransaction = mock({
blockchain,
transaction: {
Expand Down
4 changes: 2 additions & 2 deletions cypress/integration/Payment/nowallet.js
Original file line number Diff line number Diff line change
Expand Up @@ -33,8 +33,8 @@ describe('having no wallet and opening the Payment widget', () => {
cy.document().then((document)=>{
DePayWidgets.Payment({ ...defaultArguments, document })
cy.get('.ReactShadowDOMOutsideContainer').shadow().contains('.DialogHeader h1', 'Select a wallet')
cy.get('.ReactShadowDOMOutsideContainer').shadow().contains('.CardText', 'MetaMask')
cy.get('.ReactShadowDOMOutsideContainer').shadow().find('.Card[title="Connect MetaMask"]').find('.CardImage img').invoke('attr', 'src').should('eq', '')
cy.get('.ReactShadowDOMOutsideContainer').shadow().contains('.CardText', 'WalletConnect')
cy.get('.ReactShadowDOMOutsideContainer').shadow().find('.Card[title="Connect WalletConnect"]').find('.CardImage img')
})
})
})
Expand Down
Loading

0 comments on commit 6b69951

Please sign in to comment.