web-dev-qa-db-ja.com

Selenium WebDriverでネイティブロガーを取得する方法

Selenium WebDriverが使用するロガーを何らかの方法で取得することは可能ですか?発行されたすべてのコマンドのトランスクリプトをキャプチャしたい(例:開く、待機、クリックなど)。特に、テストをjunitにエクスポートしているため、Javaソリューションを探しています。

私は彼らのウェブサイトでこのコードを見つけましたが、標準出力には何も表示されません

    DesiredCapabilities caps = DesiredCapabilities.firefox(); 
    LoggingPreferences logs = new LoggingPreferences(); 
    logs.enable(LogType.DRIVER, Level.FINEST); 
    caps.setCapability(CapabilityType.LOGGING_PREFS, logs); 
    driver = new FirefoxDriver(caps);
21
Zombies

使用しているドライバーのログを有効にし、関心のあるログの種類とログレベルを選択します(私はFirefoxDriverを使用しており、すべての種類のログを有効にし、すべてのログメッセージを収集しています)

LoggingPreferences logs = new LoggingPreferences();
logs.enable(LogType.BROWSER, Level.ALL);
logs.enable(LogType.CLIENT, Level.ALL);
logs.enable(LogType.DRIVER, Level.ALL);
logs.enable(LogType.PERFORMANCE, Level.ALL);
logs.enable(LogType.PROFILER, Level.ALL);
logs.enable(LogType.SERVER, Level.ALL);

DesiredCapabilities desiredCapabilities = DesiredCapabilities.firefox();
desiredCapabilities.setCapability(CapabilityType.LOGGING_PREFS, logs);

WebDriver driver = new FirefoxDriver(desiredCapabilities);

次に、テストを実行した後、ログを収集できます(私はDRIVERログのみを収集していますが、どのタイプのログでも同じことができます)

Logs logs = driver.manage().logs();
LogEntries logEntries = logs.get(LogType.DRIVER);

for (LogEntry logEntry : logEntries) {
    System.out.println(logEntry.getMessage());
}
36
Miguel Ferreira

試す

driver.manage().logs()

ログとログタイプを取得するメソッドを持つLogsインターフェイスを取得します。 Logsインターフェースのドキュメント を参照してください

3
Nikolay

これを試して -

import logging
logging.basicConfig(filename = log_filename, level = logging.DEBUG)

リファレンス- Python-私のログファイルはどこにありますか? のセレン単体テスト

0
Thirumal

ロギングにはutils loggerが最も簡単でわかりやすいので、log4jを使用しています(IMHO)。

POMの依存関係:

<dependency>
          <groupId> org.Apache.cassandra</groupId>
          <artifactId>cassandra-all</artifactId>
          <version>0.8.1</version>
      </dependency>

      <dependency>
          <groupId>org.slf4j</groupId>
          <artifactId>slf4j-api</artifactId>
          <version>1.6.6</version>
      </dependency>
      <dependency>
          <groupId>org.slf4j</groupId>
          <artifactId>jcl-over-slf4j</artifactId>
          <version>1.6.6</version>
          <scope>runtime</scope>
      </dependency>
      <dependency>
          <groupId>org.slf4j</groupId>
          <artifactId>jul-to-slf4j</artifactId>
          <version>1.6.6</version>
          <scope>runtime</scope>
      </dependency>
      <dependency>
          <groupId>org.slf4j</groupId>
          <artifactId>log4j-over-slf4j</artifactId>
          <version>1.6.6</version>
          <scope>runtime</scope>
      </dependency>

インポートは次のとおりです。

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

使用法:

private static Logger log = LoggerFactory.getLogger(classname.class);

そしてそれをそのまま使用します:

logger.info ("butonCLick");
driver.findElement(By.id("blablabla")).click();

これがうまくいくことを願っています。

0