Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DCloud
uni-starter
提交
893a69e8
U
uni-starter
项目概览
DCloud
/
uni-starter
通知
4684
Star
229
Fork
210
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
3
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
U
uni-starter
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
3
Issue
3
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
893a69e8
编写于
4月 28, 2024
作者:
Anne_LXM
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
toMatchImageSnapshot->toSaveImageSnapshot
上级
693acc2a
变更
3
显示空白变更内容
内联
并排
Showing
3 changed file
with
203 addition
and
24 deletion
+203
-24
jest-setup.js
jest-setup.js
+187
-17
pages/pages.test.js
pages/pages.test.js
+8
-3
pages/ucenter/ucenter.test.js
pages/ucenter/ucenter.test.js
+8
-4
未找到文件。
jest-setup.js
浏览文件 @
893a69e8
const
path
=
require
(
'
path
'
);
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
}
__`
const
baseFolderName
=
`__image_snapshots__/base/__
${
uniTestPlatformInfo
}
__`
const
path
=
require
(
"
path
"
);
const
fs
=
require
(
"
fs
"
);
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
'
),
}),
// 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
"
;
if
(
!
fs
.
existsSync
(
testCaseToSnapshotFilePath
))
{
fs
.
writeFileSync
(
testCaseToSnapshotFilePath
,
"
{}
"
);
}
function
writeTestCaseToSnapshotFile
(
testCaseName
,
snapshotFilePath
)
{
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
,
});
const
_fileName
=
createFileName
({
fileName
,
testPath
,
currentTestName
,
});
const
filePath
=
path
.
join
(
snapshotDir
,
_fileName
);
let
message
=
()
=>
`
${
currentTestName
}
toSaveSnapshot success`
;
let
pass
=
true
;
try
{
checkSnapshotDir
(
path
.
dirname
(
filePath
));
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
}
=
{}
)
{
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
()}
.png`
:
""
,
testPath
,
currentTestName
,
fileType
:
"
png
"
,
});
const
filePath
=
path
.
join
(
snapshotDir
,
_fileName
);
let
message
=
()
=>
`
${
currentTestName
}
toSaveImageSnapshot success`
;
let
pass
=
true
;
try
{
checkSnapshotDir
(
path
.
dirname
(
filePath
));
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
createFileName
({
fileName
,
testPath
,
currentTestName
,
fileType
})
{
return
(
fileName
||
createSnapshotIdentifier
({
testPath
,
currentTestName
,
fileType
,
})
);
}
function
createSnapshotIdentifier
({
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
}
`
;
}
function
kebabCase
(
str
)
{
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
,
});
}
}
const
timesCalled
=
new
Map
();
pages/pages.test.js
浏览文件 @
893a69e8
...
...
@@ -19,8 +19,13 @@ describe('page screenshot test', () => {
console
.
log
(
"
page screenshot test finish
"
);
});
test
.
each
(
pages
)(
'
%s
'
,
async
()
=>
{
const
image
=
await
program
.
screenshot
();
expect
(
image
).
toMatchImageSnapshot
();
// const image = await program.screenshot();
// expect(image).toMatchImageSnapshot();
// await page.waitFor(500);
const
image
=
await
program
.
screenshot
({
fullPage
:
true
});
expect
(
image
).
toSaveImageSnapshot
();
await
page
.
waitFor
(
500
);
})
})
\ No newline at end of file
pages/ucenter/ucenter.test.js
浏览文件 @
893a69e8
...
...
@@ -55,10 +55,14 @@ describe('ucenter', () => {
})
}
it
(
'
screenshot
'
,
async
()
=>
{
// await program.screenshot({
// path: "static/screenshot/ucenter.png"
// })
const
savePath
=
process
.
env
.
saveImageSnapshotDir
console
.
log
(
'
savePath
'
,
savePath
)
await
program
.
screenshot
({
path
:
"
static/screenshot/ucenter.png
"
path
:
savePath
})
await
page
.
waitFor
(
500
);
})
})
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录