Skip to content

KamilSznajdrowicz/cypress-ecommerce-task

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

19 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

E-commerce Website Testing with Cypress

This repository contains end-to-end (E2E) tests for an e-commerce website written in Cypress using TypeScript. The goal is to ensure the functionality and reliability of key features of the website.

Table of Contents

Installation

  1. Clone the repository:

    git clone https://github.com/KamilSznajdrowicz/cypress-ecommerce-task.git
    cd cypress-ecommerce-task
  2. Install the dependencies:

    npm install

Prerequisites

Make sure you have the following versions of Node.js and npm installed:

  • Node.js: >=18.17.1
  • npm: >=9.6.7

Folder Structure

The folder structure of this project is as follows:

cypress-ecommerce-task/
│
├── cypress/
│ ├── e2e/tests/ # Test cases
│ │ ├── CategoryPage.ts # Product Search, Filter, and Sorting tests
│ │ ├── ProductPage.ts # Adding items to cart and validation tests
│ │ └── RegistrationPage.ts # Registration, login, and sample happy path tests
│ ├── fixtures/ # Test data, including fake data from Faker library
│ ├── pageObjects/ # Page Objects with functions for interacting with the application
│ └── support/ # Custom commands and support files
├── .gitignore # Files and directories to ignore in Git
├── cypress.config.ts # Cypress configuration
├── package.json # Project metadata and scripts
├── package-lock.json # Lock file for npm dependencies
├── README.md # Project documentation
└── tsconfig.json # TypeScript configuration

Scripts

The following scripts are available in the package.json file:

  • npm run cypress-o - Open the Cypress Test Runner.
  • npm run cypress-r - run Cypress tests in headless mode via Chrome.

Test Scenarios

This project includes tests for the following scenarios:

User Registration and Login:

  1. Ensure users can register and log in successfully.

  2. Ensure users can't register with an invalid email address - Happy PATH

Product Search and Filter:

  1. Verify that users can search for and filter products.

  2. Verify that users can search for and sort products.

Adding Items to Cart:

  1. Confirm that users can add searching item to their shopping cart.

Running Tests

You can run tests in two ways:

  1. Interactive Mode: This opens the Cypress Test Runner where you can see tests running in real-time.

    npm run cypress-o
  2. Headless Chrome Mode: This runs the tests in the terminal and is useful for CI/CD pipelines.

    npm run cypress-r

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published