Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
.Veneno.
wechaty
提交
3ba861fc
W
wechaty
项目概览
.Veneno.
/
wechaty
与 Fork 源项目一致
Fork自
wechaty / wechaty
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
W
wechaty
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
3ba861fc
编写于
5月 31, 2017
作者:
Huan (李卓桓)
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix(test): manage timeout better, call driver.quit() if driver fail
上级
cf953eaa
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
32 addition
and
37 deletion
+32
-37
src/puppet-web/browser-driver.ts
src/puppet-web/browser-driver.ts
+29
-37
src/puppet-web/browser.spec.ts
src/puppet-web/browser.spec.ts
+3
-0
未找到文件。
src/puppet-web/browser-driver.ts
浏览文件 @
3ba861fc
...
...
@@ -56,8 +56,6 @@ export class BrowserDriver {
await
this
.
driver
.
manage
()
.
timeouts
()
.
setScriptTimeout
(
WEBDRIVER_TIMEOUT
)
return
}
public
getWebDriver
():
WebDriver
{
...
...
@@ -107,8 +105,9 @@ export class BrowserDriver {
require
(
'
chromedriver
'
)
}
const
customChrome
=
Capabilities
.
chrome
()
.
set
(
'
chromeOptions
'
,
options
)
const
customChrome
=
Capabilities
.
chrome
()
.
set
(
'
chromeOptions
'
,
options
)
// TODO: chromedriver --silent
if
(
!
/^
(
verbose|silly
)
$/i
.
test
(
log
.
level
()))
{
...
...
@@ -156,8 +155,15 @@ export class BrowserDriver {
}
else
{
const
e
=
new
Error
(
'
getChromeDriver() got invalid driver
'
)
log
.
warn
(
'
PuppetWebBrowserDriver
'
,
e
.
message
)
log
.
warn
(
'
PuppetWebBrowserDriver
'
,
'
getChromeDriver() %s
'
,
e
.
message
)
driverError
=
e
try
{
await
driver
.
quit
()
}
catch
(
e
)
{
log
.
warn
(
'
PuppetWebBrowserDriver
'
,
'
getChromeDriver() %s
'
,
e
.
message
)
driverError
=
e
}
}
}
catch
(
e
)
{
...
...
@@ -299,65 +305,52 @@ export class BrowserDriver {
* because we are in state(open, false) state, which will cause Watchdog Reset failure.
* https://travis-ci.org/wechaty/wechaty/jobs/179022657#L3246
*/
const
TIMEOUT
=
7
*
1000
const
TIMEOUT
=
13
*
1000
let
watchdogT
imer
:
NodeJS
.
Timer
|
null
let
t
imer
:
NodeJS
.
Timer
|
null
watchdogTimer
=
setTimeout
(()
=>
{
timer
=
setTimeout
(
_
=>
{
const
e
=
new
Error
(
'
validDriverSession() driver.getSession() timeout(halt?)
'
)
log
.
warn
(
'
PuppetWebBrowserDriver
'
,
e
.
message
)
// record timeout by set timer to null
watchdogTimer
=
null
log
.
verbose
(
'
PuppetWebBrowserDriver
'
,
'
validDriverSession() watchdogTimer timeout
'
)
timer
=
null
// 1. Promise rejected
reject
(
e
)
return
return
reject
(
e
)
},
TIMEOUT
)
log
.
verbose
(
'
PuppetWebBrowserDriver
'
,
'
validDriverSession() getSession()
'
)
try
{
log
.
verbose
(
'
PuppetWebBrowserDriver
'
,
'
validDriverSession() getSession()
'
)
const
driverSession
=
await
driver
.
getSession
()
log
.
verbose
(
'
PuppetWebBrowserDriver
'
,
'
validDriverSession() getSession() done
'
)
if
(
watchdogTimer
)
{
log
.
verbose
(
'
PuppetWebBrowserDriver
'
,
'
validDriverSession() getSession() watchdogTimer cleared
'
)
clearTimeout
(
watchdogTimer
)
watchdogTimer
=
null
}
else
{
const
e
=
new
Error
(
'
watchdog timer not exist, timeout before getSession return?
'
)
log
.
warn
(
'
PuppetWebBrowserDriver
'
,
'
validDriverSession() getSession() %s
'
,
e
.
message
)
throw
e
}
// 2. Promise resolved
resolve
(
driverSession
)
return
// 3. Promise resolved
return
resolve
(
driverSession
)
}
catch
(
e
)
{
log
.
warn
(
'
PuppetWebBrowserDriver
'
,
'
validDriverSession() getSession() catch() rejected: %s
'
,
e
&&
e
.
message
||
e
)
if
(
watchdogTimer
)
{
log
.
verbose
(
'
PuppetWebBrowserDriver
'
,
'
validDriverSession() getSession() catch() watchdog timer exist, will clear it then call reject()
'
)
// 4. Promise rejected
return
reject
(
e
)
// 3. Promise rejected
clearTimeout
(
watchdogTimer
)
watchdogTimer
=
null
}
finally
{
if
(
timer
)
{
log
.
verbose
(
'
PuppetWebBrowserDriver
'
,
'
validDriverSession() getSession() clearing timer
'
)
clearTimeout
(
timer
)
timer
=
null
}
reject
(
e
)
return
}
})
log
.
verbose
(
'
PuppetWebBrowserDriver
'
,
'
validDriverSession() driver.getSession() done()
'
)
if
(
!
session
)
{
if
(
session
)
{
return
true
}
else
{
log
.
verbose
(
'
PuppetWebBrowserDriver
'
,
'
validDriverSession() found an invalid driver
'
)
return
false
}
...
...
@@ -367,7 +360,6 @@ export class BrowserDriver {
return
false
}
return
true
}
public
close
()
{
return
this
.
driver
.
close
()
as
any
as
Promise
<
void
>
}
...
...
src/puppet-web/browser.spec.ts
浏览文件 @
3ba861fc
...
...
@@ -34,4 +34,7 @@ test.serial('init()', async t => {
browser
.
state
.
current
(
'
open
'
,
false
)
t
.
throws
(
browser
.
init
(),
Error
,
'
should throw exception when call init() on a `open`-`ing` state browser
'
)
await
browser
.
quit
()
t
.
pass
(
'
should quited browser
'
)
})
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录