上传量角器Zip文件

时间:2016-08-31 09:32:00

标签: javascript selenium-webdriver protractor angularjs-e2e

我一直在研究用于上传文件的量角器脚本。

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文件,因为我可以手动完成。

如果您遇到任何类似的问题,我将非常感谢您的建议。

2 个答案:

答案 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)

对于迟到的回复表示歉意,问题出在量角器中。我已经将软件包更新到最新版本并且有效。