Cypress architecture is illustrated in the below diagram −
data:image/s3,"s3://crabby-images/229e5/229e50272406f3f55c2f3234785d18438a280a7f" alt=""
Automation tools like Selenium work by running outside the browser. However, Cypress has a different architecture. It runs within the browser. Cypress is basically based on the server – Node.js.
There is a continuous interaction of Cypress with the Node.js and they work in coordination with each other. As a result, Cypress can be utilized for testing both the front and backend of the application.
Cypress is thus, capable of handling the tasks performed in real-time on the UI and simultaneously can also perform the actions outside of the browser.
Difference between Cypress and Selenium
The basic differences between Cypress and Selenium are listed below −
Cypress | Selenium |
It is based on Javascript. | It is based on Java, C#, Python, and JavaScript. |
It has small community support | It has big community support. |
It includes an in-built video capture feature. | There is no in-built video capture feature. |
No APIs are available to handle the tabs/child windows. | APIs are available to handle tabs/child windows. |
No parallel execution can be performed. | Parallel execution can be performed. |
The only installation of npm is needed. | Supplemental Jars, libraries, and so on are required to be added as project dependencies. |
Cypress Environment Setup
For Cypress environment setup, visit the link −https://nodejs.org/en/download/. The screen that will appear is given below −
data:image/s3,"s3://crabby-images/2dc51/2dc513a5951c63e0c7ccc1eb9920e00ce05891e0" alt=""
There shall be both Windows and macOS installers. We have to get the package as per the local operating system.
For a 64- bit Windows configuration, the following pop-up comes up to save the installer.
data:image/s3,"s3://crabby-images/aff18/aff18fcd2034578f6b6a76091406de7b597642b0" alt=""
Once the installation is done, a node js file gets created in the Program Files. The path of this file should be noted. Then, enter environment variables from the Start, as shown below −
data:image/s3,"s3://crabby-images/0da0a/0da0aaa086b0bb10473e5c5caac44bdfdf63ece1" alt=""
In the System Properties pop-up, move to Advanced, click on Environment Variables. Then click on OK.
data:image/s3,"s3://crabby-images/8e822/8e8225c58e5a8710a3a470e86efbe7c01f55f774" alt=""
In the Environment Variables pop-up, move to the System variables section and click on New.
data:image/s3,"s3://crabby-images/3e288/3e288d933565bf9f0743acf841b7d8642c5f6b39" alt=""
Enter NODE_HOME and the node.js path (noted earlier) in the Variable name and the Variable value fields respectively in the New System Variable pop-up.
data:image/s3,"s3://crabby-images/6cd42/6cd42cfe071defd38b2049f6340be6fea35083be" alt=""
Once the path of the node.js file is set, we shall create an empty folder (say cypress automation) in any desired location.
Next, we need to have a JavaScript editor to write the code for Cypress. For this, we can download Visual Studio Code from the link https://code.visualstudio.com/
As per the local operating system, choose the correct package −
data:image/s3,"s3://crabby-images/507e9/507e9deaeea204004774aae027631461d248daff" alt=""
Once the executable file is downloaded, and all the installation steps are completed, the Visual Studio Code gets launched.
data:image/s3,"s3://crabby-images/b8876/b887660bafd64999f77f0d1021e4464996204609" alt=""
Select the option Open Folder from the File menu. Then, add the CypressAutomation folder (that we have created before) to the Visual Studio Code.
data:image/s3,"s3://crabby-images/2e989/2e989ada0e950976a11fa54b1dfdf598039cff88" alt=""
We need to create the package.json file with the below command from the terminal −
We have to enter details like the package name, description, and so on, as mentioned in the image given below −
npm init
Once done, the package.json file gets created within the project folder with the information we have provided.
data:image/s3,"s3://crabby-images/b8dc8/b8dc8b4bfa2f49cd14c89515759daf4331f6e023" alt=""
Once done, the package.json file gets created within the project folder with the information we have provided.
data:image/s3,"s3://crabby-images/ebb91/ebb91d2b91a5eb36911910fbdbefcad2facf6b1c" alt=""
Finally, to install Cypress run the command given below −
npm install cypress --save-dev
You will get the following output −
data:image/s3,"s3://crabby-images/2e162/2e1624d0703477e638f90d4c8948f54ed89dc04e" alt=""