Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DCloud
hello uni-app x
提交
137a5c9c
H
hello uni-app x
项目概览
DCloud
/
hello uni-app x
通知
5996
Star
90
Fork
162
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
18
列表
看板
标记
里程碑
合并请求
1
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
H
hello uni-app x
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
18
Issue
18
列表
看板
标记
里程碑
合并请求
1
合并请求
1
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
137a5c9c
编写于
3月 15, 2024
作者:
DCloud-WZF
💬
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
test: 支持 toSaveSnapshot 和 toSaveImageSnapshot 方法
上级
67c48705
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
206 addition
and
23 deletion
+206
-23
jest-setup.js
jest-setup.js
+146
-23
pages/toSaveSnapshot-toSaveImageSnapshot-template.test.js
pages/toSaveSnapshot-toSaveImageSnapshot-template.test.js
+60
-0
未找到文件。
jest-setup.js
浏览文件 @
137a5c9c
// 自动化测试
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
}
__`
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
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
}
__`
;
expect
.
extend
({
toMatchImageSnapshot
:
configureToMatchImageSnapshot
({
customSnapshotIdentifier
(
args
)
{
return
args
.
currentTestName
.
replace
(
/
\/
/g
,
'
-
'
).
replace
(
'
'
,
'
-
'
);
return
args
.
currentTestName
.
replace
(
/
\/
/g
,
"
-
"
).
replace
(
"
"
,
"
-
"
);
},
customSnapshotsDir
:
path
.
join
(
__dirname
,
baseFolderName
),
customDiffDir
:
path
.
join
(
__dirname
,
`
${
folderName
}
/`
,
'
diff
'
),
customDiffDir
:
path
.
join
(
__dirname
,
`
${
folderName
}
/`
,
"
diff
"
),
}),
toSaveSnapshot
,
toSaveImageSnapshot
,
});
function
toSaveSnapshot
(
received
,
{
customSnapshotsDir
,
fileName
}
=
{})
{
const
{
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
(
snapshotDir
);
fs
.
writeFileSync
(
filePath
,
received
);
}
catch
(
e
)
{
console
.
log
(
"
toSaveSnapshot fail
"
,
e
);
message
=
()
=>
e
.
message
;
pass
=
false
;
}
return
{
message
,
pass
,
};
}
function
toSaveImageSnapshot
(
received
,
{
customSnapshotsDir
,
customSnapshotIdentifier
}
=
{}
)
{
const
{
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
filePath
=
path
.
join
(
snapshotDir
,
_fileName
);
let
message
=
()
=>
`
${
currentTestName
}
toSaveImageSnapshot success`
;
let
pass
=
true
;
try
{
checkSnapshotDir
(
snapshotDir
);
fs
.
writeFileSync
(
filePath
,
Buffer
.
from
(
received
,
"
base64
"
));
}
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/toSaveSnapshot-toSaveImageSnapshot-template.test.js
0 → 100644
浏览文件 @
137a5c9c
describe
(
'
toSaveSnapshot & toSaveImageSnapshot template
'
,
()
=>
{
beforeAll
(
async
()
=>
{
let
page
=
await
program
.
reLaunch
(
'
/pages/tabBar/component
'
);
await
page
.
waitFor
(
1000
);
})
it
(
'
test toSaveSnapshot 1
'
,
async
()
=>
{
const
text1
=
'
test-toSaveSnapshot-1-1-
'
+
Date
.
now
()
expect
(
text1
).
toSaveSnapshot
()
const
text2
=
'
test-toSaveSnapshot-1-2-
'
+
Date
.
now
()
expect
(
text2
).
toSaveSnapshot
()
})
it
(
'
test toSaveSnapshot 2
'
,
async
()
=>
{
const
text1
=
'
test-toSaveSnapshot-2-1-
'
+
Date
.
now
()
expect
(
text1
).
toSaveSnapshot
({
customSnapshotsDir
:
`./customDir/__file_snapshots__`
,
fileName
:
'
test-toSaveSnapshot-2-1.txt
'
})
const
text2
=
'
test-toSaveSnapshot-2-2-
'
+
Date
.
now
()
expect
(
text2
).
toSaveSnapshot
({
customSnapshotsDir
:
'
./customDir/__file_snapshots__
'
})
const
text3
=
'
test-toSaveSnapshot-2-3-
'
+
Date
.
now
()
expect
(
text3
).
toSaveSnapshot
({
fileName
:
'
test-toSaveSnapshot-2-3.txt
'
})
})
it
(
'
test toSaveImageSnapshot 1
'
,
async
()
=>
{
const
img1
=
await
program
.
screenshot
();
expect
(
img1
).
toSaveImageSnapshot
()
const
img2
=
await
program
.
screenshot
();
expect
(
img2
).
toSaveImageSnapshot
()
})
it
(
'
test toSaveImageSnapshot 2
'
,
async
()
=>
{
const
img1
=
await
program
.
screenshot
();
expect
(
img1
).
toSaveImageSnapshot
({
customSnapshotsDir
:
'
./customDir/__image_snapshots__
'
,
customSnapshotIdentifier
()
{
return
'
test-toSaveImageSnapshot-2-1.png
'
;
},
})
const
img2
=
await
program
.
screenshot
();
expect
(
img2
).
toSaveImageSnapshot
({
customSnapshotsDir
:
'
./customDir/__image_snapshots__
'
,
})
const
img3
=
await
program
.
screenshot
();
expect
(
img3
).
toSaveImageSnapshot
({
customSnapshotIdentifier
()
{
return
'
test-toSaveImageSnapshot-2-3.png
'
;
},
})
})
});
\ No newline at end of file
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录