持续集成两个相互依赖的repos

时间:2012-06-28 11:32:23

标签: git github continuous-integration jenkins

我的系统中有两个“组件”,“天气服务”和“天气消费者”。

重写Weather-server以提供温度REST URI。 weather server位于github仓库中。

天气客户端,需要消耗这个,所以我写了一个新功能。这存储在different github repo

现在无论我提交哪个方式,客户端优先或服务器优先,系统将不会用于第一次提交,只有第二次提交。因此,我的Jenkins服务器将进行完全不必要的构建和测试。

我可以解决这个问题吗?

  1. 我可以在一次提交中提交两个git repos吗?我99.9%肯定没有,但值得检查。
  2. 我可以告诉Jenkins忽略某些提交吗?
  3. 我应该和它一起生活还是有人有其他想法?

    而且,是的,我知道我可以进行测试,看天气服务是否已经开启,但这不是重点。

2 个答案:

答案 0 :(得分:1)

Android Repo是处理多个git repo而不是子模块的好方法。您需要先安装repo,然后:

在Jenkins中,安装repo插件,输入清单文件所在的位置,并且不错。

手动,这样的东西引入了只读和可写的git仓库。

repo init -u git://github.com/rickfoosusa/manifest -m yourmanifest.xml 回购同步

清单文件包含遥控器和项目。

<?xml version="1.0" encoding="UTF-8"?>
<manifest>
  <remote name="github"
        fetch="git://github.com/rickfoosusa" />
  <remote name="rickfoosusa"
        fetch="git@github.com:rickfoosusa" />

  <default remote="github" revision="master"/>

  <project name="openbenchmarks" path="openbenchmarks"/>
  <project remote="rickfoosusa"
           name="myproject"
           path="openbenchmarks/myproject"/>
</manifest>

答案 1 :(得分:0)

我认为你可以告诉Jenkins在进行测试前坚持一两分钟。