t.setFilesToUpload Method
Sets files to upload. Emulates a user's selection in the browser's 'Choose File' dialog. Target element must be an <input>
with the type="file"
attribute.
t.setFilesToUpload(selector, filePath) → this | Promise<any>
Parameter | Type | Description |
---|---|---|
selector |
Function | String | Selector | Snapshot | Promise | Identifies the input field to which file paths are written. See Select Target Elements. |
filePath |
String | Array | The path(s) to the uploaded file. Relative paths are resolved against the folder with the test file. |
The following example illustrates how to use the t.setFilesToUpload
action:
fixture `My fixture`
.page `http://www.example.com/`;
test('Uploading', async t => {
await t
.setFilesToUpload('#upload-input', [
'./uploads/1.jpg',
'./uploads/2.jpg',
'./uploads/3.jpg'
])
.click('#upload-button');
});
The t.setFilesToUpload
action removes all file paths from the input before populating it with new ones.
If an error occurs while files are being uploaded, the test will fail.
The t.clearUpload method allows you to remove files added with t.setFilesToUpload
.
Select Target Elements #
For actions that target DOM elements, use the selector
parameter to identify the desired element.
You can pass any of the following objects as a selector
.
A CSS selector string.
test('My Test', async t => { // Click will be performed on the first element // that matches the CSS selector. await t.click('#submit-button'); });
A selector.
import { Selector } from 'testcafe'; fixture `My fixture` .page `http://www.example.com/`; const lastItem = Selector('.toc-item:last-child'); test('My Test', async t => { // Click will be performed on the element selected by // the 'getLastItem' selector. await t.click(lastItem); });
A client-side function that returns a DOM element.
test('My Test', async t => { // Click will be performed on the element returned by the function, // which is the third child of the document's body. await t.click(() => document.body.children[2]); });
-
import { Selector } from 'testcafe'; fixture `My fixture` .page `http://www.example.com/`; test('My Test', async t => { const topMenuSnapshot = await Selector('#top-menu'); // Click will be performed on the element whose snapshot // is specified. This is an element with the '#top-menu' ID. await t.click(topMenuSnapshot); });
A Promise returned by a selector.
import { Selector } from 'testcafe'; const submitButton = Selector('#submit-button'); fixture `My fixture` .page `http://www.example.com/`; test('My Test', async t => { // Click will be performed on the element specified by the selector // as soon as the promise is resolved. await t.click(submitButton()); });
Before executing an action, TestCafe waits for the target element to appear in the DOM and become visible. If this does not happen within the selector timeout, the test fails.
Note that TestCafe cannot interact with page elements under other elements. If the target element is not on top when an action is triggered, TestCafe waits for this element to appear in the foreground. If this does not happen within the selector timeout, the action is performed with an overlaying element. For information on why the target element can be overlaid, see the stacking description in the z-index topic.
Upload action is the only method that does not require the target
input
to be visible. You can also perform the upload action when theinput
is overlaid.