Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
7b108d3d
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,体验更适合开发者的 AI 搜索 >>
提交
7b108d3d
编写于
9月 27, 2018
作者:
C
Christof Marti
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
WIP
上级
755bf80a
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
83 addition
and
24 deletion
+83
-24
extensions/vscode-api-tests/src/singlefolder-tests/index.ts
extensions/vscode-api-tests/src/singlefolder-tests/index.ts
+1
-0
extensions/vscode-api-tests/src/singlefolder-tests/quickInput.test.ts
...scode-api-tests/src/singlefolder-tests/quickInput.test.ts
+66
-10
scripts/test-integration.sh
scripts/test-integration.sh
+13
-13
src/vs/workbench/browser/parts/quickinput/quickInput.ts
src/vs/workbench/browser/parts/quickinput/quickInput.ts
+3
-1
未找到文件。
extensions/vscode-api-tests/src/singlefolder-tests/index.ts
浏览文件 @
7b108d3d
...
...
@@ -11,6 +11,7 @@ const suite = 'Integration Single Folder Tests';
const
options
:
any
=
{
ui
:
'
tdd
'
,
useColors
:
true
,
grep
:
'
QuickInput
'
,
timeout
:
60000
};
...
...
extensions/vscode-api-tests/src/singlefolder-tests/quickInput.test.ts
浏览文件 @
7b108d3d
...
...
@@ -131,38 +131,85 @@ suite('window namespace tests', function () {
quickPick
.
selectedItems
=
[
quickPick
.
items
[
2
]];
},
0
);
});
test
(
'
createQuickPick, continue after first accept
'
,
function
(
_done
)
{
let
done
=
(
err
?:
any
)
=>
{
done
=
()
=>
{};
_done
(
err
);
};
const
quickPick
=
createQuickPick
({
events
:
[
'
active
'
,
'
selection
'
,
'
accept
'
,
'
active
'
,
'
selection
'
,
'
active
'
,
'
selection
'
,
'
accept
'
,
'
hide
'
],
activeItems
:
[[
'
eins
'
],
[],
[
'
drei
'
]],
selectionItems
:
[[
'
eins
'
],
[],
[
'
drei
'
]],
acceptedItems
:
{
active
:
[[
'
eins
'
],
[
'
drei
'
]],
selection
:
[[
'
eins
'
],
[
'
drei
'
]],
dispose
:
[
false
,
true
]
},
},
(
err
?:
any
)
=>
done
(
err
));
quickPick
.
items
=
[
'
eins
'
,
'
zwei
'
].
map
(
label
=>
({
label
}));
quickPick
.
show
();
(
async
()
=>
{
await
commands
.
executeCommand
(
'
workbench.action.acceptSelectedQuickOpenItem
'
);
await
timeout
(
async
()
=>
{
quickPick
.
items
=
[
'
drei
'
,
'
vier
'
].
map
(
label
=>
({
label
}));
await
timeout
(
async
()
=>
{
await
commands
.
executeCommand
(
'
workbench.action.acceptSelectedQuickOpenItem
'
);
},
0
);
},
0
);
})()
.
catch
(
err
=>
done
(
err
));
});
});
});
function
createQuickPick
(
expected
:
QuickPickExpected
,
done
:
(
err
?:
any
)
=>
void
)
{
function
createQuickPick
(
expected
:
QuickPickExpected
,
done
:
(
err
?:
any
)
=>
void
,
record
=
false
)
{
const
quickPick
=
window
.
createQuickPick
();
let
eventIndex
=
-
1
;
quickPick
.
onDidChangeActive
(
items
=>
{
if
(
record
)
{
console
.
log
(
`active: [
${
items
.
map
(
item
=>
item
.
label
).
join
(
'
,
'
)}
]`
);
return
;
}
try
{
assert
.
equal
(
'
active
'
,
expected
.
events
.
shift
());
eventIndex
++
;
assert
.
equal
(
'
active
'
,
expected
.
events
.
shift
(),
`onDidChangeActive (event
${
eventIndex
}
)`
);
const
expectedItems
=
expected
.
activeItems
.
shift
();
assert
.
deepEqual
(
items
.
map
(
item
=>
item
.
label
),
expectedItems
);
assert
.
deepEqual
(
quickPick
.
activeItems
.
map
(
item
=>
item
.
label
),
expectedItems
);
assert
.
deepEqual
(
items
.
map
(
item
=>
item
.
label
),
expectedItems
,
`onDidChangeActive event items (event
${
eventIndex
}
)`
);
assert
.
deepEqual
(
quickPick
.
activeItems
.
map
(
item
=>
item
.
label
),
expectedItems
,
`onDidChangeActive active items (event
${
eventIndex
}
)`
);
}
catch
(
err
)
{
done
(
err
);
}
});
quickPick
.
onDidChangeSelection
(
items
=>
{
if
(
record
)
{
console
.
log
(
`selection: [
${
items
.
map
(
item
=>
item
.
label
).
join
(
'
,
'
)}
]`
);
return
;
}
try
{
assert
.
equal
(
'
selection
'
,
expected
.
events
.
shift
());
eventIndex
++
;
assert
.
equal
(
'
selection
'
,
expected
.
events
.
shift
(),
`onDidChangeSelection (event
${
eventIndex
}
)`
);
const
expectedItems
=
expected
.
selectionItems
.
shift
();
assert
.
deepEqual
(
items
.
map
(
item
=>
item
.
label
),
expectedItems
);
assert
.
deepEqual
(
quickPick
.
selectedItems
.
map
(
item
=>
item
.
label
),
expectedItems
);
assert
.
deepEqual
(
items
.
map
(
item
=>
item
.
label
),
expectedItems
,
`onDidChangeSelection event items (event
${
eventIndex
}
)`
);
assert
.
deepEqual
(
quickPick
.
selectedItems
.
map
(
item
=>
item
.
label
),
expectedItems
,
`onDidChangeSelection selected items (event
${
eventIndex
}
)`
);
}
catch
(
err
)
{
done
(
err
);
}
});
quickPick
.
onDidAccept
(()
=>
{
if
(
record
)
{
console
.
log
(
'
accept
'
);
return
;
}
try
{
assert
.
equal
(
'
accept
'
,
expected
.
events
.
shift
());
eventIndex
++
;
assert
.
equal
(
'
accept
'
,
expected
.
events
.
shift
(),
`onDidAccept (event
${
eventIndex
}
)`
);
const
expectedActive
=
expected
.
acceptedItems
.
active
.
shift
();
assert
.
deepEqual
(
quickPick
.
activeItems
.
map
(
item
=>
item
.
label
),
expectedActive
);
assert
.
deepEqual
(
quickPick
.
activeItems
.
map
(
item
=>
item
.
label
),
expectedActive
,
`onDidAccept active items (event
${
eventIndex
}
)`
);
const
expectedSelection
=
expected
.
acceptedItems
.
selection
.
shift
();
assert
.
deepEqual
(
quickPick
.
selectedItems
.
map
(
item
=>
item
.
label
),
expectedSelection
);
assert
.
deepEqual
(
quickPick
.
selectedItems
.
map
(
item
=>
item
.
label
),
expectedSelection
,
`onDidAccept selected items (event
${
eventIndex
}
)`
);
if
(
expected
.
acceptedItems
.
dispose
.
shift
())
{
quickPick
.
dispose
();
}
...
...
@@ -171,6 +218,11 @@ function createQuickPick(expected: QuickPickExpected, done: (err?: any) => void)
}
});
quickPick
.
onDidHide
(()
=>
{
if
(
record
)
{
console
.
log
(
'
hide
'
);
done
();
return
;
}
try
{
assert
.
equal
(
'
hide
'
,
expected
.
events
.
shift
());
done
();
...
...
@@ -180,4 +232,8 @@ function createQuickPick(expected: QuickPickExpected, done: (err?: any) => void)
});
return
quickPick
;
}
async
function
timeout
<
T
>
(
run
:
()
=>
Promise
<
T
>
|
T
,
ms
:
number
):
Promise
<
T
>
{
return
new
Promise
<
T
>
(
resolve
=>
setTimeout
(()
=>
resolve
(
run
()),
ms
));
}
\ No newline at end of file
scripts/test-integration.sh
浏览文件 @
7b108d3d
...
...
@@ -14,20 +14,20 @@ cd $ROOT
# Tests in the extension host
./scripts/code.sh
$ROOT
/extensions/vscode-api-tests/testWorkspace
--extensionDevelopmentPath
=
$ROOT
/extensions/vscode-api-tests
--extensionTestsPath
=
$ROOT
/extensions/vscode-api-tests/out/singlefolder-tests
--disableExtensions
--user-data-dir
=
$VSCODEUSERDATADIR
--skip-getting-started
./scripts/code.sh
$ROOT
/extensions/vscode-api-tests/testworkspace.code-workspace
--extensionDevelopmentPath
=
$ROOT
/extensions/vscode-api-tests
--extensionTestsPath
=
$ROOT
/extensions/vscode-api-tests/out/workspace-tests
--disableExtensions
--user-data-dir
=
$VSCODEUSERDATADIR
--skip-getting-started
./scripts/code.sh
$ROOT
/extensions/vscode-colorize-tests/test
--extensionDevelopmentPath
=
$ROOT
/extensions/vscode-colorize-tests
--extensionTestsPath
=
$ROOT
/extensions/vscode-colorize-tests/out
--disableExtensions
--user-data-dir
=
$VSCODEUSERDATADIR
--skip-getting-started
./scripts/code.sh
$ROOT
/extensions/markdown-language-features/test-fixtures
--extensionDevelopmentPath
=
$ROOT
/extensions/markdown-language-features
--extensionTestsPath
=
$ROOT
/extensions/markdown-language-features/out/test
--disableExtensions
--user-data-dir
=
$VSCODEUSERDATADIR
--skip-getting-started
./scripts/code.sh
$ROOT
/extensions/search-rg/test-fixtures
--extensionDevelopmentPath
=
$ROOT
/extensions/search-rg
--extensionTestsPath
=
$ROOT
/extensions/search-rg/out/test
--disableExtensions
--user-data-dir
=
$VSCODEUSERDATADIR
--skip-getting-started
#
./scripts/code.sh $ROOT/extensions/vscode-api-tests/testworkspace.code-workspace --extensionDevelopmentPath=$ROOT/extensions/vscode-api-tests --extensionTestsPath=$ROOT/extensions/vscode-api-tests/out/workspace-tests --disableExtensions --user-data-dir=$VSCODEUSERDATADIR --skip-getting-started
#
./scripts/code.sh $ROOT/extensions/vscode-colorize-tests/test --extensionDevelopmentPath=$ROOT/extensions/vscode-colorize-tests --extensionTestsPath=$ROOT/extensions/vscode-colorize-tests/out --disableExtensions --user-data-dir=$VSCODEUSERDATADIR --skip-getting-started
#
./scripts/code.sh $ROOT/extensions/markdown-language-features/test-fixtures --extensionDevelopmentPath=$ROOT/extensions/markdown-language-features --extensionTestsPath=$ROOT/extensions/markdown-language-features/out/test --disableExtensions --user-data-dir=$VSCODEUSERDATADIR --skip-getting-started
#
./scripts/code.sh $ROOT/extensions/search-rg/test-fixtures --extensionDevelopmentPath=$ROOT/extensions/search-rg --extensionTestsPath=$ROOT/extensions/search-rg/out/test --disableExtensions --user-data-dir=$VSCODEUSERDATADIR --skip-getting-started
mkdir
$ROOT
/extensions/emmet/test-fixtures
./scripts/code.sh
$ROOT
/extensions/emmet/test-fixtures
--extensionDevelopmentPath
=
$ROOT
/extensions/emmet
--extensionTestsPath
=
$ROOT
/extensions/emmet/out/test
--disableExtensions
--user-data-dir
=
$VSCODEUSERDATADIR
--skip-getting-started
.
rm
-r
$ROOT
/extensions/emmet/test-fixtures
#
mkdir $ROOT/extensions/emmet/test-fixtures
#
./scripts/code.sh $ROOT/extensions/emmet/test-fixtures --extensionDevelopmentPath=$ROOT/extensions/emmet --extensionTestsPath=$ROOT/extensions/emmet/out/test --disableExtensions --user-data-dir=$VSCODEUSERDATADIR --skip-getting-started .
#
rm -r $ROOT/extensions/emmet/test-fixtures
# Integration tests in AMD
./scripts/test.sh
--runGlob
**
/
*
.integrationTest.js
"
$@
"
#
#
Integration tests in AMD
#
./scripts/test.sh --runGlob **/*.integrationTest.js "$@"
# Tests in commonJS
cd
$ROOT
/extensions/css-language-features/server
&&
$ROOT
/scripts/node-electron.sh
test
/index.js
cd
$ROOT
/extensions/html-language-features/server
&&
$ROOT
/scripts/node-electron.sh
test
/index.js
#
#
Tests in commonJS
#
cd $ROOT/extensions/css-language-features/server && $ROOT/scripts/node-electron.sh test/index.js
#
cd $ROOT/extensions/html-language-features/server && $ROOT/scripts/node-electron.sh test/index.js
rm
-r
$VSCODEUSERDATADIR
#
rm -r $VSCODEUSERDATADIR
src/vs/workbench/browser/parts/quickinput/quickInput.ts
浏览文件 @
7b108d3d
...
...
@@ -506,7 +506,9 @@ class QuickPick<T extends IQuickPickItem> extends QuickInput implements IQuickPi
}
this
.
_selectedItems
=
selectedItems
as
T
[];
this
.
onDidChangeSelectionEmitter
.
fire
(
selectedItems
as
T
[]);
this
.
onDidAcceptEmitter
.
fire
();
if
(
selectedItems
.
length
)
{
this
.
onDidAcceptEmitter
.
fire
();
}
}),
this
.
ui
.
list
.
onChangedCheckedElements
(
checkedItems
=>
{
if
(
!
this
.
canSelectMany
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录