-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
17 changed files
with
2,102 additions
and
335 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
* | ||
!.gitignore | ||
!package.json |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
{ | ||
"version": "0.1.0-autogenerated.11858138475473992995", | ||
"name": "@polkadot-api/descriptors", | ||
"files": [ | ||
"dist" | ||
], | ||
"exports": { | ||
".": { | ||
"types": "./dist/index.d.ts", | ||
"module": "./dist/index.mjs", | ||
"import": "./dist/index.mjs", | ||
"require": "./dist/index.js" | ||
}, | ||
"./package.json": "./package.json" | ||
}, | ||
"main": "./dist/index.js", | ||
"module": "./dist/index.mjs", | ||
"browser": "./dist/index.mjs", | ||
"types": "./dist/index.d.ts", | ||
"sideEffects": false, | ||
"peerDependencies": { | ||
"polkadot-api": "*" | ||
} | ||
} |
Binary file not shown.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
{ | ||
"version": 0, | ||
"descriptorPath": ".papi/descriptors", | ||
"entries": { | ||
"pas": { | ||
"chain": "paseo", | ||
"metadata": ".papi/metadata/pas.scale" | ||
} | ||
} | ||
} |
141 changes: 141 additions & 0 deletions
141
packages/example/cypress/e2e/test cypress-polkadot-wallet plugin papi.cy.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,141 @@ | ||
import { waitForAuthRequest } from '../utils/waitForAuthRequests' | ||
|
||
const Alice = { | ||
address: '5Fsaew2ZtsgpaCUWDmBnz8Jn8i49dvJFQUaJ5TZ6NGC1EBeS', | ||
addressWithPrefix0: '14osoGHdkexJ1jV2BQEo8H8vzL3oLDrPUyJnEkYSvMDXQcu7', | ||
name: 'Alice', | ||
type: 'sr25519', | ||
mnemonic: 'blame only east lunar valve mother link pill expect eight quote table' | ||
} as any | ||
|
||
const EXAMPLE_DAPP_NAME = 'example-dapp' | ||
const CUSTOM_WALLET_NAME = 'My-custom-wallet' | ||
const TESTING_LANDING_PAGE = 'http://localhost:3333' | ||
|
||
describe('test cypress-polkadot-wallet plugin', () => { | ||
it('should check if plugin is installed', () => { | ||
expect(cy).property('initWallet').to.be.a('function') | ||
}) | ||
|
||
it('should init the wallet and connect accounts with authorization request', () => { | ||
cy.visit(TESTING_LANDING_PAGE) | ||
cy.initWallet([Alice]) | ||
cy.get('#connect-accounts-papi').click() | ||
cy.getAuthRequests().then((authRequests) => { | ||
const requests = Object.values(authRequests) | ||
// we should have 1 connection request to the wallet | ||
cy.wrap(requests.length).should('eq', 1) | ||
// this request should be from the application EXAMPLE_DAPP_NAME | ||
cy.wrap(requests[0].origin).should('eq', EXAMPLE_DAPP_NAME) | ||
cy.approveAuth(requests[0].id, [Alice.address]) | ||
}) | ||
|
||
// check that the extension is injected | ||
cy.get('#all-extensions').should('contain', 'polkadot-js') | ||
// check that the accounts in papi is injected | ||
cy.get('#all-accounts').should('contain', Alice.address) | ||
cy.get('#injected-error').should('be.empty') | ||
}) | ||
|
||
it('should init the wallet and connect accounts without authorization request', () => { | ||
cy.visit(TESTING_LANDING_PAGE) | ||
// because we pass the origin here, all the account will be automatically | ||
// accepted by the wallet comming from this origin | ||
cy.initWallet([Alice], EXAMPLE_DAPP_NAME) | ||
cy.get('#connect-accounts-papi').click() | ||
|
||
// Here, the wallet has not requested the user authorization, as if the user | ||
// had already approved this Dapp in the past | ||
|
||
// check that 'polkadot-js' is injected and that we get access to the | ||
// injected accounts | ||
cy.get('#all-extensions').should('contain', 'polkadot-js') | ||
cy.get('#all-accounts').should('contain', Alice.address) | ||
cy.get('#injected-error').should('be.empty') | ||
}) | ||
|
||
it('should init the wallet and connect accounts without authorization request and a custom wallet name', () => { | ||
cy.visit(TESTING_LANDING_PAGE) | ||
cy.initWallet([Alice], EXAMPLE_DAPP_NAME, CUSTOM_WALLET_NAME) | ||
cy.get('#connect-accounts-papi').click() | ||
|
||
// check that the custom name is injected | ||
// and that we get access to the injected accounts | ||
cy.get('#all-extensions').should('contain', CUSTOM_WALLET_NAME) | ||
cy.get('#all-accounts').should('contain', Alice.address) | ||
cy.get('#injected-error').should('be.empty') | ||
}) | ||
|
||
it('should init the wallet and reject connection', () => { | ||
cy.visit(TESTING_LANDING_PAGE) | ||
cy.initWallet([Alice]) | ||
cy.get('#connect-accounts-papi').click() | ||
cy.getAuthRequests().then((authRequests) => { | ||
const requests = Object.values(authRequests) | ||
// we should have 1 connection request to the wallet | ||
cy.wrap(requests.length).should('eq', 1) | ||
cy.wrap(requests[0].origin).should('eq', EXAMPLE_DAPP_NAME) | ||
|
||
const ERROR_MESSAGE = 'Cancelled by user' | ||
// The reason 'Cancelled by user' is only printed in the console | ||
// and the Dapp can't access it. It can only know that there are | ||
// no injected wallet. | ||
cy.rejectAuth(requests[0].id, ERROR_MESSAGE) | ||
|
||
// check that the Dapp doesn't get access to any wallet | ||
cy.get('#injected-error').should('contain', ERROR_MESSAGE) | ||
cy.get('#injected').should('be.empty') | ||
|
||
// check that no account got injected | ||
cy.get('#all-accounts').should('be.empty') | ||
}) | ||
}) | ||
|
||
it('should sign a transaction and succeed', () => { | ||
cy.visit(TESTING_LANDING_PAGE) | ||
cy.initWallet([Alice], EXAMPLE_DAPP_NAME) | ||
cy.get('#connect-accounts-papi').click() | ||
cy.get('#all-accounts').should('contain', Alice.address) | ||
cy.get('#amount-input').type('{selectAll}{del}12345') | ||
cy.get('#send-tx-papi').click() | ||
|
||
// this is using wait-until to wait for the tx request | ||
// to reach the wallet | ||
waitForAuthRequest() | ||
|
||
cy.getTxRequests().then((req) => { | ||
const txRequests = Object.values(req) | ||
cy.wrap(txRequests.length).should('eq', 1) | ||
cy.wrap(txRequests[0].payload.address).should('eq', Alice.addressWithPrefix0) | ||
cy.approveTx(txRequests[0].id) | ||
cy.get('#tx-hash').should('not.be.empty') | ||
cy.get('#tx-events', { timeout: 10000 }).should('contain', 'ExtrinsicSuccess') | ||
cy.get('#tx-events', { timeout: 10000 }).should('contain', 'FundsUnavailable') | ||
cy.get('#tx-error').should('be.empty') | ||
}) | ||
}) | ||
|
||
it.only('should sign a transaction and get an error', () => { | ||
cy.visit(TESTING_LANDING_PAGE) | ||
cy.initWallet([Alice], EXAMPLE_DAPP_NAME) | ||
cy.get('#connect-accounts-papi').click() | ||
cy.get('#all-accounts').should('contain', Alice.address) | ||
// Alice doesn not have enough funds the tx will be broadcasted | ||
// but the blockchain should reject it | ||
cy.get('#amount-input').type('{selectAll}{del}100000000000000') | ||
cy.get('#send-tx-papi').click() | ||
|
||
waitForAuthRequest() | ||
|
||
cy.getTxRequests().then((req) => { | ||
const txRequests = Object.values(req) | ||
cy.wrap(txRequests.length).should('eq', 1) | ||
cy.wrap(txRequests[0].payload.address).should('eq', Alice.addressWithPrefix0) | ||
cy.approveTx(txRequests[0].id) | ||
// the tx hash will be present, but the chain will reject the | ||
// tx eventually | ||
cy.get('#tx-hash').should('not.be.empty') | ||
cy.get('#tx-events', { timeout: 10000 }).should('contain', 'ExtrinsicFailed') | ||
}) | ||
}) | ||
}) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.