2

新しいまたは古いFirefoxバージョン、低速または高速のインターネット接続で動作するテストを作成しました(少なくとも、vmwareの仮想マシンのインターネットは遅いと言います)が、typeKeysの後に何が失敗するのかわかりません別のコンピューターでコマンドを実行します。どういうわけかテキストが TinyMCE エディターに書き込まれないため、アサーションが失敗します。

何がそのようなことを引き起こす可能性があるか、または互換性のないコマンドがある可能性があることを誰か教えてもらえますか?

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head profile="http://selenium-ide.openqa.org/profiles/test-case">
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<link rel="selenium.base" href="http://tinymce.com" />
<title>New Test</title>
</head>
<body>
<table cellpadding="1" cellspacing="1" border="1">
<thead>
<tr><td rowspan="1" colspan="3">New Test</td></tr>
</thead><tbody>
<tr>
    <td>open</td>
    <td>http://tinymce.com/tryit</td>
    <td></td>
</tr>
<tr>
    <td>waitForPageToLoad</td>
    <td>15000</td>
    <td></td>
</tr>
<tr>
    <td>assertElementPresent</td>
    <td>id=demo_tab</td>
    <td></td>
</tr>
<tr>
    <td>waitForElementPresent</td>
    <td>id=content_ifr</td>
    <td></td>
</tr>
<tr>
    <td>selectFrame</td>
    <td>id=content_ifr</td>
    <td></td>
</tr>
<tr>
    <td>focus</td>
    <td>//body[@id='tinymce']</td>
    <td></td>
</tr>
<tr>
    <td>clickAt</td>
    <td>//body[@id='tinymce']</td>
    <td>(1,1)</td>
</tr>
<tr>
    <td>typeKeys</td>
    <td>//body[@id='tinymce']</td>
    <td>writing something in this silly form</td>
</tr>
<tr>
    <td>fireEvent</td>
    <td>//body[@id='tinymce']</td>
    <td>blur</td>
</tr>
<tr>
    <td>assertTextPresent</td>
    <td>writing something</td>
    <td></td>
</tr>
<tr>
    <td>selectFrame</td>
    <td>relative=parent</td>
    <td></td>
</tr>
<tr>
    <td>assertElementPresent</td>
    <td>id=submitbtn</td>
    <td></td>
</tr>
<tr>
    <td>clickAndWait</td>
    <td>id=submitbtn</td>
    <td></td>
</tr>
<tr>
    <td>waitForTextPresent</td>
    <td>Post dump</td>
    <td></td>
</tr>
<tr>
    <td>assertTextPresent</td>
    <td>HTML output from post</td>
    <td></td>
</tr>
<tr>
    <td>verifyTextPresent</td>
    <td>writing something</td>
    <td></td>
</tr>
</tbody></table>
</body>
</html>

私が十分に明確でない場合は、遠慮なく尋ねてください。

事前に返信いただきありがとうございます。

4

2 に答える 2

3


コマンド |を使用してみてください。runScript
ターゲット | tinyMCE.get('text_area_id_not_iframe_id').setContent('Your text')
これは、特定の tinyMCE で動作するか、1 ページに複数の tinyMCE がある

場合に機能します。tinyMCE.activeEditor.setContent('あなたのテキスト')

于 2014-04-07T17:36:22.000 に答える
1

基本的に、フレームを選択することで(他の人がこれを提案しました)、クリックとフォーカスのコマンドでアクティブなエディターになり、sendKeysコマンドが機能します。この例では、エディターに変数を渡し、TinyMCE が作成した iframe を変数として保存しています。複数のインスタンスについては、${frame} 変数に基づいてそれらをループしています。<

tr>
    <td>selectWindow</td>
    <td>null</td>
    <td></td>
</tr>
<tr>
    <td>selectFrame</td>
    <td>xpath=//*[contains (@id, '${frame}')]</td>
    <td></td>
</tr>
<tr>
    <td>click</td>
    <td>xpath=//*[contains (@id, 'tinymce')]</td>
    <td></td>
</tr>
<tr>
    <td>focus</td>
    <td>xpath=//*[contains (@id, 'tinymce')]</td>
    <td></td>
</tr>
<tr>
    <td>sendKeys</td>
    <td>xpath=//*[contains (@id, 'tinymce')]</td>
    <td>${date} ${frame}</td>
</tr>
于 2013-11-18T16:08:07.353 に答える