How to upload a file in Cypress?

In this tutorial, we will learn how to upload a file in Cypress using the cypress-file-upload NPM package. Cypress does not have a native support to do file uploads at the moment, however, this is something they plan to add in the future.

Ins…


This content originally appeared on DEV Community and was authored by Dilpreet Johal

In this tutorial, we will learn how to upload a file in Cypress using the cypress-file-upload NPM package. Cypress does not have a native support to do file uploads at the moment, however, this is something they plan to add in the future.

Installation

Since, we need to use a third-party library to do file upload, we will need to get that installed and setup to make it work with Cypress. 

Install NPM Package

First thing you need to do is install the package - 
npm install --save-dev cypress-file-upload

Setup Custom Command

cypress-file-upload library provides a custom command which we can use once we set it up. To do that, we need to import the library in the custom command file (cypress/support/commands.js) like this -

import 'cypress-file-upload';

Then, make sure this commands.js is imported in cypress/support/index.js (it might be commented):

import './commands';

Upload File Test

Now, that we have installed the package, we can go ahead and start using the custom command. In the example below, I will be uploading a file on my test website.

cypress file upload example

The key thing to focus on the example above is the .attachFile() command which is added by the helper library that we installed. It takes in a parameter i.e. the file name which should be included inside the fixtures folder as shown below.

cypress fixtures folder

Working with hidden input fields

Typically, the .attachFile() command would work if the input[type=file] element is intractable. However, if the element is hidden then you will need to make necessary changes to make the element visible and intractable again. You can do that using the help of the Cypress .invoke() function as seen below - 

Cypress .invoke function

In this example, I am removing the hidden class using the jquery removeClass function which is making my element intractable again.

To learn more about how to upload a file in Cypress, checkout the video below - 

📧 Subscribe to my mailing list to get access to more content like this as well as be part of amazing free giveaways.

👍 You can follow my content here as well -

...

I love coffees! And, if this post helped you out and you would like to support my work, you can do that by clicking on the button below and buying me a cup of coffee -

Buy me a coffee

You can also support me by liking and sharing this content.

Thanks for reading!


This content originally appeared on DEV Community and was authored by Dilpreet Johal


Print Share Comment Cite Upload Translate Updates
APA

Dilpreet Johal | Sciencx (2021-10-25T12:34:02+00:00) How to upload a file in Cypress?. Retrieved from https://www.scien.cx/2021/10/25/how-to-upload-a-file-in-cypress/

MLA
" » How to upload a file in Cypress?." Dilpreet Johal | Sciencx - Monday October 25, 2021, https://www.scien.cx/2021/10/25/how-to-upload-a-file-in-cypress/
HARVARD
Dilpreet Johal | Sciencx Monday October 25, 2021 » How to upload a file in Cypress?., viewed ,<https://www.scien.cx/2021/10/25/how-to-upload-a-file-in-cypress/>
VANCOUVER
Dilpreet Johal | Sciencx - » How to upload a file in Cypress?. [Internet]. [Accessed ]. Available from: https://www.scien.cx/2021/10/25/how-to-upload-a-file-in-cypress/
CHICAGO
" » How to upload a file in Cypress?." Dilpreet Johal | Sciencx - Accessed . https://www.scien.cx/2021/10/25/how-to-upload-a-file-in-cypress/
IEEE
" » How to upload a file in Cypress?." Dilpreet Johal | Sciencx [Online]. Available: https://www.scien.cx/2021/10/25/how-to-upload-a-file-in-cypress/. [Accessed: ]
rf:citation
» How to upload a file in Cypress? | Dilpreet Johal | Sciencx | https://www.scien.cx/2021/10/25/how-to-upload-a-file-in-cypress/ |

Please log in to upload a file.




There are no updates yet.
Click the Upload button above to add an update.

You must be logged in to translate posts. Please log in or register.