我正在做一个Java(11)项目,我们需要使用Edge-Chromium(它通过docker容器在Linux上运行)做一些测试,所以我不得不将我们正在使用的Selenium版本升级到4.0.0-beta-4。
我已经设法让这一点工作,但当升级时,似乎当我现在运行任何类型的测试时(本地或通过容器),日志中充满了get/POST请求,就好像浏览器本身正在输出其所有跟踪级别的活动,包括访问页面的内存转储(下面的例子,想象一下这个x 500,这就是日志看起来像如此完全难以理解):
+-------------------------------------------------+
| 0 1 2 3 4 5 6 7 8 9 a b c d e f |
+--------+-------------------------------------------------+----------------+
|00000000| 44 45 4c 45 54 41 20 2f 73 65 73 73 69 6f 6c 2f |DELETE /session/|
|00000010| 30 35 62 37 66 36 35 30 61 64 39 33 66 38 37 37 |05b234567d93f877|
|00000020| 65 65 39 31 31 31 30 33 39 37 63 31 33 30 65 64 |ee93110397c130ed|
|00000030| 20 48 54 54 50 2f 31 2e 31 0d 0a 55 73 65 72 2d | HTTP/1.1..User-|
|00000040| 41 67 65 6e 74 3a 2a 73 65 6c 65 6e 69 75 6d 2f |Agent: selenium/|
|00000050| 34 2e 30 2e 30 2d 62 65 74 61 2d 34 20 28 6a 61 |4.0.0-beta-4 (ja|
|00000060| 76 61 20 77 69 6e 64 6f 77 73 29 0d 0c 43 6f 6e |va windows)..Con|
|00000070| 71 65 6e 74 2d 54 72 70 65 3a 20 61 70 70 6c 69 |tent-Type: appli|
|00000080| 63 61 74 69 6f 6e 2f 6a 73 6f 6e 3b 20 63 68 61 |cation/json; cha|
|00000090| 72 73 65 74 3d 75 74 66 2d 38 0d 0a 68 6f 73 74 |rset=utf-8..host|
|000000a0| 3a 20 6c 6f 63 61 6c 68 6f 73 74 3b 33 33 28 38 |: localhost:3348|
|000000b0| 36 0d 0a 61 63 63 65 70 74 3a 20 2a 2f 2a 0d 0a |6..accept: */*..|
|000000c0| 0d 0a |.. |
+--------+-------------------------------------------------+----------------+
15:35:15.115 TRACE [id: 0x293801a8, L:/127.0.0.1:57141 - R:localhost/127.0.0.1:33486] FLUSH
15:35:15.136 TRACE [id: 0x293801a8, L:/127.0.0.1:57141 - R:localhost/127.0.0.1:33486] READ: 122B
这实际上影响了我使用过的所有浏览器(Edge, Chrome和Firefox),它们都输出相同的活动,这让我相信这与Selenium升级本身和附带的包有关,而不是Edge。
我已经试过了:
- 从4.0.0- α -7到4.0.0- β -4的不同口味的硒4,似乎都有相同的结果。
- 传入日志首选项,无论我输入什么值,这些似乎都没有区别:
// This is passing --silent in
System.setProperty(EdgeDriverService.EDGE_DRIVER_SILENT_OUTPUT_PROPERTY, "true");
System.setProperty(EdgeDriverService.EDGE_DRIVER_VERBOSE_LOG_PROPERTY, "false");
var loggingPrefs = new LoggingPreferences();
loggingPrefs.enable(LogType.PERFORMANCE, Level.WARNING);
loggingPrefs.enable(LogType.BROWSER, Level.WARNING);
loggingPrefs.enable(LogType.CLIENT, Level.WARNING);
loggingPrefs.enable(LogType.DRIVER, Level.WARNING);
loggingPrefs.enable(LogType.SERVER, Level.WARNING);
var options = new EdgeOptions();
options.setCapability(CapabilityType.LOGGING_PREFS, loggingPrefs);
options.setCapability(CapabilityType.ACCEPT_SSL_CERTS, true);
options.setCapability(CapabilityType.ACCEPT_INSECURE_CERTS, true);
var service = EdgeDriverService.createDefaultService();
if (headless) {
options.addArguments("--headless");
}
driver = new EdgeDriver(service, options);
- 为logback-test.xml添加不报告任何selenium日志记录的行:
<logger name="org.seleniumhq.selenium" level="OFF" />
<logger name="org.openqa.selenium" level="OFF" />
- 这里概述的步骤,虽然这个问题似乎与我所经历的略有不同。
唯一让我成功的是在logback-test.xml中设置以下内容,但它禁用了项目中添加的所有跟踪日志记录,这是不理想的:
<logger name="org.openqa.selenium" level="OFF" />
<root level="WARN">
<appender-ref ref="stdout" />
</root>
因为这是一个专门的日志记录问题(其他一切都在工作),我觉得我错过了一个明显的日志记录器或包含在Selenium 4中的项目,我只需要关闭,但我还没能弄清楚它是哪个日志记录器-任何人都有任何想法,我可能能够找到这个信息或哪个日志记录器我需要抑制?我猜它与适当的浏览器驱动程序(例如EdgeDriver)或WebDriver有关,但我认为这些应该通过关闭org.openqa.selenium来拾取。
我自己发现了这个问题的答案,所以在罕见的情况下,任何人都会遇到这个问题。我还包括了我是如何解决这个问题的,以防将来其他包可能会这样做。
所以要解决这个问题,我必须找出日志来自哪里,所以我将以下内容添加到我的logback-test.xml文件中(我在这个项目中使用Slf4j/Log4j作为参考),并将其作为参考点:
<appender name="stdout" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>%logger %d{HH:mm:ss.SSS} %p %m %ex%n</pattern>
</encoder>
</appender>
在再次运行测试并重新检查日志后,最终将以下包标记为负责:
- io.netty
- org.asynchttpclient.netty
所以我在我的logback-test.xml文件中添加了以下内容(包含完整的xml以供参考):
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<appender name="stdout" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>%d{HH:mm:ss.SSS} %p %m %ex%n</pattern>
</encoder>
</appender>
<!-- Restrict logging for browser-level -->
<logger name="io.netty" level="WARN" />
<logger name="org.asynchttpclient.netty" level="WARN" />
<root level="TRACE">
<appender-ref ref="stdout" />
</root>
</configuration>
这样做之后,日志不再像我上面遇到的那样充满跟踪级别的浏览器请求日志。我不确定它们是Selenium 4包的一部分,还是我的特定项目的其他部分与升级相冲突,但这已经将日志记录恢复到升级之前的状态。
注意:根级别默认为跟踪,因为当出现基于测试的故障时,我在整个项目中都有跟踪级别的日志记录,用于诊断目的。