本文翻译自:Why does my team's Podfile.lock Podspec checksums change
在开发我们最快的移动应用程序 Eigen 时,使用CocoaPods,并不会将 Pods目录保留在源代码控制下 。 当开发人员的Pods具有不同的SHA 校验和(CHECKSUMS)时,这有时会导致Podfile.lock内的有趣的数据流失。 这很奇怪,怎么会这样?
Lockfiles 是什么?
首先,为确保我们谈论同样的事儿,这是我们的Podfile.lock。在pod安装中使用lockfile来确保您的团队的所有成员具有彼此完全相同的库版本。另外,Podfile文件:
platform :ios, '9.3'
pod 'AFNetworking/Serialization', '~> 3.0'
target 'MyApp'
运行pod安装的开发人员将获得最新的3.x版本,最初可能是3.1版本,但是6个月后,他们可以获得3.4 - 没有锁定文件,没有办法跟踪具体的构建。这就是为什么它应该永远在你的代码库。在上面的情况下,我的lockfile看起来像这样:
PODS:
- AFNetworking/Serialization (3.1.0)
DEPENDENCIES:
- AFNetworking/Serialization (~> 3.0)
SPEC CHECKSUMS:
AFNetworking: 5e0e199f73d8626b11e79750991f5d173d1f8b67
PODFILE CHECKSUM: 876ceaa409f4ade2b3d58d310dbe026393824bcc
COCOAPODS: 1.0.0.beta.8
Spec CHECKSUMS能做什么?
通过CocoaPods Master Specs repo,我们尽最大努力确保为公众提供一个一次性的Podspecs存储库。不过,您无法保证每个人都拥有与团队中其他人一样的Podspec版本。
所以,CocoaPods对您的Podspec的JSON表示进行校验和,并将其保存在锁定文件中。你可以复制这段代码就能很容易的生成CHECKSUMS:
~/D/MyApp ⏛ pod ipc spec ~/.cocoapods/repos/master/Specs/AFNetworking/3.1.0/AFNetworking.podspec.json | openssl sha1
5e0e199f73d8626b11e79750991f5d173d1f8b67
那为什么我看到流失?
使用git仓库,正常的git开发流程是:
拉取一个分支,更改podfile文件
项目开发
提交到主分支
更新Podspec文件,更新到最新Tag的版本
CocoaPods在后台更新更新仓库做的很十分聪明,但是它并不完美。为了避免重新创建整个Pods文件夹,每次它会检查您的库是否处于预期版本,并跳过重新创建整个过程。
在上面的例子中,我们使用了CocoaPods的Specs repo版本的Podspec。在一个分支中,举例来说:
pod 'AFNetworking/Serialization', :git => "https://github.com/orta/AFNetworking.git", :commit => "6f31b5c7bcbd59d4dac7e92e215d3c2c22f3400e"
Podspec在Pods / Local \ Podspecs / AFNetworking.podspec.json中以JSON格式保存到Pods目录中,这是为了确保在Cocodopods沙盒中始终可以访问Podspecs,并且会适当的加快访问速度。这就是podspec用于生成校验和的原因。
那么这怎么会不同步?
• 在开发周期中,使用库时,您将使用pod update [library]来更新正在使用的库。您可以多次使用。
• PR你在分支上继续做开发,直到你准备要代码审查。此时,你有一个正在开发的版本,你在本地仓库提交了一个PR版用于代码审查。
• 有一些修改影响到podspec的审查,你并没有使用pod update [library]更新仓库,而是回滚了代码(例如,你更改了一些元数据,这不保证另一个更新通过CI 。)
• 一旦所有的代码都审核完,所有的修改都被merge到master分支上
• 运行 pod install - 继续在Pods目录中使用Podspec的旧版本 ,例如:
Pods/Local\ Podspecs/AFNetworking.podspec.json.
• 现在,您的本地Pods文件夹中有较旧的AFNetworking.podspec.json,当下一个人运行pod install并将更改合并时,他们会获得不同的SHA,因为它们具有元数据更改的版本。
简单修复
最好的选择是在导致流失的计算机上运行pod update [library],这将告诉CocoaPods专门请求一个新版本的库。如果没有给出与您的团队其余部分相同的校验和,那么有一个很好的老朋友:
rm -rf Pods && pod安装
作者: