Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
weixin_46011646
wechaty
提交
f932dea8
W
wechaty
项目概览
weixin_46011646
/
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,发现更多精彩内容 >>
提交
f932dea8
编写于
11月 26, 2016
作者:
Huan (李卓桓)
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
more check for exception/rejection
上级
e5b1ad6a
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
42 addition
and
29 deletion
+42
-29
src/puppet-web/browser-driver.ts
src/puppet-web/browser-driver.ts
+13
-5
src/puppet-web/event.ts
src/puppet-web/event.ts
+1
-1
test/puppet-web/bridge.spec.ts
test/puppet-web/bridge.spec.ts
+28
-23
未找到文件。
src/puppet-web/browser-driver.ts
浏览文件 @
f932dea8
...
...
@@ -239,27 +239,35 @@ export class BrowserDriver {
try
{
log
.
verbose
(
'
PuppetWebBrowserDriver
'
,
'
valid() getSession()
'
)
const
session
=
await
new
Promise
((
resolve
,
reject
)
=>
{
// reject
const
timer
=
setTimeout
(()
=>
{
const
e
=
new
Error
(
'
valid() driver.getSession() timeout(halt?)
'
)
log
.
warn
(
'
PuppetWebBrowserDriver
'
,
e
.
message
)
reject
(
e
)
// 1. Promise rejected
return
reject
(
e
)
},
67
*
1000
)
// resolve
driver
.
getSession
()
.
then
(
session
=>
{
log
.
verbose
(
'
PuppetWebBrowserDriver
'
,
'
valid() getSession() done
'
)
clearTimeout
(
timer
)
resolve
(
session
)
// 2. Promise resolved
return
resolve
(
session
)
})
.
catch
(
e
=>
{
log
.
warn
(
'
PuppetWebBrowserDriver
'
,
'
valid() getSession() rejected: %s
'
,
e
&&
e
.
message
||
e
)
// 3. Promise rejected
return
reject
(
e
)
})
})
log
.
verbose
(
'
PuppetWebBrowserDriver
'
,
'
valid() driver.getSession() done(
out
)
'
)
log
.
verbose
(
'
PuppetWebBrowserDriver
'
,
'
valid() driver.getSession() done()
'
)
if
(
!
session
)
{
log
.
verbose
(
'
PuppetWebBrowserDriver
'
,
'
valid() found an invalid driver
'
)
...
...
src/puppet-web/event.ts
浏览文件 @
f932dea8
...
...
@@ -251,7 +251,7 @@ async function onServerLogin(this: PuppetWeb, data, attempt = 0): Promise<void>
this
.
userId
=
await
this
.
bridge
.
getUserName
()
if
(
!
this
.
userId
)
{
log
.
verbose
(
'
PuppetWebEvent
'
,
'
onServerLogin: browser not full loaded(%d), retry later
'
,
attempt
)
log
.
verbose
(
'
PuppetWebEvent
'
,
'
onServerLogin: browser not full
y
loaded(%d), retry later
'
,
attempt
)
setTimeout
(
onServerLogin
.
bind
(
this
,
data
,
++
attempt
),
500
)
return
}
...
...
test/puppet-web/bridge.spec.ts
浏览文件 @
f932dea8
...
...
@@ -54,36 +54,41 @@ test('retryPromise()', async t => {
})
test
(
'
WechatyBro.ding()
'
,
async
t
=>
{
const
PORT
=
58788
const
browser
=
new
Browser
()
t
.
truthy
(
browser
,
'
should instanciated a browser
'
)
try
{
const
PORT
=
58788
const
mockPuppet
=
{
browser
:
browser
}
const
bridge
=
new
Bridge
(
mockPuppet
as
PuppetWeb
,
PORT
)
t
.
truthy
(
bridge
,
'
should instanciated a bridge with mocked puppet
'
)
const
browser
=
new
Browser
()
t
.
truthy
(
browser
,
'
should instanciated a browser
'
)
await
browser
.
init
()
t
.
pass
(
'
should instanciated a browser
'
)
const
mockPuppet
=
{
browser
:
browser
}
const
bridge
=
new
Bridge
(
mockPuppet
as
PuppetWeb
,
PORT
)
t
.
truthy
(
bridge
,
'
should instanciated a bridge with mocked puppet
'
)
await
browser
.
open
()
t
.
pass
(
'
should open success
'
)
await
browser
.
init
()
t
.
pass
(
'
should instanciated a browser
'
)
await
bridge
.
inject
()
t
.
pass
(
'
should injected WechatyBro
'
)
await
browser
.
open
()
t
.
pass
(
'
should open success
'
)
const
retDing
=
await
bridge
.
execute
(
'
return WechatyBro.ding()
'
)
t
.
is
(
retDing
,
'
dong
'
,
'
should got dong after execute WechatyBro.ding()
'
)
await
bridge
.
inject
(
)
t
.
pass
(
'
should injected WechatyBro
'
)
// @deprecated
// const retReady = await b.execute('return WechatyBro.isReady()')
// t.is(typeof retReady, 'boolean', 'should got a boolean return after execute WechatyBro.isReady()')
const
retDing
=
await
bridge
.
execute
(
'
return WechatyBro.ding()
'
)
t
.
is
(
retDing
,
'
dong
'
,
'
should got dong after execute WechatyBro.ding()
'
)
const
retCode
=
await
bridge
.
proxyWechaty
(
'
isLogin
'
)
t
.
is
(
typeof
retCode
,
'
boolean
'
,
'
should got a boolean after call proxyWechaty(isLogin)
'
)
// @deprecated
// const retReady = await b.execute('return WechatyBro.isReady()')
// t.is(typeof retReady, 'boolean', 'should got a boolean return after execute WechatyBro.isReady()')
await
bridge
.
quit
()
t
.
pass
(
'
b.quit()
'
)
await
browser
.
quit
()
t
.
pass
(
'
browser.quit()
'
)
const
retCode
=
await
bridge
.
proxyWechaty
(
'
isLogin
'
)
t
.
is
(
typeof
retCode
,
'
boolean
'
,
'
should got a boolean after call proxyWechaty(isLogin)
'
)
await
bridge
.
quit
()
t
.
pass
(
'
b.quit()
'
)
await
browser
.
quit
()
t
.
pass
(
'
browser.quit()
'
)
}
catch
(
err
)
{
t
.
fail
(
'
exception:
'
+
err
.
message
)
}
})
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录