1

我需要帮助编写 Laravel Dusk 测试。我将 Vue 与ElementUI一起使用。select()我真的很喜欢这个框架,但是,我不能在我的测试中使用 Dusk 的内置方法。

这是因为 ElementUI 的select组件不会生成真正的<select>标签,而是创建一个普通的<input>(即只读的),并且在页面底部,带有 select 选项的 popper,所以,<select>我的页面中没有标签,只有一个<div>和一个只读<input>

我怎样才能用 Dusk 编写一个测试,让我点击一个“div”?

如果我尝试使用以下内容输入该输入:

// $browser->select('my_select_id'); not working,
$browser->type('my_select_id', 1);

它向我抛出了一个异常:

Facebook\WebDriver\Exception\InvalidElementStateException: invalid element state: Element must be user-editable in order to clear it.

所以我不知道如何测试 ElementUI 的选择 :(

请帮忙,

谢谢!

编辑

发布 ElementUI 生成的 html:

    <div class="el-select w-100 el-select--mini" value="0" title="Cliente" dusk="v-select-component">
        <div class="el-input el-input--mini el-input--suffix">
            <input autocomplete="off" placeholder="Cliente" size="mini" name="client_id" id="client_id" readonly="readonly" type="text" rows="2" class="el-input__inner">
            <span class="el-input__suffix">
                <span class="el-input__suffix-inner">
                    <i class="el-select__caret el-input__icon el-icon-arrow-up"></i>
                </span>
            </span>
        </div>
        <div class="el-select-dropdown el-popper" style="display: none; min-width: 512.344px;">
            <div class="el-scrollbar" style="">
                <div class="el-select-dropdown__wrap el-scrollbar__wrap" style="margin-bottom: -17px; margin-right: -17px;">
                    <ul class="el-scrollbar__view el-select-dropdown__list" style="position: relative;">
                        <li class="el-select-dropdown__item selected"><span>Item 1</span></li>
                        <li class="el-select-dropdown__item"><span>Item 2</span></li>
                    </ul>
                </div>
                <div class="el-scrollbar__bar is-horizontal">
                    <div class="el-scrollbar__thumb" style="transform: translateX(0%);"></div>
                </div>
                <div class="el-scrollbar__bar is-vertical">
                    <div class="el-scrollbar__thumb" style="transform: translateY(0%);"></div>
                </div>
            </div>
        </div>
    </div>

编辑2:

我用 ElementUI 的选择示例添加了一个简单的JSFiddle 。我只是想用 Laravel Dusk 测试那个选择

4

3 回答 3

2

您必须单击.el-select元素并等待弹出器打开:

$browser->click('.el-select');
$browser->waitFor('.el-select-dropdown.el-popper');

然后您可以按索引选择一个选项:

$browser->elements('.el-select-dropdown__item')[2]->click();

或通过文字:

$selector = "//li[@class='el-select-dropdown__item']/span[text()='Option3']";
$browser->driver->findElement(WebDriverBy::xpath($selector))->click();

我看不到按值选择选项的方法,因为值不在 HTML 中的任何位置。

于 2018-03-28T16:42:03.610 回答
0

@Lionslair 是对的:如果您在页面中使用多个el-select,@JonasStaudenmeir 的解决方案会返回错误。

为了使它工作,我使用 javascript 执行。您可以将此功能添加到您的自定义Browser或您的Component

public function elSelectDropdownClose(Browser $browser)
{
    $browser->script(
<<<EOT
    Array.prototype.slice.call(document.querySelectorAll('.el-select-dropdown.el-popper:not([style*=\"display: none\"])')).map(function(el){
        el.style.display = 'none'
    })
EOT
    );
}
public function elSelectDropdownClick(Browser $browser, $index)
{
    $browser->script(
<<<EOT
    document.querySelectorAll('.el-select-dropdown.el-popper:not([style*=\"display: none\"]) .el-select-dropdown__item')[$index].click()
EOT
    );
    $this->elSelectDropdownClose($browser);
}

运行测试:

$browser
    ->click('.el-select.first')
    ->elSelectDropdownClick(0);

$browser
    ->click('.el-select.second')
    ->elSelectDropdownClick(2);
于 2018-09-21T20:20:45.120 回答
0

仅当您在页面上只有一个 el-select 时才有效,当您有多个时无法识别它们或添加标识符

于 2018-09-20T07:20:24.367 回答