当前位置: 首页 > 面试题库 >

在端到端测试中使用跨平台键盘快捷键

邵劲
2023-03-14
问题内容

问题:

在相当大的测试代码库中,我们使用了不同的键盘快捷键。例如,要复制所选文本,我们使用CTRL/COMMAND + C,粘贴CTRL/COMMAND + v,打开一个新标签页CTRL/COMMAND + T等。

为了保持在多个平台上的测试工作, 我们想使CTRLVS
COMMAND选择自动取决于在什么平台上的目标浏览器上运行
。为了确定目标平台,我们目前正在使用以下帮助程序功能,该功能使用navigator.appVersion

this.getControlKey = function () {
    return browser.executeScript("return navigator.appVersion.indexOf('Mac');").then(function (isMac) {
        return isMac ? protractor.Key.COMMAND : protractor.Key.CONTROL;
    });
};

这种方法的问题是getControlKey()返回一个承诺,并且每次使用它时,我们都必须明确地解决该承诺:

helpers.getControlKey().then(function (controlKey) {
    elm.sendKeys(protractor.Key.chord(controlKey, "c"));
});

问题:

  1. 是否可以避免嵌套并简化使用getControlKey()?理想情况下,我希望它像这样简单:

    elm.sendKeys(protractor.Key.chord(helpers.getControlKey(), "c"));
    
  2. 是否使用navigator.appVersion最佳方法来确定目标平台,还有更好的方法吗?


问题答案:

对于两种情况,这是我的最佳答案,

  • 如果多个测试人员在自己的计算机上运行脚本,则可以将helper方法放置在onPrepare()将值分配给常量全局变量的函数中,该变量可用于所有测试。

  • 如果所有测试都在将所有测试随机分配给不同机器的分布式平台上运行,则在这种情况下编写辅助方法,将值分配给该测试中beforeAll()函数的恒定局部变量将是有用的。

转到第二个问题,还有另一种方法,我们可以使用量角器getCapabilities()方法获得在其上执行测试规范的平台。

获取平台类型的代码-

//Below code can be placed either in `onPrepare()` function or `beforeAll()` function depending the need.
//If the below code is placed in the `beforeAll()` function then i guess there won't be any need for a global variable.

browser.controlKey = protractor.Key.CONTROL; //browser.controlKey is a global variable and can be accessed anywhere in the test specs
browser.getCapabilities().then(function(capabilities){
    if(capabilities.caps_.platform === "MAC")
        browser.controlKey = protractor.Key.COMMAND;
});

用法:

elm.sendKeys(protractor.Key.chord(browser.controlKey, "c")); //if its stored as global variable

希望能帮助到你。



 类似资料:
  • 主要内容:Windows 和 Mac 的键盘快捷键,基本的快捷键,文本编辑,Web 浏览器,屏幕截图通过使用键盘快捷键可以节省时间。 Windows 和 Mac 的键盘快捷键 在现代操作系统中和计算机软件程序中,键盘快捷键经常被使用。 使用键盘快捷键能帮您节省很多时间。 基本的快捷键 描述 Windows Mac OS 编辑菜单 Alt + E Ctrl + F2 + F 文件菜单 Alt + F Ctrl + F2 + E 视图菜单 Alt + V Ctrl + F2 + V 全选文本 Ctr

  • 配置本地和全局键盘快捷键 本地快捷键 您可以使用Menu模块来配置仅在应用程序集中时才触发的键盘快捷键。为此,在创建MenuItem时务必指定[`accelerator]属性。 1 const {Menu, MenuItem} = require('electron') 2 const menu = new Menu() 3 ​ 4 menu.append(new MenuItem({ 5 lab

  • 配置本地和全局键盘快捷键 Keyboard Shortcuts Configure local and global keyboard shortcuts 本地快捷键 您可以使用 [Menu] 模块来配置快捷键,只有在 app 处于焦点状态时才可以触发快捷键。 为此,在创建 MenuItem时必须指定一个 [accelerator] 属性。 const { Menu, MenuItem } = r

  • 键盘快捷键 控制台配备了一套非常方便的键盘快捷键,使其工作效率更高。下面是一段概述: 一般编辑 Ctrl/Cmd + I 当前请求自动缩进。 Ctrl + Space 打开自动补全 (即使没有打字也可以)。 Ctrl/Cmd + Enter 提交请求。 Ctrl/Cmd + Up/Down 跳转到上一个/下一个请求的开始或结束。 Ctrl/Cmd + Alt + L 折叠或展开当前代码块。 Ctr

  • 概览 该功能允许你为 Electron 应用程序配置应用和全局键盘快捷键。 示例 本地快捷键 应用键盘快捷键仅在应用程序被聚焦时触发。 为了配置本地快捷键,你需要在创建Menu模块中的MenuItem时指定accelerator属性。 Starting with a working application from the Quick Start Guide, update the main.js

  • Chrome DevTools有几个内置的快捷键,可以节省你的日常工作的时间。 本指南提供了Chrome DevTools中每个快捷键的快速参考。虽然一些快捷方式在全局范围内可用,但其他的快捷方式用于特定的某些单个面板,并根据它可以使用的位置分解。 您还可以在提示工具中找到快捷方式。将鼠标悬停在某个元素上以显示其提示工具。如果元素有快捷方式,提示工具将会包含它。 打开开发者工具 在Google C