Firefox через GeckoDriver создает исключение для .Quit () в Selenium 3.0.1
Контекст: Firefox 50.0.2, 64-разрядная версия, C #, Visual Studio 2015, Windows Server 2012 R2, Azure, ClearScript.V8.5.4.7, Selenium.Mozilla.Firefox.Webdriver.0.6.0.1, Selenium.WebDriver.GeckoDriver.Win64.0.11 0,1
Я использую ClearScript, чтобы обернуть объекты Selenium для использования в JavaScript, а именно
static JScriptEngine JSengine = null;
...
JSengine = new JScriptEngine(WindowsScriptEngineFlags.EnableDebugging | WindowsScriptEngineFlags.EnableJITDebugging);
...
JSengine.AddHostType("CSFirefoxDriver", typeof(FirefoxDriver));
JSengine.AddHostType("CSFirefoxOptions", typeof(FirefoxOptions));
JSengine.AddHostType("CSFirefoxDriverService", typeof(FirefoxDriverService));
Я создаю экземпляр Firefox, используя следующий JS
var driverService = CSFirefoxDriverService.CreateDefaultService();
driverService.FirefoxBinaryPath = "C:\\Program Files\\Mozilla Firefox\\firefox.exe";
driverService.HideCommandPromptWindow = true;
driverService.SuppressInitialDiagnosticInformation = true;
var options = new CSFirefoxOptions();
driver = new CSFirefoxDriver(driverService, options, CSTimeSpan.FromSeconds(30));
Соответствующий код выхода / удаления
try {
driver.Quit();
} catch (E) {
T.Error().Send("driver.Quit() failed.");
}
try {
driver.Dispose();
} catch (E) {
T.Error().Send("driver.Dispose() failed.");
}
(T является объектом регистрации)
Когда вызов метода .Quit () выполняется, я получаю следующий диалог.
Если я закомментирую .Quit (), то получу то же самое для .Dispose ().
Другие форумы предлагали отключить аппаратное ускорение в настройках Firefox. Это не имеет никакого значения вообще.
Существует также проблема наgeckodriver Форум об этом требует какого-то исправления. Это, конечно, не исправлено сейчас.
Журнал событий Windows здесь не особенно полезен, а именно
<Event xmlns="http://schemas.microsoft.com/win/2004/08/events/event">
<System>
<Provider Name="Application Popup" Guid="{47BFA2B7-BD54-4FAC-B70B-29021084CA8F}" />
<EventID>26</EventID>
<Version>0</Version>
<Level>4</Level>
<Task>0</Task>
<Opcode>0</Opcode>
<Keywords>0x8000000000000000</Keywords>
<TimeCreated SystemTime="2016-12-13T03:16:28.936810900Z" />
<EventRecordID>1227958</EventRecordID>
<Correlation />
<Execution ProcessID="5856" ThreadID="11580" />
<Channel>System</Channel>
<Computer>VM1-SQLWEB-W12</Computer>
<Security UserID="S-1-5-18" />
</System>
<EventData>
<Data Name="Caption">firefox.exe - Application Error</Data>
<Data Name="Message">The exception Breakpoint A breakpoint has been reached. (0x80000003) occurred in the application at location 0x880f00ef. Click on OK to terminate the program Click on CANCEL to debug the program</Data>
</EventData>
</Event>
Куда мне идти отсюда? Я могу вернуться к PhantomJS, пока не будет найдено исправление.