Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
3056c983
V
vscode
项目概览
xxadev
/
vscode
与 Fork 源项目一致
从无法访问的项目Fork
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
V
vscode
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
3056c983
编写于
9月 05, 2018
作者:
J
Joao Moreno
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
more ipc tests
上级
4cb81879
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
37 addition
and
3 deletion
+37
-3
src/vs/base/parts/ipc/test/node/ipc.test.ts
src/vs/base/parts/ipc/test/node/ipc.test.ts
+37
-3
未找到文件。
src/vs/base/parts/ipc/test/node/ipc.test.ts
浏览文件 @
3056c983
...
...
@@ -11,6 +11,7 @@ import { Emitter, toNativePromise, Event } from 'vs/base/common/event';
import
{
TPromise
}
from
'
vs/base/common/winjs.base
'
;
import
{
CancellationToken
,
CancellationTokenSource
}
from
'
vs/base/common/cancellation
'
;
import
{
canceled
}
from
'
vs/base/common/errors
'
;
import
{
timeout
}
from
'
vs/base/common/async
'
;
class
QueueProtocol
implements
IMessagePassingProtocol
{
...
...
@@ -101,10 +102,15 @@ interface ITestService {
error
(
message
:
string
):
TPromise
<
void
>
;
neverComplete
():
TPromise
<
void
>
;
neverCompleteCT
(
cancellationToken
:
CancellationToken
):
TPromise
<
void
>
;
pong
:
Event
<
string
>
;
}
class
TestService
implements
ITestService
{
private
_pong
=
new
Emitter
<
string
>
();
readonly
pong
=
this
.
_pong
.
event
;
marco
():
TPromise
<
string
>
{
return
TPromise
.
wrap
(
'
polo
'
);
}
...
...
@@ -124,6 +130,10 @@ class TestService implements ITestService {
return
new
TPromise
((
_
,
e
)
=>
cancellationToken
.
onCancellationRequested
(()
=>
e
(
canceled
())));
}
ping
(
msg
:
string
):
void
{
this
.
_pong
.
fire
(
msg
);
}
}
interface
ITestChannel
extends
IChannel
{
...
...
@@ -132,6 +142,8 @@ interface ITestChannel extends IChannel {
call
(
command
:
'
neverComplete
'
):
TPromise
<
void
>
;
call
(
command
:
'
neverCompleteCT
'
,
arg
:
undefined
,
cancellationToken
:
CancellationToken
):
TPromise
<
void
>
;
call
<
T
>
(
command
:
string
,
arg
?:
any
,
cancellationToken
?:
CancellationToken
):
TPromise
<
T
>
;
listen
(
event
:
'
pong
'
):
Event
<
string
>
;
listen
<
T
>
(
event
:
string
,
arg
?:
any
):
Event
<
T
>
;
}
...
...
@@ -149,8 +161,9 @@ class TestChannel implements ITestChannel {
}
}
listen
<
T
>
(
event
:
string
,
arg
?:
any
):
Event
<
T
>
{
listen
(
event
:
string
,
arg
?:
any
):
Event
<
any
>
{
switch
(
event
)
{
case
'
pong
'
:
return
this
.
service
.
pong
;
default
:
throw
new
Error
(
'
not implemented
'
);
}
}
...
...
@@ -158,6 +171,10 @@ class TestChannel implements ITestChannel {
class
TestChannelClient
implements
ITestService
{
get
pong
():
Event
<
string
>
{
return
this
.
channel
.
listen
(
'
pong
'
);
}
constructor
(
private
channel
:
ITestChannel
)
{
}
marco
():
TPromise
<
string
>
{
...
...
@@ -198,10 +215,11 @@ suite('Base IPC', function () {
suite
(
'
one to one
'
,
function
()
{
let
server
:
IPCServer
;
let
client
:
IPCClient
;
let
service
:
TestService
;
let
ipcService
:
ITestService
;
setup
(
function
()
{
const
service
=
new
TestService
();
service
=
new
TestService
();
const
testServer
=
new
TestIPCServer
();
server
=
testServer
;
...
...
@@ -280,8 +298,24 @@ suite('Base IPC', function () {
return
promise
;
});
});
test
(
'
listen to events
'
,
async
function
()
{
const
messages
=
[];
ipcService
.
pong
(
msg
=>
messages
.
push
(
msg
));
await
timeout
(
0
);
assert
.
deepEqual
(
messages
,
[]);
service
.
ping
(
'
hello
'
);
await
timeout
(
0
);
assert
.
deepEqual
(
messages
,
[
'
hello
'
]);
service
.
ping
(
'
world
'
);
await
timeout
(
0
);
assert
.
deepEqual
(
messages
,
[
'
hello
'
,
'
world
'
]);
});
});
suite
(
'
getDelayedChannel
'
,
function
()
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录