synpress
synpress copied to clipboard
cy.task('setupMetamask') issue
While running the setupMetamask i got this issue? Is there someone having the same problem?
setupMetamask, Object{3}
CypressError
cy.task('setupMetamask') failed with the following error:
> Cannot read properties of undefined (reading 'waitForTimeout')
Because this error occurred during a before each hook we are skipping the remaining tests in the current suite: wallet
Yes, I got the same issue withsetupMetaMask
what environemtn are you using it?
github actions?
No, I used cypress with puppeteer
I use the same as you.
waitForTimeout is because the puppeeteer cannot open in time.
What i did to overcome this was create a fake first test with wait(5000) to give time for pupeeteer to open up in time. Still trying to figure out what is going on in here.
P.S - i forked synpress to my repos and created also a npm package with the information need to work as a plugin.
you can take a look in here - https://github.com/pcardosolei/cypress-metamask-plugin
I have checked this cypress-metamask-v2 repo as well and is it working well? Or did you update from this repo?
Did not test that.
Totally forked from synpress. I want to have a stable plugin version and then pass the relevant information to this repo so people can use synpress on a more stable way.
The reason why i added as a plugin is to be flexible with my tests. I'm passing via CYPRESS_VARIABLE in the CI CD and cypress.env.json for the variables i want to have in my local tests.
How could I integrate your repo into my project? Because I did yarn add -D cypress-metamask-v2
some days ago and it took very long time in link step
so it looked very weird or heavy. Btw can I see your npm package link?
https://www.npmjs.com/package/cypress-metamask-plugin
I will be updating the readMe as I have time.
If you make any example without yarn add
, it would very helpful
-
npm run cy:open
for the cypress window. -
npm run cy:run
to run all tests.
on package json.
"cy:run": "CYPRESS_REMOTE_DEBUGGING_PORT=9222 cypress run --browser chrome --headed"
I will update it.
How could I integrate your repo into my project? Because I did
yarn add -D cypress-metamask-v2
some days ago and it took very long time inlink step
so it looked very weird or heavy. Btw can I see your npm package link?
yes. i will be updating as I see the need.
While running the setupMetamask i got this issue? Is there someone having the same problem?
setupMetamask, Object{3} CypressError cy.task('setupMetamask') failed with the following error: > Cannot read properties of undefined (reading 'waitForTimeout') Because this error occurred during a before each hook we are skipping the remaining tests in the current suite: wallet
Is the issue resolved or did you come across any solution ?
you tried on the local or github actions?
I tried on local.
Facing this issue
My code:
When I run synpress natively on my host, it works fine. But when I run it headed via xhost in a docker container, I get the same errors as above. Same thing if I run it headless in the docker container, I get these undefined / waitForTimeout errors.
Anyone have any luck tracking down what's actually going on ?
I use the same as you.
waitForTimeout is because the puppeeteer cannot open in time.
What i did to overcome this was create a fake first test with wait(5000) to give time for pupeeteer to open up in time. Still trying to figure out what is going on in here.
P.S - i forked synpress to my repos and created also a npm package with the information need to work as a plugin.
you can take a look in here - https://github.com/pcardosolei/cypress-metamask-plugin
But the timeout error is happening in the before hook, the tests don't get a chance to even run.
Push them to before each instead of before.
On Thu, 2 Jun 2022, 15:51 Marko Bilal, @.***> wrote:
I use the same as you.
waitForTimeout is because the puppeeteer cannot open in time.
What i did to overcome this was create a fake first test with wait(5000) to give time for pupeeteer to open up in time. Still trying to figure out what is going on in here.
P.S - i forked synpress to my repos and created also a npm package with the information need to work as a plugin.
you can take a look in here - https://github.com/pcardosolei/cypress-metamask-plugin
But the timeout error is happening in the before hook, the tests don't get a chance to even run.
— Reply to this email directly, view it on GitHub https://github.com/Synthetixio/synpress/issues/414#issuecomment-1144958136, or unsubscribe https://github.com/notifications/unsubscribe-auth/ACNFYLU7EGJIYXLKU6HYFSLVNDDABANCNFSM5WGRF65Q . You are receiving this because you commented.Message ID: @.***>
Push them to before each instead of before. … On Thu, 2 Jun 2022, 15:51 Marko Bilal, @.> wrote: I use the same as you. waitForTimeout is because the puppeeteer cannot open in time. What i did to overcome this was create a fake first test with wait(5000) to give time for pupeeteer to open up in time. Still trying to figure out what is going on in here. P.S - i forked synpress to my repos and created also a npm package with the information need to work as a plugin. you can take a look in here - https://github.com/pcardosolei/cypress-metamask-plugin But the timeout error is happening in the before hook, the tests don't get a chance to even run. — Reply to this email directly, view it on GitHub <#414 (comment)>, or unsubscribe https://github.com/notifications/unsubscribe-auth/ACNFYLU7EGJIYXLKU6HYFSLVNDDABANCNFSM5WGRF65Q . You are receiving this because you commented.Message ID: @.>
Ok I'll put it this way: Synpress run on native host : chrome opens , metamask setup runs right away and I see all the fields get populated for metamask setup
Synpress run from docker container: no metamask popup, just fails with the above errors as others have also posted.
I created a single test to give time to pupeeteer to run everything. im still trying to put it from the start. I'm not using synpress . just it as a plugin.
github actions?
Yes Github action does not work
I tried on local. Facing this issue
My code:
Experiencing the same problem in Gitpod environment, which runs a remote docker image. The default puppeteer-spec.js
tests from the Synpress repo pass. However metamask-spec.js
from the same repo fail.
I tried on local. Facing this issue
My code:
Experiencing the same problem in Gitpod environment, which runs a remote docker image. The default
puppeteer-spec.js
tests from the Synpress repo pass. Howevermetamask-spec.js
from the same repo fail.
Is your localhost server running in the same container ? It might not be able to reach your web server
Is your localhost server running in the same container ? It might not be able to reach your web server
Thank you for responding, @marko911
After tinkering quite a bit with environment settings and install dependencies, I was able to get to a point where synpress run
works well, however synpress open
shows the same type of errors.
Here is the latest repo: https://github.com/ivelin/sweat-token/tree/fix-pm-gas-v2/e2e-tests
Recording of a passing spec:
https://user-images.githubusercontent.com/2234901/184509727-b4580592-362f-4e97-8d6f-c3db912905d3.mp4
@ivelin Why are you trying to do synpress open ?
@ivelin Why are you trying to do synpress open ?
Just as a usability convenience. It saves some time from starting the whole cypress stack each time via synpress run
.
Hello! I have the same problem as described above run tests locally
describe('User can load page', () => {
before(() => {
cy.setupMetamask();
cy.changeMetamaskNetwork('localhost')
cy.visit('/')
});
it('is expected to display a sussess message', () => {
cy.get('[data-cy=title]').should('contain.text', 'MetaMask Detected')
});
it('is expected to display the local wallet address', () => {
cy.get('[data-cy=address').should('contain.text', 'Your address is: 0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266')
});
it('is expected to display the local wallet balance', () => {
cy.get('[data-cy=balance').should('contain.text', 'Balance: 10000000000000000000000')
});
})
"@synthetixio/synpress": "^2.3.3-beta.0",
"cypress": "^10.8.0",
Is your localhost server running in the same container ? It might not be able to reach your web server
Thank you for responding, @marko911
After tinkering quite a bit with environment settings and install dependencies, I was able to get to a point where
synpress run
works well, howeversynpress open
shows the same type of errors.Here is the latest repo: https://github.com/ivelin/sweat-token/tree/fix-pm-gas-v2/e2e-tests
Recording of a passing spec:
home.js.mp4
Hey, I am still experiencing the same error. What dependencies did you install to fix it?
@Super-Nim I am not sure where you are at with your setup but I actually dug into the synpres code while they still used puppeteer and found a lot of hacky code with arbitrary timeouts like wait(3000) where the page would wait 3s for example to show the metamask modal. This wasn't enough time in my local setup so the metamask setup would always fail. Since then the synpress team has updated their library and use playwright instead of puppeteer. I'd try the new version if I were you and see if you still experience same problems.
@Super-Nim I am not sure where you are at with your setup but I actually dug into the synpres code while they still used puppeteer and found a lot of hacky code with arbitrary timeouts like wait(3000) where the page would wait 3s for example to show the metamask modal. This wasn't enough time in my local setup so the metamask setup would always fail. Since then the synpress team has updated their library and use playwright instead of puppeteer. I'd try the new version if I were you and see if you still experience same problems.
I have tried both v1 and the latest versions of Synpress. The V1.2.0 loads the metamask setup tab - but then stops working after the first interaction.
I have been trying to get the Metamask setup tab to load for Synpress V2.4.1 but it just errors out like above, and doesn't even get setup. Here is my synpress.config.js file:
{
animationDistanceThreshold: 5,
arch: 'x64',
baseUrl: 'https://c3-my-test.myshopify.com',
blockHosts: null,
browsers: [
{
name: 'chrome',
family: 'chromium',
channel: 'stable',
displayName: 'Chrome',
version: '106.0.5249.103',
path: 'C:\Program Files (x86)\Google\Chrome\Application\chrome.exe',
minSupportedVersion: 64,
majorVersion: '106',
},
{
name: 'edge',
family: 'chromium',
channel: 'stable',
displayName: 'Edge',
version: '106.0.1370.37',
path: 'C:\Program Files (x86)\Microsoft\Edge\Application\msedge.exe',
minSupportedVersion: 79,
majorVersion: '106',
},
{
name: 'electron',
channel: 'stable',
family: 'chromium',
displayName: 'Electron',
version: '102.0.5005.148',
path: '',
majorVersion: 102,
},
],
chromeWebSecurity: true,
clientCertificates: [],
defaultCommandTimeout: 300000,
downloadsFolder: 'cypress/downloads',
env: {
coverage: false,
REMOTE_DEBUGGING_PORT: 9222,
},
excludeSpecPattern: '*.hot-update.js',
execTimeout: 60000,
experimentalFetchPolyfill: false,
experimentalInteractiveRunEvents: false,
experimentalModifyObstructiveThirdPartyCode: false,
experimentalSessionAndOrigin: false,
experimentalSingleTabRunMode: false,
experimentalSourceRewriting: false,
experimentalStudio: false,
experimentalWebKitSupport: false,
fileServerFolder: '',
fixturesFolder: 'cypress/fixtures',
hosts: null,
includeShadowDom: false,
isInteractive: true,
keystrokeDelay: 0,
modifyObstructiveCode: true,
nodeVersion: null,
numTestsKeptInMemory: 50,
pageLoadTimeout: 300000,
platform: 'win32',
port: null,
projectId: null,
redirectionLimit: 20,
reporter: 'spec',
reporterOptions: null,
requestTimeout: 300000,
resolvedNodePath: null,
resolvedNodeVersion: null,
responseTimeout: 30000,
retries: {
runMode: 0,
openMode: 0,
},
screenshotOnRunFailure: true,
screenshotsFolder: 'cypress/screenshots',
scrollBehavior: 'top',
slowTestThreshold: 10000,
specPattern: 'cypress/e2e/**/*.cy.{js,jsx,ts,tsx}',
supportFile: 'cypress/support/index.js',
supportFolder: false,
taskTimeout: 60000,
testIsolation: 'legacy',
trashAssetsBeforeRuns: true,
userAgent: 'synpress',
video: false,
videoCompression: 32,
videosFolder: 'videos',
videoUploadOnPasses: true,
viewportHeight: 850,
viewportWidth: 1366,
waitForAnimations: true,
watchForFileChanges: true,
}
Hey there,
When I use synpress run
it's working fine, however when I use synpress open
I get the same error as @qaultron and @nobita851 (see screenshot below).
I think I'm using the latest version (2.4.1-beta.1
), so it's probably not due to a pupetter hack as pointed out by @marko911 .
Using the open
mode is, as @ivelin said, a must have for convenience and a requirement for me.
Any clues on this ? Thanks :)
data:image/s3,"s3://crabby-images/0eb7e/0eb7e2fe92b8707e49f102da2e200250be0887ae" alt="image"