移动测试基础 在 APP 包的 icon 上展示打包的版本信息

ELes for PPmoney · June 04, 2018 · Last by spring-ssh replied at June 07, 2018 · 1767 hits

适用场景

大家是否有遇到过测试app的时候,想要提bug却忘了自己装的是哪个时候打出来的包,版本号一样,icon一样,打开放测试包的文件夹又有一堆测试包,一时间想不起来到底安装的是哪个包的场景?

又或者有时候覆盖安装不知道自己覆盖安装成功了没有,却没法校验的场景?

如果你们有遇到这些烦恼,那么这篇文章正好能解决你们的问题——在APP的icon上加上版本信息吧!

实现效果图:

实现效果图

实现思路

  • 通过ImageMagick实现icon图片的处理,编写icon处理脚本
  • 在构建之前加入app的icon的预处理脚本即可
  • 目前我们的测试app都是通过jenkins来打包的,只要在jenkins配置的脚本中,在构建那一步之前插入以下脚本即可(以下脚本运行环境为Mac OS)。

具体脚本实现

# 修改打包图标添加打包信息
# iOS端插入到“xcodebuild”执行之前
# Android端插入到“./gradlew”执行之前

# 判断脚本运行环境是否安装了ImageMagick
convertPath=`which convert`

if [[ ! -f ${convertPath} || -z ${convertPath} ]]; then
echo "==============
WARNING: 你需要先安装 ImageMagick!!!!:
brew install imagemagick
=============="

exit 0
fi

# 基于上下文编写要显示在icon上的信息,支持\n换行
CURRENT_TIME=$(date +"%Y%m%d%H%M")
caption="$CURRENT_TIME\n${CUR_VERSION} \n${BUILD_NUMBER}"
echo "caption: ${caption}"

# 处理图片步骤
function generateIcon() {
originalImg=$1

# 添加散射+高斯模糊
convert ${originalImg} -spread 10 spread-original.png
convert spread-original.png -blur 10x8 blur-original.png

# 截取下部分
width=`identify -format %w ${originalImg}`
height=`identify -format %h ${originalImg}`
height_0=`expr ${height} / 2`
height_1=$((${height} - ${height_0}))
convert blur-original.png -crop ${width}x${height_0}+0+${height_1} crop-blur-original.png

# 加字
point_size=$(((8 * $width) / 58))

convert -background none -fill black -pointsize ${point_size} -gravity center caption:"${caption}" crop-blur-original.png +swap -composite label.png

# 合成
composite -geometry +0+${height_0} label.png ${originalImg} ${originalImg}

# 清除文件
rm blur-original.png
rm crop-blur-original.png
rm label.png
}

# 找到appicon的文件夹,遍历执行icon修改
iconpath="$WORKSPACE/${iconpath}"
for file in ${iconpath}/*
do
if [[ $file == *mipmap* ]]
then
filename="$file/icon.png"
generateIcon $filename
fi
done


# ========= end for =========

参考资料

iOS——写一个快速定位问题的脚本

共收到 7 条回复 时间 点赞

为啥不直接看版本号啊。。。

恒温 回复

有些App需要登陆进去才能看到版本号,对于手机比较多,环境比较多的来说,找到正确的账号也不是容易的事。
这样比较直观。

有在python下可用的库么?

ELes #4 · June 07, 2018 作者
snake 回复

是的 之前我们的APP需要登录后才能看到版本号,不过这里的版本号 是指开发过程中的打包版本标识 而不是正式发布的时候在APP中的版本号,主要是为了区分测试版本的哈。

ELes #5 · June 07, 2018 作者
spring-ssh 回复

查了一下是有的,叫做PythonMagick ,我是直接在环境里安装了ImageMagick,所以没用过这个库,但找到了一篇文章https://blog.csdn.net/sweeper_freedoman/article/details/69789307

ELes #6 · June 07, 2018 作者
恒温 回复

其实这里的版本号 是指开发过程中的打包版本标识 而不是正式发布的时候在APP中的版本号。我们app在关于中的版本号用的是正式发布的版本号,没法通过APP中的版本号区分测试版本,所以才有了这个需求

ELes 回复

谢谢,下来我去试试。😀

需要 Sign In 后方可回复, 如果你还没有账号请点击这里 Sign Up