Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
.Veneno.
wechaty
提交
62ce6183
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,发现更多精彩内容 >>
提交
62ce6183
编写于
5月 22, 2017
作者:
Huan (李卓桓)
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix(test): clearTimeout for prevent race condition(?)
上级
61d82006
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
15 addition
and
21 deletion
+15
-21
test/puppet-web/puppet-web.spec.ts
test/puppet-web/puppet-web.spec.ts
+15
-21
未找到文件。
test/puppet-web/puppet-web.spec.ts
浏览文件 @
62ce6183
...
...
@@ -10,18 +10,9 @@ import { test } from 'ava'
import
{
Config
,
log
,
}
from
'
../../src/config
'
// import { Message } from '../../src/message'
}
from
'
../../src/config
'
import
PuppetWeb
from
'
../../src/puppet-web
'
import
Server
from
'
../../src/puppet-web/server
'
// import { spy } from 'sinon'
// process.on('unhandledRejection', (reason, p) => {
// console.log('!!!!!!! unhandledRejection in puppet-web.spec.ts')
// console.log('Unhandled Rejection at: Promise', p, 'reason:', reason)
// console.log('!!!!!!!')
// })
import
PuppetWebServer
from
'
../../src/puppet-web/server
'
/**
* the reason why use `test.serial` here is:
...
...
@@ -56,25 +47,25 @@ test.serial('login/logout events', async t => {
})
test
.
serial
(
'
server/browser socketio ding
'
,
async
t
=>
{
const
p
w
=
new
PuppetWeb
()
t
.
truthy
(
p
w
,
'
should instantiated a PuppetWeb
'
)
const
p
uppet
=
new
PuppetWeb
()
t
.
truthy
(
p
uppet
,
'
should instantiated a PuppetWeb
'
)
Config
.
puppetInstance
(
p
w
)
Config
.
puppetInstance
(
p
uppet
)
const
EXPECTED_DING_DATA
=
'
dingdong
'
try
{
await
p
w
.
init
()
await
p
uppet
.
init
()
t
.
pass
(
'
should be inited
'
)
const
ret
=
await
dingSocket
(
p
w
.
server
)
const
ret
=
await
dingSocket
(
p
uppet
.
server
)
t
.
is
(
ret
,
EXPECTED_DING_DATA
,
'
should got EXPECTED_DING_DATA after resolved dingSocket()
'
)
}
catch
(
e
)
{
t
.
fail
(
e
&&
e
.
message
||
e
||
'
unknown exception???
'
)
}
try
{
await
p
w
.
quit
()
await
p
uppet
.
quit
()
}
catch
(
err
)
{
t
.
fail
(
err
.
message
)
}
...
...
@@ -83,17 +74,17 @@ test.serial('server/browser socketio ding', async t => {
/////////////////////////////////////////////////////////////////////////////
function
dingSocket
(
server
:
Server
)
{
function
dingSocket
(
server
:
PuppetWeb
Server
)
{
const
maxTime
=
60000
// 60s
const
waitTime
=
3000
let
totalTime
=
0
return
new
Promise
((
resolve
,
reject
)
=>
{
log
.
verbose
(
'
TestPuppetWeb
'
,
'
dingSocket()
'
)
setTimeout
(
_
=>
{
re
turn
re
ject
(
'
dingSocket() no response timeout after
'
+
2
*
maxTime
)
const
timeoutTimer
=
setTimeout
(
_
=>
{
reject
(
'
dingSocket() no response timeout after
'
+
2
*
maxTime
)
},
2
*
maxTime
)
.
unref
()
timeoutTimer
.
unref
()
testDing
()
return
...
...
@@ -113,7 +104,10 @@ test.serial('server/browser socketio ding', async t => {
log
.
silly
(
'
TestPuppetWeb
'
,
'
dingSocket() server.socketClient: %s
'
,
server
.
socketClient
)
server
.
socketClient
.
once
(
'
dong
'
,
data
=>
{
log
.
verbose
(
'
TestPuppetWeb
'
,
'
socket recv event dong:
'
+
data
)
clearTimeout
(
timeoutTimer
)
return
resolve
(
data
)
})
server
.
socketClient
.
emit
(
'
ding
'
,
EXPECTED_DING_DATA
)
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录