您好,欢迎来到二三娱乐。
搜索
您的当前位置:首页Podfile.lock内 Spec CHECKSUMS 改变的

Podfile.lock内 Spec CHECKSUMS 改变的

来源:二三娱乐

Lockfiles 是什么?

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版本。

~/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。在一个分支中,举例来说:

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安装

作者:

Copyright © 2019- yule263.com 版权所有 湘ICP备2023023988号-1

违法及侵权请联系:TEL:199 1889 7713 E-MAIL:2724546146@qq.com

本站由北京市万商天勤律师事务所王兴未律师提供法律服务