• Basics of Javascript
• Cypress Automation Testing
• Mocha / BDD cucumber Framework
• Git and GitHub
• CICD – Jenkins
Javascript Basics for Automation
- Introduction to JavaScript
- Variables and Datatypes
- Conditional Statements
- Loops
- Functions
- Objects
- Working with Objects
- Arrays
- Working with Arrays
- Working with Strings
- Working with numbers
- Class
- Constructor
- Static
- OOPs
Cypress Automation Testing tool
- Course Summary:
- Introduction to Cypress
- Setting up Cypress, Writing the First Test
- Running Cypress Tests in command line, Cypress Hooks
- Page Object Model, Viewport, Fixtures
- Locators – Xpath and plugin configuration
- CSS, Custom commands, Aliasing, and working with Checkboxes, Radio buttons
- Working with Dropdowns, Alerts, File upload, File download
- Video reporting, Dashboard reports, Mochawesome reports
- API testing Integration, BDD Cucumber integration
- Learning Outcomes:
At the completion of the Course participants will exhibit competencies / Skills of:
- Understand Cypress from Scratch and build fast and reliable Automation tests for any Web Applications using Cypress
- Practical knowledge in designing Cypress Automation framework from scratch using Mocha and Cucumber Frameworks
- Real-Time Hands-on Exercises to practice Cypress Parallelly with Videos for building confidence on the tool
- Complete understanding of Cypress Components for generating test execution Videos, Screenshots & Reporting
- Participants will learn advanced architectural concepts like Page Object Modelling
- Cypress Automation Testing Tool
- What are the benefits of Automation?
- Why we do automation
- When should you automate your software testing
- When should automation not be preferred
- Selenium Vs Cypress
- Cypress Introduction
- What is Cypress?
- Why Learn Cypress?
- How does Cypress Work?
- What are the Key Differences between Cypress and other Automation Tools?
- Cypress Demo
- Environment Setup
- Chrome & Firefox Browser Installation
- Prerequisites – [NodeJS Setup]
- NodeJs Setup
- Gitbash Setup
- VS Code Installation & Configuration
- Cypress Setup
- Cypress Installation & Setup
- NPM Installation & Update
- Cypress Overview
- Opening Cypress for the First Time!
- Cypress Test Runner
- Cypress Project Structure
- Cypress API
- Cypress API – Overview
- Mocha
- Mocha – Overview
- Constructing our First Test using Mocha
- Basic Cypress Commands
∙ Command Activation & Inspecting Specific Cypress Commands
∙ Visit & Click Command
∙ Click Options
∙ Type Command
- Creating Our First Test
∙ Creating Our Second Cypress Test – (Positive Test Case)
∙ Creating Our Second Cypress Test – (Negative Test Case)
- Browser Selection – (Chrome, Electron, Firefox)
∙ Running Tests in Chrome, Electron & Firefox
- Web Elements & Selectors
∙ Why do we need Selectors?
∙ Document Object Model (DOM) & Elements
∙ Practical In Depth Look into Selectors
∙ Selector Generator Tools
∙ CSS Selectors
∙ Xpath Selectors
- Assertions
∙ Why do we need Assertions?
∙ Chai Assertions & Cypress Examples
∙ Adding Assertions to our Existing Tests
∙ Cypress Contains
- Referencing Windows
∙ cy.title()
∙ cy.url()
- Triggering Tests via Command Line
∙ Headless Electron Browser
∙ Non Headless Electron Browser
∙ Non Headless Chrome Browser
∙ Trigger Individual Tests
- Working with Cypress Plugins
∙ Cypress Plugins
∙ Cypress Plugins – Xpath
∙ Cypress Plugins – File download
∙ Cypress Plugins – File upload
∙ Cypress Plugins – Cucumber
Cypress real events
- Cypress Chaining Commands
∙ Cypress Chaining Commands – Introduction
∙ More Examples of Command Chaining – get, find, contains, eq
- Logging
∙ Cypress log
- Promises and the Then Command
∙ Promises Real World Example
∙ Cypress and Promises
∙ then Command
- Iterating through Elements
∙ Iterating through Elements – Documentation & Preparation
∙ Practical Example of Iterating through Elements
- Alias & Invoke
∙ Alias & Invoke – Documentation
∙ Alias & Invoke – Practical Example
- Wrap()
- Cypress Limitations
∙ Cypress Limitations
- Browser Navigation
∙ Back, Forward, Reload
- Handling – Alerts
∙ Handing Alerts – Documentation
∙ Handling Alerts – Example
- Handling – Checkboxes
∙ Handling Checkboxes
- Handling – Radio Buttons
∙ Handling Radio Buttons
∙ Validating States of Radio Buttons (Checked & Unchecked)
- Handling – Drop-down Lists
∙ Handling Drop-down Lists
- Autocomplete (Suggested) Lists
∙ Handling Autocomplete Lists
- Mouse Actions
∙ Scroll into View
∙ Drag & Drop
∙ Double Click
∙ Right click Assertions
- Handling Data from Tables
∙ Handling Data – Example
- File Upload
∙ Introduction & Preparation
∙ Uploading File(s)
∙ Uploading no File(s)
- Fixtures
∙ Fixtures – Documentation
∙ Fixtures & Data Driven
∙ Fixtures Custom Commands
- Custom Commands
∙ Custom Commands – Documentation & Practical Example
∙ Using Custom Commands to Further Improve our Framework
- Overriding Default Settings
∙ Cypress.config
∙ Ignore Files
- Environment & Global Variables
∙ Prerequisites
∙ Environment Variables
∙ Setting up a Base URL
- Page Object Modelling
∙ Page Object Modelling
- Configuring & Handling Timeouts
∙ URL Timeouts
∙ Explicit Timeouts
∙ Assertion Timeouts
∙ Wait
- Screenshots & Recordings
∙ Capturing Screenshots
∙ Recording Videos
- Viewport – Altering Screen Sizes
∙ Altering Viewports – Configuring Size and Orientation
- Reporting
∙ Mochawesome Reporter
∙ Mochawesome – Merging Reports GitHub
Allure REports
- ∙ GitHub – Account Creation & Login
∙ Visual Studio Code & GitHub – Setup
∙ Committing and Pushing our Code (Framework) to GitHub
∙ Pushing & Pulling New Changes
- API Test Automation
∙ Cypress – API Testing integration
∙ Cypress – API Testing – GET
∙ Cypress – API Testing – POST
∙ Cypress – API Testing – PUT
∙ Cypress – API Testing – Delete
- Cypress – Cucumber
∙ Cypress – Cucumber Integration
- Convert excel to Json
∙ Data driven testing using excel file
- Cypress cloud Reports
- Handling Elements
∙ Tabs, I-frames, Shadow Elements, Tables, Links
- Cypress Changelog
- Read file and Write file
- Cypress Playground option
- Comparison between cypress old and new versions
- cy.origin()
- cy.sesion()
- Jenkins Integration