Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
.Veneno.
wechaty
提交
f17d153f
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,发现更多精彩内容 >>
提交
f17d153f
编写于
6月 10, 2016
作者:
Huan (李卓桓)
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix unit tests for puppet-web
上级
919e8515
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
41 addition
and
41 deletion
+41
-41
src/puppet-web.js
src/puppet-web.js
+4
-1
test/puppet-web-spec.js
test/puppet-web-spec.js
+37
-40
未找到文件。
src/puppet-web.js
浏览文件 @
f17d153f
...
...
@@ -116,7 +116,7 @@ class PuppetWeb extends Puppet {
return
co
.
call
(
this
,
function
*
()
{
yield
this
.
browser
.
init
()
yield
this
.
browser
.
open
()
yield
this
.
browser
.
open
(
'
https://res.wx.qq.com/zh_CN/htmledition/v2/images/icon/ico_loading28a2f7.gif
'
)
yield
this
.
checkSession
()
yield
this
.
loadSession
().
catch
(
e
=>
{
log
.
verbose
(
'
PuppetWeb
'
,
'
loadSession rejected: %s
'
,
e
)
/* fail safe */
})
yield
this
.
checkSession
()
...
...
@@ -270,6 +270,9 @@ class PuppetWeb extends Puppet {
return
this
.
send
(
m
)
}
/**
* logout from browser, then server will emit `logout` event
*/
logout
()
{
return
this
.
bridge
.
logout
()
}
getContact
(
id
)
{
return
this
.
bridge
.
getContact
(
id
)
}
...
...
test/puppet-web-spec.js
浏览文件 @
f17d153f
...
...
@@ -40,22 +40,22 @@ function dingSocket(server) {
})
}
false
&&
test
(
'
PuppetWeb smoke testing
'
,
function
(
t
)
{
let
pw
co
(
function
*
()
{
pw
=
new
PuppetWeb
({
port
:
PORT
,
head
:
HEAD
,
session
:
SESSION
})
t
.
ok
(
pw
,
'
new PuppetWeb
'
)
test
(
'
PuppetWeb smoke testing
'
,
function
(
t
)
{
let
pw
=
new
PuppetWeb
({
port
:
PORT
,
head
:
HEAD
,
session
:
SESSION
})
t
.
ok
(
pw
,
'
new PuppetWeb
'
)
co
(
function
*
()
{
yield
pw
.
init
()
t
.
pass
(
'
pw full inited
'
)
t
.
equal
(
pw
.
isLogined
()
,
false
,
'
instanc
e not logined
'
)
t
.
equal
(
pw
.
logined
()
,
false
,
'
should b
e not logined
'
)
// XXX find a better way to mock...
pw
.
bridge
.
getUserName
=
function
()
{
return
Promise
.
resolve
(
'
mockedUserName
'
)
}
pw
.
bridge
.
getUserName
=
function
()
{
return
Promise
.
resolve
(
'
mockedUserName
'
)
}
pw
.
getContact
=
function
()
{
return
Promise
.
resolve
(
'
dummy
'
)
}
const
p1
=
new
Promise
((
resolve
)
=>
{
pw
.
once
(
'
login
'
,
r
=>
{
t
.
equal
(
pw
.
isLogined
()
,
true
,
'
logined after
login event
'
)
t
.
equal
(
pw
.
logined
()
,
true
,
'
should be logined after emit
login event
'
)
resolve
()
})
})
...
...
@@ -64,51 +64,49 @@ false && test('PuppetWeb smoke testing', function(t) {
const
p2
=
new
Promise
((
resolve
)
=>
{
pw
.
once
(
'
logout
'
,
r
=>
{
t
.
equal
(
pw
.
isLogined
()
,
false
,
'
logouted after logout event
'
)
resolve
()
process
.
nextTick
(()
=>
{
// wait to next tick for pw clean logined user status
// log.verbose('TestPuppetWeb', 'on(logout) received %s, islogined: %s', r, pw.logined())
t
.
equal
(
pw
.
logined
()
,
false
,
'
logouted after logout event
'
)
resolve
()
})
})
})
pw
.
server
.
emit
(
'
logout
'
)
yield
p2
})
.
catch
(
e
=>
t
.
fail
(
e
))
// Reject
.
then
(
r
=>
{
// Finally 1
log
.
warn
(
'
TestPuppetWeb
'
,
'
finally()
'
)
return
pw
.
quit
()
// log.warn('TestPuppetWeb', 'finally()')
pw
.
quit
()
.
then
(
t
.
end
)
})
.
then
(
r
=>
{
t
.
end
()
})
// Finally 2
.
catch
(
e
=>
t
.
fail
(
e
))
// Exception
})
// WTF?
false
&&
test
(
'
Puppet Web server/browser communication
'
,
function
(
t
)
{
let
pw2
co
(
function
*
()
{
pw
=
new
PuppetWeb
({
port
:
PORT
,
head
:
HEAD
,
session
:
SESSION
})
t
.
ok
(
pw2
,
'
new PuppetWeb
'
)
yield
Promise
.
resolve
()
test
(
'
Puppet Web server/browser communication
'
,
function
(
t
)
{
let
pw
=
new
PuppetWeb
({
port
:
PORT
,
head
:
HEAD
,
session
:
SESSION
})
t
.
ok
(
pw
,
'
new PuppetWeb
'
)
yield
pw2
.
init
()
t
.
pass
(
'
pw2 inited
'
)
co
(
function
*
()
{
yield
pw
.
init
()
t
.
pass
(
'
pw inited
'
)
const
retSocket
=
yield
dingSocket
(
pw
2
.
server
)
const
retSocket
=
yield
dingSocket
(
pw
.
server
)
t
.
equal
(
retSocket
,
'
dong
'
,
'
dingSocket got dong
'
)
})
.
catch
(
e
=>
{
.
catch
(
e
=>
{
// Reject
log
.
warn
(
'
TestPuppetWeb
'
,
'
error: %s
'
,
e
)
t
.
fail
(
e
)
})
// Reject
})
.
then
(
r
=>
{
// Finally
pw
2
.
quit
()
t
.
end
(
)
pw
.
quit
()
.
then
(
t
.
end
)
})
.
catch
(
e
=>
{
t
.
fail
(
e
)
})
// Exception
})
false
&&
test
(
'
Puppet Web WTF server/browser communication
'
,
function
(
t
)
{
/*
false && test('Puppet Web promise version of server/browser communication', function(t) {
pw = new PuppetWeb({port: PORT, head: HEAD, session: SESSION})
t.ok(pw, 'new PuppetWeb')
...
...
@@ -140,6 +138,7 @@ false && test('Puppet Web WTF server/browser communication', function(t) {
throw e
}) // Exception
})
*/
test
(
'
Puppet Web browser session save & load
'
,
function
(
t
)
{
let
pw
=
new
PuppetWeb
({
port
:
PORT
,
head
:
HEAD
,
session
:
SESSION
})
...
...
@@ -203,14 +202,6 @@ test('Puppet Web browser session save & load', function(t) {
const
cookieAfterQuit
=
yield
pw
.
browser
.
driver
.
manage
().
getCookie
(
EXPECTED_COOKIE
.
name
)
t
.
equal
(
cookieAfterQuit
.
name
,
EXPECTED_COOKIE
.
name
,
'
cookie from getCookie() after browser quit, should load the right cookie back
'
)
})
.
catch
(
e
=>
{
// Reject
log
.
warn
(
'
TestPuppetWeb
'
,
'
error: %s
'
,
e
)
t
.
fail
(
e
)
})
.
then
(
r
=>
{
// Finally
pw
.
quit
()
t
.
end
()
// clean
require
(
'
fs
'
).
unlink
(
SESSION
,
err
=>
{
if
(
err
)
{
...
...
@@ -218,6 +209,12 @@ test('Puppet Web browser session save & load', function(t) {
}
})
})
.
catch
(
e
=>
{
// Reject
log
.
warn
(
'
TestPuppetWeb
'
,
'
error: %s
'
,
e
)
t
.
fail
(
e
)
})
.
then
(
r
=>
{
// Finally
pw
.
quit
().
then
(
t
.
end
)
})
.
catch
(
e
=>
{
t
.
fail
(
e
)
})
// Exception
})
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录