Cursor testing

E2E Tests Timing Out in Cursor-Generated Test Suites

End-to-end tests generated by Cursor using Playwright, Cypress, or Selenium time out during execution. Tests hang waiting for elements that never appear, pages that never load, or network requests that never complete. The tests work sometimes but fail intermittently, making your test suite unreliable and CI pipelines unpredictable.

E2E test flakiness is the number one reason teams abandon automated testing. Cursor generates tests that follow the happy path but don't account for the asynchronous, timing-dependent nature of real browser interactions. The AI writes selectors for elements that may not exist yet, clicks buttons before they're interactive, and asserts content that loads asynchronously.

The result is a test suite that passes locally (where the app is fast) but fails in CI (where resources are limited and the app is slower), or passes 80% of the time and fails randomly on the other 20%.

Error Messages You Might See

TimeoutError: Waiting for selector "button.submit" exceeded 30000ms TimeoutError: page.waitForNavigation: Timeout 30000ms exceeded Error: Element is not visible or not an HTMLElement CypressError: Timed out retrying after 4000ms: Expected to find element: '[data-cy=result]' Test timeout of 60000ms exceeded
TimeoutError: Waiting for selector "button.submit" exceeded 30000msTimeoutError: page.waitForNavigation: Timeout 30000ms exceededError: Element is not visible or not an HTMLElementCypressError: Timed out retrying after 4000ms: Expected to find element: '[data-cy=result]'Test timeout of 60000ms exceeded

Common Causes

  • Static waits instead of dynamic waits — Cursor uses await page.waitForTimeout(3000) instead of waiting for specific elements or conditions, which is both slow and unreliable
  • Fragile CSS selectors — Tests use selectors like .sc-bdfBwQ.iQNHGt (auto-generated class names) that change every build, or deeply nested selectors that break with minor DOM changes
  • Missing API/network wait — The test clicks a submit button and immediately checks for a success message, without waiting for the API request to complete
  • Element not interactable — The test tries to click an element that's rendered but covered by a modal, loading overlay, or tooltip
  • CI environment is slower — Tests assume fast load times from local development. CI runners have less CPU/memory, making everything slower and timing-dependent tests fail
  • Navigation not awaited — The test clicks a link that triggers navigation but checks for content before the new page loads

How to Fix It

  1. Use data-testid attributes — Add data-testid="submit-button" to important elements and select with page.getByTestId('submit-button'). These are stable across builds and style changes
  2. Wait for specific conditions, not time — Replace waitForTimeout with await page.waitForSelector('[data-testid="success-message"]') or Playwright's auto-waiting assertions like await expect(page.getByText('Success')).toBeVisible()
  3. Wait for network idle after actions — Use await page.waitForLoadState('networkidle') or await page.waitForResponse(url => url.includes('/api/submit')) after form submissions
  4. Increase default timeout for CI — Set timeout: 60000 in your Playwright/Cypress config for CI environments while keeping shorter timeouts locally
  5. Use Playwright's built-in auto-waiting — Playwright's click(), fill(), and expect() methods auto-wait for elements to be visible and interactive. Use these instead of manual waits
  6. Add retry logic for flaky assertions — Use Playwright's expect().toBeVisible({ timeout: 10000 }) or Cypress's built-in retry-ability to handle timing variations

Real developers can help you.

prajwalfullstack prajwalfullstack Hi Im a full stack developer, a vibe coded MVP to Market ready product, I'm here to help Matthew Jordan Matthew Jordan I've been working at a large software company named Kainos for 2 years, and mainly specialise in Platform Engineering. I regularly enjoy working on software products outside of work, and I'm a huge fan of game development using Unity. I personally enjoy Python & C# in my spare time, but I also specialise in multiple different platform-related technologies from my day job. Pratik Pratik SWE with 15+ years of experience building and maintaining web apps and extensive BE infrastructure Jen Jacobsen Jen Jacobsen I’m a Full-Stack Developer with over 10 years of experience building modern web and mobile applications. I enjoy working across the full product lifecycle — turning ideas into real, well-built products that are intuitive for users and scalable for businesses. I particularly enjoy building mobile apps, modern web platforms, and solving complex technical problems in a way that keeps systems clean, reliable, and easy to maintain. Jared Hasson Jared Hasson Full time lead founding dev at a cyber security saas startup, with 10 yoe and a bachelor's in CS. Building & debugging software products is what I've spent my time on for forever Stanislav Prigodich Stanislav Prigodich 15+ years building iOS and web apps at startups and enterprise companies. I want to use that experience to help builders ship real products - when something breaks, I'm here to fix it. Krishna Sai Kuncha Krishna Sai Kuncha Experienced Professional Full stack Developer with 8+ years of experience across react, python, js, ts, golang and react-native. Developed inhouse websearch tooling for AI before websearch was solved : ) Omar Faruk Omar Faruk As a Product Engineer at Klasio, I contributed to end-to-end product development, focusing on scalability, performance, and user experience. My work spanned building and refining core features, developing dynamic website templates, integrating secure and reliable payment gateways, and optimizing the overall system architecture. I played a key role in creating a scalable and maintainable platform to support educators and learners globally. I'm enthusiastic about embracing new challenges and making meaningful contributions. Dor Yaloz Dor Yaloz SW engineer with 6+ years of experience, I worked with React/Node/Python did projects with React+Capacitor.js for ios Supabase expert Caio Rodrigues Caio Rodrigues I'm a full-stack developer focused on building practical and scalable web applications. My main experience is with **React, TypeScript, and modern frontend architectures**, where I prioritize clean code, component reusability, and maintainable project structures. I have strong experience working with **dynamic forms, state management (Redux / React Hook Form), and complex data-driven interfaces**. I enjoy solving real-world problems by turning ideas into reliable software that companies can actually use in their daily operations. Beyond coding, I care about **software quality and architecture**, following best practices for componentization, code organization, and performance optimization. I'm also comfortable working across the stack when needed, integrating APIs, handling business logic, and helping transform prototypes into production-ready systems. My goal is always to deliver solutions that are **simple, efficient, and genuinely useful for the people using them.**

You don't need to be technical. Just describe what's wrong and a verified developer will handle the rest.

Get Help

Frequently Asked Questions

How do I make E2E tests less flaky?

Three key practices: 1) Never use fixed timeouts (waitForTimeout), always wait for specific conditions. 2) Use stable selectors (data-testid) instead of CSS classes or XPath. 3) Wait for network requests to complete before asserting results. Also run tests in a consistent environment with controlled test data.

Should I run E2E tests in CI on every commit?

Run fast unit tests on every commit. Run E2E tests on pull requests and before deployments. E2E tests are slow and resource-intensive, so running them on every commit slows down the feedback loop. Use parallelization and test sharding to speed them up when you do run them.

Related Cursor Issues

Can't fix it yourself?
Real developers can help.

You don't need to be technical. Just describe what's wrong and a verified developer will handle the rest.

Get Help