我一直在研究用于上传文件的量角器脚本。
function upload(params) {
return _waitForElm(params.xpath)
.then(() => {
var absPath = path.resolve(__dirname, '../../../assets/' + params.filePath.match(/[^\\\/]+$/)[0]);
return $(params.xpath).sendKeys(absPath);
}).catch(err => {
console.error(jasmine.getEnv().currentSpec.description, 'Upload file', params.xpath);
throw err;
});
}
params.xpath实际上是一个有效的CSS选择器(旧变量名)。
/**
* Wait for an element to be present and scroll to it if not displayed.
*
* @param xpath
* @returns {Promise<U>|IPromise<U>}
*/
function waitForElm(xpath) {
return browser.wait(() => {
return element.all(by.css(xpath)).then(items => {
return items.length > 0;
});
}, 10000)
.then(() => {
return $(xpath).isDisplayed().then(isDisplayed => {
if (!isDisplayed) {
return _scrollToElm(xpath);
}
});
});
}
/**
* Scroll to the element in the page.
*
* @param xpath
* @returns {Promise<U>|IPromise<U>}
* @private
*/
function _scrollToElm(xpath) {
let elm = $(xpath);
return browser.executeScript('arguments[0].scrollIntoView();', elm.getWebElement());
}
上传功能完全适用于我的其他文件(jpg,png和PDF)但不上传zip文件,并且在失败时不会抛出任何异常。输入文件也接受zip文件,因为我可以手动完成。
如果您遇到任何类似的问题,我将非常感谢您的建议。
答案 0 :(得分:1)
您的代码看起来正确,我刚刚检查了上传ZIP文件,部分重新使用您的代码,看起来不错。
var filePath = 'documents.zip';
var absPath = path.resolve(__dirname, '../Resources/' + filePath.match(/[^\\\/]+$/)[0]);
console.log(absPath); // C:\Users\<<user>>\Project\abc\Resources\documents.zip
filespage.upload(absPath);
答案 1 :(得分:0)
对于迟到的回复表示歉意,问题出在量角器中。我已经将软件包更新到最新版本并且有效。