Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
31fbc68a
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,发现更多精彩内容 >>
提交
31fbc68a
编写于
2月 10, 2019
作者:
M
Matt Bierner
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Strict null check resolver.test
上级
6d973fef
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
39 addition
and
39 deletion
+39
-39
src/vs/workbench/services/files/electron-browser/fileService.ts
.../workbench/services/files/electron-browser/fileService.ts
+1
-1
src/vs/workbench/services/files/test/electron-browser/resolver.test.ts
...nch/services/files/test/electron-browser/resolver.test.ts
+38
-38
未找到文件。
src/vs/workbench/services/files/electron-browser/fileService.ts
浏览文件 @
31fbc68a
...
...
@@ -1142,7 +1142,7 @@ export class StatResolver {
this
.
etag
=
etag
(
size
,
mtime
);
}
resolve
(
options
:
IResolveFileOptions
):
Promise
<
IFileStat
>
{
resolve
(
options
:
IResolveFileOptions
|
undefined
):
Promise
<
IFileStat
>
{
// General Data
const
fileStat
:
IFileStat
=
{
...
...
src/vs/workbench/services/files/test/electron-browser/resolver.test.ts
浏览文件 @
31fbc68a
...
...
@@ -32,13 +32,13 @@ suite('Stat Resolver', () => {
test
(
'
resolve file
'
,
function
()
{
let
resolver
=
create
(
'
/index.html
'
);
return
resolver
.
resolve
(
null
).
then
(
result
=>
{
return
resolver
.
resolve
(
undefined
).
then
(
result
=>
{
assert
.
ok
(
!
result
.
isDirectory
);
assert
.
equal
(
result
.
name
,
'
index.html
'
);
assert
.
ok
(
!!
result
.
etag
);
resolver
=
create
(
'
examples
'
);
return
resolver
.
resolve
(
null
).
then
(
result
=>
{
return
resolver
.
resolve
(
undefined
).
then
(
result
=>
{
assert
.
ok
(
result
.
isDirectory
);
});
});
...
...
@@ -49,20 +49,20 @@ suite('Stat Resolver', () => {
let
resolver
=
create
(
'
/
'
);
return
resolver
.
resolve
(
null
).
then
(
result
=>
{
return
resolver
.
resolve
(
undefined
).
then
(
result
=>
{
assert
.
ok
(
result
);
assert
.
ok
(
result
.
children
);
assert
.
ok
(
result
.
children
.
length
>
0
);
assert
.
ok
(
result
.
isDirectory
);
assert
.
equal
(
result
.
children
.
length
,
testsElements
.
length
);
assert
.
ok
(
result
.
children
!
.
length
>
0
);
assert
.
ok
(
result
!
.
isDirectory
);
assert
.
equal
(
result
.
children
!
.
length
,
testsElements
.
length
);
assert
.
ok
(
result
.
children
.
every
((
entry
)
=>
{
assert
.
ok
(
result
.
children
!
.
every
((
entry
)
=>
{
return
testsElements
.
some
((
name
)
=>
{
return
path
.
basename
(
entry
.
resource
.
fsPath
)
===
name
;
});
}));
result
.
children
.
forEach
((
value
)
=>
{
result
.
children
!
.
forEach
((
value
)
=>
{
assert
.
ok
(
path
.
basename
(
value
.
resource
.
fsPath
));
if
([
'
examples
'
,
'
other
'
].
indexOf
(
path
.
basename
(
value
.
resource
.
fsPath
))
>=
0
)
{
assert
.
ok
(
value
.
isDirectory
);
...
...
@@ -85,20 +85,20 @@ suite('Stat Resolver', () => {
return
resolver
.
resolve
({
resolveTo
:
[
toResource
(
'
other/deep
'
)]
}).
then
(
result
=>
{
assert
.
ok
(
result
);
assert
.
ok
(
result
.
children
);
assert
.
ok
(
result
.
children
.
length
>
0
);
assert
.
ok
(
result
.
children
!
.
length
>
0
);
assert
.
ok
(
result
.
isDirectory
);
let
children
=
result
.
children
;
const
children
=
result
.
children
!
;
assert
.
equal
(
children
.
length
,
4
);
le
t
other
=
utils
.
getByName
(
result
,
'
other
'
);
cons
t
other
=
utils
.
getByName
(
result
,
'
other
'
);
assert
.
ok
(
other
);
assert
.
ok
(
other
.
children
.
length
>
0
);
assert
.
ok
(
other
!
.
children
!
.
length
>
0
);
let
deep
=
utils
.
getByName
(
other
,
'
deep
'
);
const
deep
=
utils
.
getByName
(
other
!
,
'
deep
'
);
assert
.
ok
(
deep
);
assert
.
ok
(
deep
.
children
.
length
>
0
);
assert
.
equal
(
deep
.
children
.
length
,
4
);
assert
.
ok
(
deep
!
.
children
!
.
length
>
0
);
assert
.
equal
(
deep
!
.
children
!
.
length
,
4
);
});
});
...
...
@@ -108,24 +108,24 @@ suite('Stat Resolver', () => {
return
resolver
.
resolve
({
resolveTo
:
[
toResource
(
'
other/Deep
'
)]
}).
then
(
result
=>
{
assert
.
ok
(
result
);
assert
.
ok
(
result
.
children
);
assert
.
ok
(
result
.
children
.
length
>
0
);
assert
.
ok
(
result
.
children
!
.
length
>
0
);
assert
.
ok
(
result
.
isDirectory
);
le
t
children
=
result
.
children
;
assert
.
equal
(
children
.
length
,
4
);
cons
t
children
=
result
.
children
;
assert
.
equal
(
children
!
.
length
,
4
);
le
t
other
=
utils
.
getByName
(
result
,
'
other
'
);
cons
t
other
=
utils
.
getByName
(
result
,
'
other
'
);
assert
.
ok
(
other
);
assert
.
ok
(
other
.
children
.
length
>
0
);
assert
.
ok
(
other
!
.
children
!
.
length
>
0
);
let
deep
=
utils
.
getByName
(
other
,
'
deep
'
);
const
deep
=
utils
.
getByName
(
other
!
,
'
deep
'
);
if
(
isLinux
)
{
// Linux has case sensitive file system
assert
.
ok
(
deep
);
assert
.
ok
(
!
deep
.
children
);
// not resolved because we got instructed to resolve other/Deep with capital D
assert
.
ok
(
!
deep
!
.
children
);
// not resolved because we got instructed to resolve other/Deep with capital D
}
else
{
assert
.
ok
(
deep
);
assert
.
ok
(
deep
.
children
.
length
>
0
);
assert
.
equal
(
deep
.
children
.
length
,
4
);
assert
.
ok
(
deep
!
.
children
!
.
length
>
0
);
assert
.
equal
(
deep
!
.
children
!
.
length
,
4
);
}
});
});
...
...
@@ -136,25 +136,25 @@ suite('Stat Resolver', () => {
return
resolver
.
resolve
({
resolveTo
:
[
toResource
(
'
other/deep
'
),
toResource
(
'
examples
'
)]
}).
then
(
result
=>
{
assert
.
ok
(
result
);
assert
.
ok
(
result
.
children
);
assert
.
ok
(
result
.
children
.
length
>
0
);
assert
.
ok
(
result
.
children
!
.
length
>
0
);
assert
.
ok
(
result
.
isDirectory
);
let
children
=
result
.
children
;
const
children
=
result
.
children
!
;
assert
.
equal
(
children
.
length
,
4
);
le
t
other
=
utils
.
getByName
(
result
,
'
other
'
);
cons
t
other
=
utils
.
getByName
(
result
,
'
other
'
);
assert
.
ok
(
other
);
assert
.
ok
(
other
.
children
.
length
>
0
);
assert
.
ok
(
other
!
.
children
!
.
length
>
0
);
let
deep
=
utils
.
getByName
(
other
,
'
deep
'
);
const
deep
=
utils
.
getByName
(
other
!
,
'
deep
'
);
assert
.
ok
(
deep
);
assert
.
ok
(
deep
.
children
.
length
>
0
);
assert
.
equal
(
deep
.
children
.
length
,
4
);
assert
.
ok
(
deep
!
.
children
!
.
length
>
0
);
assert
.
equal
(
deep
!
.
children
!
.
length
,
4
);
le
t
examples
=
utils
.
getByName
(
result
,
'
examples
'
);
cons
t
examples
=
utils
.
getByName
(
result
,
'
examples
'
);
assert
.
ok
(
examples
);
assert
.
ok
(
examples
.
children
.
length
>
0
);
assert
.
equal
(
examples
.
children
.
length
,
4
);
assert
.
ok
(
examples
!
.
children
!
.
length
>
0
);
assert
.
equal
(
examples
!
.
children
!
.
length
,
4
);
});
});
...
...
@@ -164,16 +164,16 @@ suite('Stat Resolver', () => {
return
resolver
.
resolve
({
resolveSingleChildDescendants
:
true
}).
then
(
result
=>
{
assert
.
ok
(
result
);
assert
.
ok
(
result
.
children
);
assert
.
ok
(
result
.
children
.
length
>
0
);
assert
.
ok
(
result
.
children
!
.
length
>
0
);
assert
.
ok
(
result
.
isDirectory
);
let
children
=
result
.
children
;
const
children
=
result
.
children
!
;
assert
.
equal
(
children
.
length
,
1
);
let
deep
=
utils
.
getByName
(
result
,
'
deep
'
);
assert
.
ok
(
deep
);
assert
.
ok
(
deep
.
children
.
length
>
0
);
assert
.
equal
(
deep
.
children
.
length
,
4
);
assert
.
ok
(
deep
!
.
children
!
.
length
>
0
);
assert
.
equal
(
deep
!
.
children
!
.
length
,
4
);
});
});
});
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录