あまり一般的ではないようですが、非常に興味深い作業です。標準的な方法はないと思うので、何かを実装する必要があります。
私はPerlをあまり知らず、Javaを使用しているので、これは単なる注意事項です。
実行されたすべてのコマンドをログに記録DefaultSelenium
するextendedを使用するテストのクラスを拡張します。HttpCommandProcessor
import com.thoughtworks.selenium.HttpCommandProcessor;
public class ExtHttpCommandProcessor extends HttpCommandProcessor {
public ExtHttpCommandProcessor(String serverHost, int serverPort,
String browserStartCommand, String browserURL) {
super(serverHost, serverPort, browserStartCommand, browserURL);
}
public String doCommand(String commandName, String[] args) {
StringBuffer sb = new StringBuffer();
sb.append("|" + commandName + "|");
if (args!=null) {
for (String arg : args) {
sb.append(arg + "|");
}
if (args.length<2) {
sb.append(" |");
}
} else {
sb.append(" | |");
}
System.out.println(sb.toString());
// or log it where you want
return super.doCommand(commandName, args);
}
}
と
import com.thoughtworks.selenium.DefaultSelenium;
public class ExtSelenium extends DefaultSelenium {
public ExtSelenium(String serverHost, int serverPort,
String browserStartCommand, String browserURL) {
super(new ExtHttpCommandProcessor(serverHost, serverPort, browserStartCommand, browserURL));
}
}
SeleneseTestCase
次に、テストのベースとして使用するために拡張します。
インポートcom.thoughtworks.selenium.SeleneseTestCase;
public class ExSeleneseTestCase extends SeleneseTestCase {
public void setUp(String url, String browserString) throws Exception {
int port = 4444;
if (url==null) {
url = "http://localhost:" + port;
}
selenium = new ExtSelenium("localhost", port, browserString, url);
selenium.start();
selenium.setContext(this.getClass().getSimpleName() + "." + getName());
}
}
このようなテストの出力は次のようになります。
| getNewBrowserSession | * iexplore | http:// localhost:8080 / |
| setContext | SimpleTest.testNew | |
| open | /webapp/test.html | |
|isTextPresent|サンプルテキスト| |
|クリック|sampleLink| |
| waitForPageToLoad | 10000 | |
| testComplete | | |
このソリューションはverify
sとassert
sをログに記録しないため、ExSeleneseTestCaseでオーバーライドして、トレースを生成することもできます。