fastlane踩坑记

2019-03-03  本文已影响0人  微笑_d797
官方对fastlane的定义.png

Fastlane是一套使用Ruby写的自动化工具集,旨在简化Android和iOS的部署过程,自动化你的工作流。它可以简化一些乏味、单调、重复的工作,像截图、代码签名以及发布App

要说这个fastlane坑真是巨多,本来以为半天能搞定的生生搞了一天半,还是没有搞定,下面给大家说说遇到的坑让他加少走弯路

安装

404

我们去官网阅读他的文档
安装有两种方式

image.png
第一个坑来了其实这个坑是个小坑倒是不算特别的难,就是当我们执行sudo gem install fastlane -NV 命令的时候总是报各种404总之就是安装不上解决方法就是将自己电脑的RubyGems镜像地址更新为

https://gems.ruby-china.com/

没有权限访问 usr/bin

如果之前为taobao或者后缀为org的也可以注意一下这几点。这两个源早已经不维护了


image.png

然后执行 sudo gem install fastlane -NV 依然报错说没有权限访问/usr/bin 这个文件夹,具体错无信息我忘了反正大概就是这个意思这个时候执行

sudo gem install fastlane -NV -n /usr/local/bin

就可以安装到这个文件夹里面了

使用

初始化

接下来就是使用了,由于本人第一次用这个工具所以基本总结就是自定义lane 然后用fastlane去执行,一步一步的

Permissiondenied

首先在项目根目录执行fastlane init着点基本没什么问题,如果执行失败报错 Permissiondenied


image.png

执行 sudo fastlane init 这样
总之一切权限问题基本都需要在前面加sudo关键字以系统级别来执行这命令

初始化成功会报4个选项

image.png

大意就是说 自动屏幕截图 自动部署TestFlight 自动部署App Store 手动部署
这里我们可以选择 3 或者 4 区别就是 如果选4 App file里面的东西需要自己手动配置,为了减少不必要的设置(其实是懒)我选择了3,
然后登陆自己的Apple ID,这里因为我已经登陆过了所以不再需要密码双重验证什么的,如果需要绑定双重的验证设备在身边可以直接进行,不在身边输入sms可以手机验证码,因为我账号绑定在公司测试机上了所以我选择的是后者。


image.png

他说我的app在App Store Connect里面没有问我是不是要穿建一个这里我选择的否
到这整个项目的初始化就完成了

配置Fastfile

打开项目发现多了几个文件


image.png

这几个文件是fastlane的主要工作文件。主要工作是在fastlane文件夹里的Fastfile里面完成的。先打开Appfile发现这些东西都是已经配置好了的,如果刚刚选择了4这些东西都需要自己手动填写


image.png

直接编辑是不可能的所以只能通过 sudo vim xfile 编辑这些文件
编辑问题不说接下来说编辑遇到的坑也是自己不会所以就饶了许多弯子
打开fastlane看里面的文件布局


image.png
先说说里面常见的几个action把

gym

他的作用基本上是这事导出路径导出方式等等

xcodebuild clean archive -archivePath build/MyApp \
                         -scheme MyApp
xcodebuild -exportArchive \
           -exportFormat ipa \
           -archivePath "build/MyApp.xcarchive" \
           -exportPath "build/MyApp.ipa" \
           -exportProvisioningProfile "ProvisioningProfileName"

这是我文件的gym设置

gym(
            scheme: "你的scheme",
            export_method: "ad-hoc/appstore/",
            silent:true,
#            export_xcargs: "-allowProvisioningUpdates",
            export_options: {
                provisioningProfiles: {
                    "bundle" => "对应的打包文件"
                }
            }
        )

match

设置证书托管在git上面这样可以多终端写作无需配置多虚profile文件

还有好多action,大家可以去官网查阅

直接执行sudo fastlane release命令。

image.png
这是为什么呢这是一个折腾了我好久的大坑,我总结说我的Xcode没有权限访问要是传需要配置 -allowProvisioningUpdates和证路径,但是这样执行还是不行,扔然报这个错误
我总结了一下后来把fastfile文件改成exeport_options
image.png
还是不行依然报这个错
image.png
但是我用Xcode build 就没事按那个正常的配置配置就可以打出包来并且成功发布到蒲公英
#使用方法

if [ ! -d ./IPADir ];
    then
        mkdir -p IPADir;
fi

#工程绝对路径
project_path=$(cd `dirname $0`; pwd)

#工程名 将XXX替换成自己的工程名
project_name=xxxx

#scheme名 将XXX替换成自己的sheme名
scheme_name=xxxx

#打包模式 Debug/Release
development_mode=Release

#build文件夹路径
build_path=${project_path}/build

#plist文件所在路径
exportOptionsPlistPath=${project_path}/exportAppstore.plist

#导出.ipa文件所在路径
exportIpaPath=${project_path}/IPADir/${development_mode}

echo "请输入你想法发布的方式 ? [ 1:app-store 2:ad-hoc] "

##
read number
    while([[ $number != 1 ]] && [[ $number != 2 ]])
    do
        echo "笨蛋,只能输入 1 or 2"
        echo "请输入你想法发布的方式 ? [ 1:app-store 2:ad-hoc] "
        read number
    done

if [ $number == 1 ];
    then
    development_mode=Release
    exportOptionsPlistPath=${project_path}/exportAppstore.plist
## 证书名字

    else
    development_mode=Debug
    exportOptionsPlistPath=${project_path}/exportTest.plist

fi


echo '///-----------'
echo '/// 正在清理工程'
echo '///-----------'
xcodebuild \
clean -configuration ${development_mode} -quiet  || exit


echo '///--------'
echo '/// 清理完成'
echo '///--------'
echo ''

echo '///-----------'
echo '/// 正在编译工程:'${development_mode}
echo '///-----------'
xcodebuild \
archive -workspace ${project_path}/${project_name}.xcworkspace \
-scheme ${scheme_name} \
-configuration ${development_mode} \
-archivePath ${build_path}/${project_name}.xcarchive -quiet  || exit

echo '///--------'
echo '/// 编译完成'
echo '///--------'
echo ''

echo '///----------'
echo '/// 开始ipa打包'
echo '///----------'
xcodebuild -exportArchive -archivePath ${build_path}/${project_name}.xcarchive \
-configuration ${development_mode} \
-exportPath ${exportIpaPath} \
-exportOptionsPlist ${exportOptionsPlistPath} \
-quiet || exit

# 删除build包
if [[ -d build ]]; then
rm -rf build -r
fi


if [ -e $exportIpaPath/$scheme_name.ipa ];
    then
    echo '///----------'
    echo '/// ipa包已导出'
    echo '///----------'
    open $exportIpaPath
    else
    echo '///-------------'
    echo '/// ipa包导出失败 '
    echo '///-------------'
fi
echo '///------------'
echo '/// 打包ipa完成  '
echo '///-----------='
echo ''

echo '///-------------'
echo '/// 开始发布ipa包 '
echo '///-------------'

if [ $number == 1 ];
    then

    #验证并上传到App Store
    # 将-u 后面的XXX替换成自己的AppleID的账号,-p后面的XXX替换成自己的密码
    altoolPath="/Applications/Xcode.app/Contents/Applications/Application Loader.app/Contents/Frameworks/ITunesSoftwareService.framework/Versions/A/Support/altool"
    "$altoolPath" --validate-app -f ${exportIpaPath}/${scheme_name}.ipa -u xxxx [-p xxx]
    "$altoolPath" --upload-app -f ${exportIpaPath}/${scheme_name}.ipa -u  xxxx -p xxx
else

    echo "请输入你要发布的平台 ? [ 1:fir 2:蒲公英] "
    ##
    read platform
        while([[ $platform != 1 ]] && [[ $platform != 2 ]])
        do
            echo "笨蛋,只能输入 1 or 2"
            echo "请输入你要发布的平台 ? [ 1:fir 2:蒲公英] "
            read platform
        done

            if [ $platform == 1 ];
                then
                #上传到Fir
                # 将XXX替换成自己的Fir平台的token
                fir login -T xxxx
                fir publish $exportIpaPath/$scheme_name.ipa
            else
                echo "开始上传到蒲公英"
                #上传到蒲公英
                #蒲公英aipKey
                MY_PGY_API_K=xxx
                #蒲公英uKey
                MY_PGY_UK=xxxx

                curl -F "file=@${exportIpaPath}/${scheme_name}.ipa" -F "uKey=${MY_PGY_UK}" -F "_api_key=${MY_PGY_API_K}" https://qiniu-storage.pgyer.com/apiv1/app/upload
            fi
fi
echo "\n\n"
echo "已运行完毕>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>"
exit 0
image.png

以上均是在我使用手动签名的情况,自动签名我用了下坑更多,他会自动为你创建profile文件关键是你每执行一次就会创建一个,后来无奈我就用手动的了。

所以这个坑的原因是啥我也不知道,也希望有知道的能告诉我一声,这个坑怎么过。如果我知道了后续这个博客也会更新。

上一篇下一篇

猜你喜欢

热点阅读