我正在使用'量角器'测试我的Web应用程序。 我在项目中添加了“ vue2-editor” ,我想在编辑器中写一些东西并保存数据。 这是Vue生成的html:
<div id="quill-container" class="ql-container ql-snow">
<div class="ql-editor ql-blank" data-gramm="false" contenteditable="true" data-placeholder="Add Note...">
<p>
<br>
</p>
</div>
<div class="ql-clipboard" contenteditable="true" tabindex="-1"></div>
<div class="ql-mention-list-container" style="display: none; position: absolute;">
<ul class="ql-mention-list"></ul>
</div>
</div>
这是我的测试代码:
describe('When you save a note', function () {
beforeAll(function () {
browser.get('http://example');
element.all(by.css(" [id='quill-container'] > div.ql-editor.ql-blank")).click();
element.all(by.css(" [id='quill-container'] > div.ql-editor.ql-blank")).sendKeys('Some Notes add here');
element(by.css("[id='add-note-btn']")).click();
browser.sleep(1000);
});
it('You must see your note at the current page', function () {
expect(element(by.xpath('//p[text()="Some Notes add here"]')).isPresent()).toBe(true);
});
});
执行代码时,量角器会显示以下消息:
失败:元素不可交互
我该怎么办?
答案 0 :(得分:0)
基本上,有四个原因导致元素不可交互。
1)计时-元素加载所需的时间。为此,您需要检查如何使用隐式显式等待
2)检查元素是否在框架中
3)定位器不正确
4)错误的响应方式实施。这仍然源于3)。某些网站仅针对移动版和网络版启用了一个代码。因此,当您检查xxxxx.size时,该元素将具有多个实例。您将需要在列表中搜索显示为!= none的那一个。