利用了两天时间建八个测试项目各种报错,今天终于有所收获,此文章贡献给和我一样还在摸索的人,希望能有点帮助,也便于以后查阅!
大致步骤:
1、利用码云新建一个项目,以及ssh密钥等配置
2、创建并设置一个私有的Spec Repo
3、创建pod所需要的项目工程文件
4、验证本地配置的podspec文件是否可用
5、测试
6、更新维护podspec
7、小偏方
第一:利用码云新建一个项目,以及ssh密钥等配置 参考码云基本操作,创建成功后的项目。
第二:创建并设置一个私有的Spec Repo
在码云中打开创建的项目工程,页面右边会有克隆/下载按钮,点击复制HTTPS地址
打开Terminal,执行如下命令
命令格式# pod repo add [Private Repo Name(最好和项目名保持一致)] [码云HTTPS clone URL]
$ pod repo add TestTools https://git.oschina.net/helen_add/testtools.git
详情:如果有遇到需要输入username和password的输入回车就可以了
YRdeMacBook-Air:~ yr$ pod repo add TestTools https://git.oschina.net/helen_add/testtools.git
Cloning spec repo `TestTools` from `https://git.oschina.net/helen_add/testtools.git`
检查是否安装成功
$ cd ~/.cocoapods/repos/TestTools
$ pod repo lint . (注意:“ .” 不能省略)
第三:创建Pod项目工程文件
将路径切换到放项目的文件夹下:
$ cd /Users/yr/Desktop/T9 (没错这是我创的第九个测试文件)
$ pod lib create TestTools 创建pod文件
创建过程中需要回答问题
What language do you want to use?? [ Swift / ObjC ] 直接输入Objc 不输入直接回车默认选择第一个,以下几个问题都是。
Would you like to include a demo application with your library? [ Yes / No ]
Which testing frameworks will you use? [ Specta / Kiwi / None ]
Would you like to do view based testing? [ Yes / No ]
What is your class prefix?
问题回答:Objc - Yes - Specta - Yes - TT (供参考)
为了模拟代码提交过程,这里利用Xcode新建了一个.m和.h文件,在.m文件中随便写了几句代码,找到下面文件路径,将创建的.m和.h文件放到Classes文件夹下
将路径切换到Example文件夹下,执行pod install,用xcode打开Example下的pod管理的项目,根据下图路径查看,你会看到放Classe下的文件,到了Demo的pod中,这只是本地的成功。
插句嘴:每当你向TestTools中添加了新的文件或者以后更新了podspec的版本都需要重新执行一遍pod update命令。
继续将本地仓库关联到远程仓库,一步步执行下面命令
$ cd /Users/yr/Desktop/T9/TestTools 切换到项目目录下
$ git add .
$ git commit -s -m "Initial Commit of Tools"
$ git remote add origin https://git.oschina.net/helen_add/testtools.git (之前复制的码云中的下载地址)
$ git push -u origin master //报错
报错信息:
To https://git.oschina.net/helen_add/testtools.git
! [rejected] master -> master (fetch first)
error: failed to push some refs to 'https://git.oschina.net/helen_add/testtools.git'
hint: Updates were rejected because the remote contains work that you do
hint: not have locally. This is usually caused by another repository pushing
hint: to the same ref. You may want to first integrate the remote changes
hint: (e.g., 'git pull ...') before pushing again.
hint: See the 'Note about fast-forwards' in 'git push --help' for details.
继续执行
$ git fetch
$ git push --force origin master //直接强推,成功
信息:
Counting objects: 241, done.
Delta compression using up to 4 threads.
Compressing objects: 100% (230/230), done.
Writing objects: 100% (241/241), 122.05 KiB | 0 bytes/s, done.
Total 241 (delta 49), reused 0 (delta 0)
To https://git.oschina.net/helen_add/testtools.git
+ dc12b7c...ccb5dae master -> master (forced update)
完成后可以去码云查看工程
第四、验证本地配置的podspec文件是否可用
因为podspec文件中获取Git版本控制的项目还需要tag号,所以先打个tag
$ git tag -m "first release" 0.1.0
$ git push --tags 推送tags到远程仓库
$ git tag 查看tag
接下来podspec文件的编写,根据下面路径找到podspec文件,双击打开
如下图,简单设置需要更改的地方,设置homepage通过前提是你的项目是公开的,更多配置信息可以参考podspec文件配置
设置完成后继续执行,检查podspec是否可用
$ pod lib lint
成功输出:
-> TestTools (0.1.0)
TestTools passed validation.
如果有错误,根据提示一一修改
将修改的文件提交到远端仓库
$ git add .
$ git commit -m "set podsepc"
$ git push --set-upstream origin master
5、测试,能否将穿件的TestTools通过pod拉取到项目中,在一个pod管理的项目,打开podfile,加入
pod ’TestTools’, :git=>’git@git.oschina.net:helen_add/testtools.git’
执行pod install,打开项目,在pods下会看到刚添加的TestTools成功!
6、维护和更新
如果想加入一个装icon的文件夹,直接把文件拖到和Classe同级
重新打卡TestTools.podspec文件,然后重新上传修改的文件代码到远端仓库,在使用pod install更新就可以使用添加的图片啦!文件夹为空编辑 pod lint lib 会报错
附上demo地址:码云地址
7、还有这样的操作!!!
编译podspec时候可以先不在Classes里面放代码 等编译通过 提交成功 可以从pod上拉这个库后 再在Classes中添加你的库代码 这样做的好处就是podspec文件配置内容后 执行pod lib lint 时候非常容易报错 要求代码可以正常运行 但是等你podspec可是正常使用成后直接提交代码到git上就可以了 错误代码也没关系 (偏方)