6

我正在尝试使用 OSX 服务器设置 Xcode 机器人。在配置了 git 存储库并创建了一个机器人之后,我运行了集成。它失败了,因为存储库仅被部分签出。更准确地说:在配置的 6 个子模块中,只有 3 个被初始化和检出。

didi@mac:/Library/Server/Xcode/Data/BotRuns/Cache/c5fda8f4-4d25-4d25-c18a-eb0b16a06692/source$ git submodule status
+c6e8420aec4147641fb1ca12d9f1d31bdd804e77 libs/asi-http-request (v1.7-320-gc6e8420)
-ae64a38766b42f236bb94f0e661cddb829f9ac43 libs/kraken
-7da02b323636bbaa0bbbf5b4eb229fcc07b1e14a libs/route-me
 152f9ee5576e710705a49032253d7d5af5366f9c libs/routing (152f9ee)
 347aaf74fe0c6388785095efdbf6397851514b7f libs/rtlabel (1.0-32-g347aaf7)
-562cf6b1c879f03546f5184e012cea15c4f159db libs/skmaps

(- 表示未初始化)

查看机器人日志,似乎只是忽略了子模块初始化部分中缺少的子模块:

...
Checking connectivity... done
Submodule 'libs/asi-http-request' (https://github.com/BikeCityGuide/asi-http-request.git) registered for path 'libs/asi-http-request'
Submodule 'libs/routing' (ssh://mac_ci@rooty.bikecityguide.org/var/repos/librouting.git) registered for path 'libs/routing'
Submodule 'libs/rtlabel' (https://github.com/BikeCityGuide/RTLabel.git) registered for path 'libs/rtlabel'
Cloning into 'libs/asi-http-request'...
...

这里或其他任何地方都没有错误消息。在日志中的任何地方都没有提到例如“kraken”(丢失子模块的名称)。

手动签出时(克隆、子模块初始化、子模块更新),所有子模块都被初始化。

.gitmodules 看起来像这样:

$ cat .gitmodules 
[submodule "libs/asi-http-request"]
    path = libs/asi-http-request
    url = https://github.com/BikeCityGuide/asi-http-request.git
[submodule "libs/rtlabel"]
    path = libs/rtlabel
    url = https://github.com/BikeCityGuide/RTLabel.git
[submodule "libs/routing"]
    path = libs/routing
    url = ../librouting.git
[submodule "libs/kraken"]
    path = libs/kraken
    url = ../kraken_ios.git
[submodule "libs/route-me"]
    path = libs/route-me
    url = ../route-me.git
[submodule "libs/skmaps"]
    path = libs/skmaps
    url = ../skmaps.git

相对 URL 引用的基础存储库和 4 个子模块存储库都需要 ssh 身份验证。在 OSX 服务器中设置的用户可以访问所有这些。bot 的日志中没有任何试图拉取丢失子模块的痕迹。

我可以手动修复本地存储库,但我不想在添加新项目和新子模块时再次遇到同样的问题。

git 版本 1.8.4.2

我没主意了。

4

3 回答 3

13

在 Xcode 6.1.1 和 OS X Server 4.0 上,看起来他们修复了带有分离 HEAD 问题的子模块,但仍然存在一些错误。我的一个项目的一个子模块被 Xcode Server 完全忽略,因此应用程序无法构建:

$ git submodule
 8a88bc41c9dc0f57c921d82bc4e7b93e1c4cbf7a InAppStore (heads/master)
 e4203f9f61d2546868c1274da5c7a0c56b87a737 Libraries (heads/master)  <--- IGNORED
 01902f255e6c3d90f0db41cb62dd2934098b98dd MixpanelTracker (heads/master)
 e2bee59accd817d50dff881a42c9e9afe307226f XLFacility (1.4.1-5-ge2bee59)

对我来说,解决方法是添加一个预集成脚本触发器,如下所示:

cd "$XCS_SOURCE_DIR/{YOUR_APP_REPO_NAME_WITHOUT_DOT_GIT_SUFFIX}"
git submodule update --init --recursive

在这一点上,尽管有关于结帐不干净或类似情况的非致命警告,但事情正在建设中。当我更改机器人的配置以将“清洁”设置为“始终”时,它们就消失了。

于 2015-01-06T09:06:15.410 回答
1

在 Xcode 9 服务器中,如果工作区中的 Xcode 项目之一没有引用子模块的文件,则不会初始化子模块。

例如,当您从不属于您的代码的子模块中包含一个头文件时,可能会发生这种情况,因此您将其添加到“头文件搜索路径”(c/c++)而不是将其添加到项目中。

一种可能的解决方法是将子模块中的至少一个文件添加到 Xcode 项目中。它甚至可以是一个Readme.md文件。这比使用自定义脚本检查子模块更容易,因为它依赖 Xcode Server 来存储您的 GIT 凭据。

于 2018-08-21T21:56:33.793 回答
0

我理解它是一个错误吗?我遇到了同样的问题,发现分离的子模块存在问题。请参阅下一篇展示如何解决此问题的文章(对公共存储库没有帮助) http://ikennd.ac/blog/2013/10/xcode-bots-common-problems-and-workarounds/

希望这对您有所帮助。

于 2014-01-10T23:40:33.467 回答