如何在Firefox 14中使用Selenium IDE在TinyMCE编辑器中输入文本

时间:2012-09-13 12:54:48

标签: tinymce selenium-ide

我做了一个测试,它适用于较新或较旧的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>

不要犹豫,问我是否不够清楚。

感谢您提前回复。

2 个答案:

答案 0 :(得分:3)

尝试使用
命令| runScript
目标| tinyMCE.get(&#39; text_area_id_not_iframe_id&#39;)。setContent(&#39;您的文字&#39;)
这将适用于特定的tinyMCE或如果您在一个页面上有多个tinyMCE

否则,如果您只有一个tinyMCE,则运行脚本| tinyMCE.activeEditor.setContent(&#39;您的文字&#39;)

答案 1 :(得分:1)

这是我的工作,基本上,通过选择框架(其他人建议这一点),然后click和focus命令将使其成为活动编辑器,允许sendKeys命令工作。在这个例子中,我将一个变量传递给编辑器,并将iframe TinyMCE创建为一个变量。对于多个实例,我基于$ {frame}变量循环遍历它们。 &LT;

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>