npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

@applitools/testgenai-cypress

v0.8.23

Published

Applitools TestGenAI enables both technical and non-technical team members to expand test coverage effectively. This inclusivity allows non-technical participants to engage in test automation, helping to distribute the workload more efficiently across the

Readme

Applitools TestGenAI Plugin for Cypress

Applitools TestGenAI enables both technical and non-technical team members to expand test coverage effectively. This inclusivity allows non-technical participants to engage in test automation, helping to distribute the workload more efficiently across the team.

Advantages of TestGenAI:

  • Time-savings: It swiftly records user actions, generating test cases without the need to write manual code for each step.
  • Self-Healing and Robust Tests: The tool automates mundane tasks like filling in forms and provides amenities that improve the overall quality of the generated test code, making tests more robust and easier to maintain over time.
  • Modern Test Coverage: Quickly create modern test coverage in code using Cypress, which includes industry best practices and allows easy migration from existing test implementations, such as Selenium, to Cypress.
  • Facilitates non-developers involvement in test automation, effectively distributing the test creation workload.
  • Automatic reusable variable generation.
  • Page Object Model generation to make code more efficient and tests more readable.

If you have any questions, please visit our documentation or contact us at [email protected]

Getting Started

Installation

npm install @applitools/testgenai-cypress

Initial Setup

Option 1: Automatic Setup

You can automatically configure the TestGenAI plugin by running:

npx @applitools/testgenai-cypress init

Option 2: Manual Setup

If you prefer manual setup or encountered issues with automatic configuration:

  1. Add to your cypress/support/e2e.js:
import '@applitools/testgenai-cypress/commands'
  1. Add to your cypress.config.js:
const { testGenAICypressTasksSetup } = require("@applitools/testgenai-cypress/tasks");

module.exports = defineConfig({
  e2e: {
    setupNodeEvents(on, config) {
      testGenAICypressTasksSetup(on)
    },
  },
});
  1. Create required directories:
    • Create a testgenai folder inside your cypress directory
    • Inside testgenai, create two folders: autoheal and POMs
    • Final structure: ./cypress/testgenai/autoheal and ./cypress/testgenai/POMs

Configuration

Using Configuration Options

Configure the TestGenAI plugin through the env.applitoolsTestGenAI object in your cypress.config.js. Here's an example combining various options:

module.exports = defineConfig({
  env: {
    applitoolsTestGenAI: {
      // Basic configuration
      isEnabled: true,
      autohealDataFolders: ['cypress/testgenai/autoheal'],

      // Network settings
      waitForNetworkCalls: {
        isEnabled: true,
        idle: 3000,
        timeout: 30000
      },

      // Element timing settings
      getElementTimeout: 30000,
      ifExistsTimeout: 5000,

      // Debug settings
      debug: {
        fileLogEnabled: true,
        recordTestRun: false
      }
    }
  },
});

All configuration options are optional and will use their default values if not specified.

Configuration Options Reference

Core Settings

| Option | Default | Description | |--------|---------|-------------| | isEnabled | true | Disable/enable the Preflight Cypress plugin | | generateFixedTests | true | Generate auto-healed tests | | allowObscuredElements | true | Allow obscured elements | | forceActions | false | Forces interactions with elements even when they're covered by other elements or not fully visible. |

Network Settings

| Option | Default | Description | |--------|---------|-------------| | waitForNetworkCalls.isEnabled | true | Wait for network calls to finish before continuing test | | waitForNetworkCalls.idle | 2000ms | Wait for network calls to be idle before continuing | | waitForNetworkCalls.timeout | 60000ms | Maximum wait time for network calls to finish |

Element Timing Settings

| Option | Default | Description | |--------|---------|-------------| | getElementTimeout | 60000ms | Maximum time to wait for an element to appear | | ifExistsTimeout | 3000ms | Maximum time to wait for an element to exist | | waitToDisappear.searchElementTimeout | 10000ms | Maximum time to wait for an element to appear before waiting for it to disappear | | waitToDisappear.timeout | 90000ms | Maximum time to wait for an element to disappear |

Selector and Auto-healing Settings

| Option | Default | Description | |--------|---------|-------------| | autohealDataFolders | [] | A list of directory paths to the autoheal folder | | selectorGeneratorOptions.excludedAttributeTypes | [] | List of selector attributes to exclude in self-healing | | selectorGeneratorOptions.excludedAttributeValueKeywords | [] | List of selector attributes containing keywords to exclude in self-healing | | selectorGeneratorOptions.includedAttributeTypes | [] | List of selector attributes to prefer in self-healing |

Debug Settings

| Option | Default | Description | |--------|---------|-------------| | debug.fileLogEnabled | false | Enable debug logging and generate a log file in the debug folder | | debug.recordTestRun | false | Enable debug recording of test execution and generate a zip file in the debug folder |