我设法弄乱了我的巡航控制项目。
当我移动到新的源代码控制主机时,我正在更新持续集成服务器上的项目存储库的Git URL。我有点剪切和粘贴愉快并将存储库的错误URL粘贴到原点。所以下次Cruise Control做了一次拉动它合并并拉出了许多不应该存放在存储库中的东西。
一旦我意识到自己的错误,我认为不是问题,我只是删除有问题的存储库并使用正确的网址进行克隆。
除了Cruise Control似乎已经记住了混乱的存储库中的最后一个更改集,并且当决定是否需要进行新构建时,它会抛出一个不合适的东西。无论如何,这就是我猜的。当它发出git log命令时,它说它无法在清理后的资源库中找到更改集。
它发出的命令是:
git log 66cd57438ea42b4f8cb6dbf033dc1162f61a4d54..origin/master --name-status --pretty=format:"Commit:%H%nTime:%ci%nAuthor:%an%nE-Mail:%ae%nMessage:%s%n%n%b%nChanges:" -m
Git的回应是
Source control operation failed: fatal: Invalid revision range 66cd57438ea42b4f8cb6dbf033dc1162f61d5e65..origin/master
变更集ID肯定不存在于正确的存储库中,但存在于我错误合并的存储库中。
如何让Cruise Control .net忘记duff变更集ID?
答案 0 :(得分:7)
CruiseControl.net将最后一次提交的ID存储在每个项目state
文件中。
这些通常是驻留在服务器目录中的文本文件(c:\ Program Files(x86)\ CruiseControl.NET \ server)
e.g。 状态文件可以包含:
<IntegrationResult xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" scmError="false">
<ProjectName>Project1</ProjectName>
...
<Label>1.2.3.4</Label>
<Parameters>
...
<NameValuePair name="$LastChangeNumber" value="66cd57438ea42b4f8cb6dbf033dc1162f61a4d54" />
</Parameters>
<LastSuccessfulIntegrationLabel>1.2.3.4</LastSuccessfulIntegrationLabel>
<SourceControl name="commit" value="66cd57438ea42b4f8cb6dbf033dc1162f61a4d54" />
</IntegrationResult>
您可以修改此文件以包含与正确的存储库相关的提交ID;但是你必须先停止CruiseControl。一旦改变了服务器/服务并且一切都很好,就重新启动服务器/服务。
唯一需要更改的行是:
<SourceControl name="commit" value="66cd57438ea42b4f8cb6dbf033dc1162f61a4d54" />
其他属性可以保留原样;它们只是最后一次构建的属性。