Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DCloud
hello uni-app x
提交
36a23a84
H
hello uni-app x
项目概览
DCloud
/
hello uni-app x
通知
6068
Star
93
Fork
166
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
19
列表
看板
标记
里程碑
合并请求
1
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
H
hello uni-app x
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
19
Issue
19
列表
看板
标记
里程碑
合并请求
1
合并请求
1
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
36a23a84
编写于
3月 26, 2024
作者:
dcloud_wdl
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
update jest-setup.js 适配新版截图对比方案
上级
76b14049
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
154 addition
and
139 deletion
+154
-139
jest-setup.js
jest-setup.js
+154
-139
未找到文件。
jest-setup.js
浏览文件 @
36a23a84
const
path
=
require
(
"
path
"
);
const
fs
=
require
(
"
fs
"
);
const
{
configureToMatchImageSnapshot
}
=
require
(
"
jest-image-snapshot
"
);
const
hbuilderx_version
=
process
.
env
.
HX_Version
;
const
uniTestPlatformInfo
=
process
.
env
.
uniTestPlatformInfo
?
process
.
env
.
uniTestPlatformInfo
.
replace
(
/
\s
/g
,
"
_
"
)
:
""
;
const
folderName
=
`__image_snapshots__/
${
hbuilderx_version
}
/__
${
uniTestPlatformInfo
}
__`
;
let
environment
=
"
official
"
;
if
(
hbuilderx_version
.
includes
(
"
dev
"
))
{
environment
=
"
dev
"
;
}
else
if
(
hbuilderx_version
.
includes
(
"
alpha
"
))
{
environment
=
"
alpha
"
;
}
const
baseFolderName
=
`__image_snapshots__/base/
${
environment
}
/__
${
uniTestPlatformInfo
}
__`
;
const
{
configureToMatchImageSnapshot
}
=
require
(
'
jest-image-snapshot
'
);
let
saveImageSnapshotDir
=
process
.
env
.
saveImageSnapshotDir
||
path
.
join
(
__dirname
,
'
__snapshot__
'
);
expect
.
extend
({
toMatchImageSnapshot
:
configureToMatchImageSnapshot
({
customSnapshotIdentifier
(
args
)
{
return
args
.
currentTestName
.
replace
(
/
\/
/g
,
"
-
"
).
replace
(
"
"
,
"
-
"
);
},
customSnapshotsDir
:
path
.
join
(
__dirname
,
baseFolderName
)
,
customDiffDir
:
path
.
join
(
__dirname
,
`
${
folderName
}
/`
,
"
diff
"
),
}),
toSaveSnapshot
,
toSaveImageSnapshot
,
toMatchImageSnapshot
:
configureToMatchImageSnapshot
({
customSnapshotIdentifier
(
args
)
{
return
args
.
currentTestName
.
replace
(
/
\/
/g
,
"
-
"
).
replace
(
"
"
,
"
-
"
);
},
customSnapshotsDir
:
process
.
env
.
saveImageSnapshotDir
,
customDiffDir
:
path
.
join
(
saveImageSnapshotDir
,
"
diff
"
),
}),
toSaveSnapshot
,
toSaveImageSnapshot
,
});
const
testCaseToSnapshotFilePath
=
process
.
env
.
testCaseToSnapshotFilePath
||
"
./testCaseToSnapshotFilePath.json
"
;
process
.
env
.
testCaseToSnapshotFilePath
||
"
./testCaseToSnapshotFilePath.json
"
;
if
(
!
fs
.
existsSync
(
testCaseToSnapshotFilePath
))
{
fs
.
writeFileSync
(
testCaseToSnapshotFilePath
,
"
{}
"
);
fs
.
writeFileSync
(
testCaseToSnapshotFilePath
,
"
{}
"
);
}
function
writeTestCaseToSnapshotFile
(
testCaseName
,
snapshotFilePath
)
{
const
data
=
JSON
.
parse
(
fs
.
readFileSync
(
testCaseToSnapshotFilePath
));
if
(
!
data
[
testCaseName
])
{
data
[
testCaseName
]
=
[
snapshotFilePath
];
}
else
{
data
[
testCaseName
].
push
(
snapshotFilePath
);
}
fs
.
writeFileSync
(
testCaseToSnapshotFilePath
,
JSON
.
stringify
(
data
,
null
,
2
));
const
data
=
JSON
.
parse
(
fs
.
readFileSync
(
testCaseToSnapshotFilePath
));
if
(
testCaseName
.
includes
(
__dirname
))
{
testCaseName
=
testCaseName
.
substring
(
`
${
__dirname
}
`
.
length
);
if
(
testCaseName
[
0
]
==
'
/
'
||
testCaseName
[
0
]
==
'
\\
'
)
{
testCaseName
=
testCaseName
.
substring
(
1
);
};
};
if
(
!
data
[
testCaseName
])
{
data
[
testCaseName
]
=
[
snapshotFilePath
];
}
else
{
data
[
testCaseName
].
push
(
snapshotFilePath
);
}
fs
.
writeFileSync
(
testCaseToSnapshotFilePath
,
JSON
.
stringify
(
data
,
null
,
2
));
}
function
toSaveSnapshot
(
received
,
{
customSnapshotsDir
,
fileName
}
=
{})
{
const
{
snapshotState
:
{
_rootDir
},
testPath
,
currentTestName
,
}
=
this
;
const
SNAPSHOTS_DIR
=
"
__file_snapshots__
"
;
const
snapshotDir
=
process
.
env
.
saveSnapshotDir
||
createSnapshotDir
({
customSnapshotsDir
,
testPath
,
SNAPSHOTS_DIR
,
function
toSaveSnapshot
(
received
,
{
customSnapshotsDir
,
fileName
}
=
{})
{
const
{
snapshotState
:
{
_rootDir
},
testPath
,
currentTestName
,
}
=
this
;
const
SNAPSHOTS_DIR
=
"
__file_snapshots__
"
;
const
snapshotDir
=
process
.
env
.
saveSnapshotDir
||
createSnapshotDir
({
customSnapshotsDir
,
testPath
,
SNAPSHOTS_DIR
,
});
const
_fileName
=
createFileName
({
fileName
,
testPath
,
currentTestName
,
});
const
_fileName
=
createFileName
({
fileName
,
testPath
,
currentTestName
,
});
const
filePath
=
path
.
join
(
snapshotDir
,
_fileName
);
let
message
=
()
=>
`
${
currentTestName
}
toSaveSnapshot success`
;
let
pass
=
true
;
try
{
checkSnapshotDir
(
snapshotDir
);
fs
.
writeFileSync
(
filePath
,
received
);
writeTestCaseToSnapshotFile
(
testPath
.
replace
(
`
${
_rootDir
}
/`
,
""
),
filePath
);
}
catch
(
e
)
{
console
.
log
(
"
toSaveSnapshot fail
"
,
e
);
message
=
()
=>
e
.
message
;
pass
=
false
;
}
return
{
message
,
pass
,
};
const
filePath
=
path
.
join
(
snapshotDir
,
_fileName
);
let
message
=
()
=>
`
${
currentTestName
}
toSaveSnapshot success`
;
let
pass
=
true
;
try
{
checkSnapshotDir
(
snapshotDir
);
fs
.
writeFileSync
(
filePath
,
received
);
writeTestCaseToSnapshotFile
(
testPath
.
replace
(
`
${
_rootDir
}
/`
,
""
),
filePath
);
}
catch
(
e
)
{
console
.
log
(
"
toSaveSnapshot fail
"
,
e
);
message
=
()
=>
e
.
message
;
pass
=
false
;
}
return
{
message
,
pass
,
};
}
function
toSaveImageSnapshot
(
received
,
{
customSnapshotsDir
,
customSnapshotIdentifier
}
=
{}
received
,
{
customSnapshotsDir
,
customSnapshotIdentifier
}
=
{}
)
{
const
{
snapshotState
:
{
_rootDir
},
testPath
,
currentTestName
,
}
=
this
;
const
SNAPSHOTS_DIR
=
"
__image_snapshots__
"
;
const
snapshotDir
=
process
.
env
.
saveImageSnapshotDir
||
createSnapshotDir
({
customSnapshotsDir
,
testPath
,
SNAPSHOTS_DIR
,
const
{
snapshotState
:
{
_rootDir
},
testPath
,
currentTestName
,
}
=
this
;
const
SNAPSHOTS_DIR
=
"
__image_snapshots__
"
;
const
snapshotDir
=
process
.
env
.
saveImageSnapshotDir
||
createSnapshotDir
({
customSnapshotsDir
,
testPath
,
SNAPSHOTS_DIR
,
});
const
_fileName
=
createFileName
({
fileName
:
customSnapshotIdentifier
?
customSnapshotIdentifier
()
:
""
,
testPath
,
currentTestName
,
fileType
:
"
png
"
,
});
const
_fileName
=
createFileName
({
fileName
:
customSnapshotIdentifier
?
customSnapshotIdentifier
()
:
""
,
testPath
,
currentTestName
,
fileType
:
"
png
"
,
});
const
filePath
=
path
.
join
(
snapshotDir
,
_fileName
);
let
message
=
()
=>
`
${
currentTestName
}
toSaveImageSnapshot success`
;
let
pass
=
true
;
try
{
checkSnapshotDir
(
snapshotDir
);
fs
.
writeFileSync
(
filePath
,
Buffer
.
from
(
received
,
"
base64
"
));
writeTestCaseToSnapshotFile
(
testPath
.
replace
(
`
${
_rootDir
}
/`
,
""
),
filePath
);
}
catch
(
e
)
{
console
.
log
(
"
toSaveImageSnapshot fail
"
,
e
);
message
=
()
=>
e
.
message
;
pass
=
false
;
}
return
{
message
,
pass
,
};
const
filePath
=
path
.
join
(
snapshotDir
,
_fileName
);
let
message
=
()
=>
`
${
currentTestName
}
toSaveImageSnapshot success`
;
let
pass
=
true
;
try
{
checkSnapshotDir
(
snapshotDir
);
fs
.
writeFileSync
(
filePath
,
Buffer
.
from
(
received
,
"
base64
"
));
writeTestCaseToSnapshotFile
(
testPath
.
replace
(
`
${
_rootDir
}
/`
,
""
),
filePath
);
}
catch
(
e
)
{
console
.
log
(
"
toSaveImageSnapshot fail
"
,
e
);
message
=
()
=>
e
.
message
;
pass
=
false
;
}
return
{
message
,
pass
,
};
}
function
createSnapshotDir
({
customSnapshotsDir
,
testPath
,
SNAPSHOTS_DIR
})
{
return
customSnapshotsDir
||
path
.
join
(
path
.
dirname
(
testPath
),
SNAPSHOTS_DIR
);
function
createSnapshotDir
({
customSnapshotsDir
,
testPath
,
SNAPSHOTS_DIR
})
{
return
customSnapshotsDir
||
path
.
join
(
path
.
dirname
(
testPath
),
SNAPSHOTS_DIR
);
}
function
createFileName
({
fileName
,
testPath
,
currentTestName
,
fileType
})
{
return
(
fileName
||
createSnapshotIdentifier
({
testPath
,
currentTestName
,
fileType
,
})
);
function
createFileName
({
fileName
,
testPath
,
currentTestName
,
fileType
})
{
return
(
fileName
||
createSnapshotIdentifier
({
testPath
,
currentTestName
,
fileType
,
})
);
}
function
createSnapshotIdentifier
({
testPath
,
currentTestName
,
fileType
=
"
txt
"
,
testPath
,
currentTestName
,
fileType
=
"
txt
"
,
})
{
const
snapshotIdentifier
=
kebabCase
(
`
${
path
.
basename
(
testPath
)}
-
${
currentTestName
}
`
);
const
counter
=
timesCalled
.
get
(
`
${
snapshotIdentifier
}
-
${
fileType
}
`
)
||
1
;
timesCalled
.
set
(
`
${
snapshotIdentifier
}
-
${
fileType
}
`
,
counter
+
1
);
return
`
${
snapshotIdentifier
}
-
${
counter
}
.
${
fileType
}
`
;
const
snapshotIdentifier
=
kebabCase
(
`
${
path
.
basename
(
testPath
)}
-
${
currentTestName
}
`
);
const
counter
=
timesCalled
.
get
(
`
${
snapshotIdentifier
}
-
${
fileType
}
`
)
||
1
;
timesCalled
.
set
(
`
${
snapshotIdentifier
}
-
${
fileType
}
`
,
counter
+
1
);
return
`
${
snapshotIdentifier
}
-
${
counter
}
.
${
fileType
}
`
;
}
function
kebabCase
(
str
)
{
return
str
.
replaceAll
(
/
([
a-z
])([
A-Z
])
/g
,
"
$1-$2
"
)
.
replaceAll
(
/
\s
+/g
,
"
-
"
)
.
replaceAll
(
/_+/g
,
"
-
"
)
.
replaceAll
(
/
\/
+/g
,
"
-
"
)
.
replaceAll
(
/
\.
+/g
,
"
-
"
)
.
toLowerCase
();
return
str
.
replaceAll
(
/
([
a-z
])([
A-Z
])
/g
,
"
$1-$2
"
)
.
replaceAll
(
/
\s
+/g
,
"
-
"
)
.
replaceAll
(
/_+/g
,
"
-
"
)
.
replaceAll
(
/
\/
+/g
,
"
-
"
)
.
replaceAll
(
/
\.
+/g
,
"
-
"
)
.
toLowerCase
();
}
function
checkSnapshotDir
(
snapshotDir
)
{
if
(
!
fs
.
existsSync
(
snapshotDir
))
{
fs
.
mkdirSync
(
snapshotDir
,
{
recursive
:
true
,
});
}
if
(
!
fs
.
existsSync
(
snapshotDir
))
{
fs
.
mkdirSync
(
snapshotDir
,
{
recursive
:
true
,
});
}
}
const
timesCalled
=
new
Map
();
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录