Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
1ab76005
V
vscode
项目概览
掘金者说
/
vscode
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
V
vscode
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
未验证
提交
1ab76005
编写于
5月 07, 2021
作者:
J
Johannes Rieken
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
even more strict assertions in flaky integration tests
上级
f7f1dbd5
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
33 addition
and
19 deletion
+33
-19
extensions/vscode-api-tests/src/singlefolder-tests/notebook.test.ts
.../vscode-api-tests/src/singlefolder-tests/notebook.test.ts
+33
-19
未找到文件。
extensions/vscode-api-tests/src/singlefolder-tests/notebook.test.ts
浏览文件 @
1ab76005
...
...
@@ -32,11 +32,20 @@ class Kernel {
readonly
controller
:
vscode
.
NotebookController
;
readonly
associatedNotebooks
=
new
Set
<
string
>
();
constructor
(
id
:
string
,
label
:
string
)
{
this
.
controller
=
vscode
.
notebook
.
createNotebookController
(
id
,
'
notebookCoreTest
'
,
label
);
this
.
controller
.
executeHandler
=
this
.
_execute
.
bind
(
this
);
this
.
controller
.
hasExecutionOrder
=
true
;
this
.
controller
.
supportedLanguages
=
[
'
typescript
'
,
'
javascript
'
];
this
.
controller
.
onDidChangeNotebookAssociation
(
e
=>
{
if
(
e
.
selected
)
{
this
.
associatedNotebooks
.
add
(
e
.
notebook
.
uri
.
toString
());
}
else
{
this
.
associatedNotebooks
.
delete
(
e
.
notebook
.
uri
.
toString
());
}
});
}
protected
async
_execute
(
cells
:
vscode
.
NotebookCell
[]):
Promise
<
void
>
{
...
...
@@ -68,12 +77,13 @@ function getFocusedCell(editor?: vscode.NotebookEditor) {
return
editor
?
editor
.
document
.
cellAt
(
editor
.
selections
[
0
].
start
)
:
undefined
;
}
async
function
assertKernel
(
controller
:
vscode
.
NotebookController
):
Promise
<
void
>
{
async
function
assertKernel
(
kernel
:
Kernel
,
notebook
:
vscode
.
NotebookDocument
):
Promise
<
void
>
{
const
success
=
await
vscode
.
commands
.
executeCommand
(
'
notebook.selectKernel
'
,
{
extension
:
'
vscode.vscode-api-tests
'
,
id
:
controller
.
id
id
:
kernel
.
controller
.
id
});
assert
.
ok
(
success
,
`expected selected kernel to be
${
controller
.
id
}
`
);
assert
.
ok
(
success
,
`expected selected kernel to be
${
kernel
.
controller
.
id
}
`
);
assert
.
ok
(
kernel
.
associatedNotebooks
.
has
(
notebook
.
uri
.
toString
()));
}
suite
(
'
Notebook API tests
'
,
function
()
{
...
...
@@ -694,13 +704,14 @@ suite('Notebook API tests', function () {
});
test
(
'
cell execute and select kernel
'
,
async
function
()
{
const
resource
=
await
createRandomNotebookFile
();
await
vscode
.
commands
.
executeCommand
(
'
vscode.openWith
'
,
resource
,
'
notebookCoreTest
'
);
assert
.
strictEqual
(
vscode
.
window
.
activeNotebookEditor
!==
undefined
,
true
,
'
notebook first
'
);
const
editor
=
vscode
.
window
.
activeNotebookEditor
!
;
const
notebook
=
await
openRandomNotebookDocument
();
const
editor
=
await
vscode
.
window
.
showNotebookDocument
(
notebook
);
assert
.
strictEqual
(
vscode
.
window
.
activeNotebookEditor
===
editor
,
true
,
'
notebook first
'
);
const
cell
=
editor
.
document
.
cellAt
(
0
);
await
withEvent
<
vscode
.
NotebookCellOutputsChangeEvent
>
(
vscode
.
notebook
.
onDidChangeCellOutputs
,
async
(
event
)
=>
{
await
assertKernel
(
kernel1
,
notebook
);
await
vscode
.
commands
.
executeCommand
(
'
notebook.cell.execute
'
);
await
event
;
assert
.
strictEqual
(
cell
.
outputs
.
length
,
1
,
'
should execute
'
);
// runnable, it worked
...
...
@@ -712,7 +723,7 @@ suite('Notebook API tests', function () {
});
await
withEvent
<
vscode
.
NotebookCellOutputsChangeEvent
>
(
vscode
.
notebook
.
onDidChangeCellOutputs
,
async
(
event
)
=>
{
await
assertKernel
(
kernel2
.
controller
);
await
assertKernel
(
kernel2
,
notebook
);
await
vscode
.
commands
.
executeCommand
(
'
notebook.cell.execute
'
);
await
event
;
assert
.
strictEqual
(
cell
.
outputs
.
length
,
1
,
'
should execute
'
);
// runnable, it worked
...
...
@@ -747,12 +758,12 @@ suite('Notebook API tests', function () {
}
};
const
resource
=
await
createRandomNotebookFile
();
const
editor
=
await
vscode
.
window
.
showNotebookDocument
(
resource
);
const
notebook
=
await
openRandomNotebookDocument
();
const
editor
=
await
vscode
.
window
.
showNotebookDocument
(
notebook
);
const
cell
=
editor
.
document
.
cellAt
(
0
);
await
assertKernel
(
cancelableKernel
.
controller
);
await
withEvent
<
vscode
.
NotebookCellOutputsChangeEvent
>
(
vscode
.
notebook
.
onDidChangeCellOutputs
,
async
(
event
)
=>
{
await
assertKernel
(
cancelableKernel
,
notebook
);
assert
.
ok
(
editor
===
vscode
.
window
.
activeNotebookEditor
);
await
vscode
.
commands
.
executeCommand
(
'
notebook.cell.execute
'
);
await
vscode
.
commands
.
executeCommand
(
'
notebook.cell.cancelExecution
'
);
...
...
@@ -791,13 +802,12 @@ suite('Notebook API tests', function () {
}
};
const
resource
=
await
createRandomNotebookFile
();
const
editor
=
await
vscode
.
window
.
showNotebookDocument
(
resource
);
const
notebook
=
await
openRandomNotebookDocument
();
const
editor
=
await
vscode
.
window
.
showNotebookDocument
(
notebook
);
const
cell
=
editor
.
document
.
cellAt
(
0
);
await
assertKernel
(
interruptableKernel
.
controller
);
await
withEvent
<
vscode
.
NotebookCellOutputsChangeEvent
>
(
vscode
.
notebook
.
onDidChangeCellOutputs
,
async
(
event
)
=>
{
await
assertKernel
(
interruptableKernel
,
notebook
);
assert
.
ok
(
editor
===
vscode
.
window
.
activeNotebookEditor
);
await
vscode
.
commands
.
executeCommand
(
'
notebook.cell.execute
'
);
await
vscode
.
commands
.
executeCommand
(
'
notebook.cell.cancelExecution
'
);
...
...
@@ -1134,6 +1144,9 @@ suite('Notebook API tests', function () {
});
test
(
'
Output changes are applied once the promise resolves
'
,
async
function
()
{
let
called
=
false
;
const
verifyOutputSyncKernel
=
new
class
extends
Kernel
{
constructor
()
{
...
...
@@ -1150,14 +1163,15 @@ suite('Notebook API tests', function () {
assert
.
strictEqual
(
cell
.
notebook
.
cellAt
(
0
).
outputs
.
length
,
1
);
assert
.
deepStrictEqual
(
cell
.
notebook
.
cellAt
(
0
).
outputs
[
0
].
outputs
[
0
].
value
,
[
'
Some output
'
]);
task
.
end
({});
called
=
true
;
}
};
const
resource
=
await
createRandomNotebookFile
();
await
vscode
.
commands
.
executeCommand
(
'
vscode.openWith
'
,
resource
,
'
notebookCoreTest
'
);
await
assertKernel
(
verifyOutputSyncKernel
.
controller
);
const
notebook
=
await
openRandomNotebookDocument
();
await
vscode
.
window
.
showNotebookDocument
(
notebook
);
await
assertKernel
(
verifyOutputSyncKernel
,
notebook
);
await
vscode
.
commands
.
executeCommand
(
'
notebook.cell.execute
'
);
assert
.
strictEqual
(
called
,
true
);
verifyOutputSyncKernel
.
controller
.
dispose
();
});
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录