量角器 Zip 文件上传

Protractor Zip file uploading

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

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

如果您遇到类似的任何问题,我将不胜感激。

您的代码看起来正确,我刚刚检查了上传一个 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);

抱歉回复晚了,问题出在量角器上。我已经将软件包更新到最新版本并且它有效。