【发布时间】:2017-01-21 10:54:49
【问题描述】:
目的:
作为质量检查,我们需要确保所有合格的修订都合并到所有更高的修订。
示例:
Release_10 --> Release_11
在 TortoiseSVN 中,通过单击“显示日志”按钮很容易找出哪些修订已被合并。合并的修订通过格式和合并图标清楚地区分。
你也可以通过纯SVN列出所有合并的修订:
C:\Release_11>svn mergeinfo --show-revs merged https://svn_repo/project/branches/releases/Release_10
r32894
r32897
r32901
r32903
r32929
r32987
r32994
r32996
r33006
r33017
r33020
r33021
r33041
r33045
r33077
目前,我有列出所有修订信息的代码:
SVNURL svnURL = SVNURL.parseURIEncoded(url);
SVNRepository repository = SVNRepositoryFactory.create(svnURL);
BasicAuthenticationManager authManager = BasicAuthenticationManager.newInstance("username", "password".toCharArray());
authManager.setProxy("00.00.00.00", 8080, null, (char[])null);
repository.setAuthenticationManager(authManager);
@SuppressWarnings("unchecked")
Collection<SVNLogEntry> logEntries = repository.log(new String[] { "" }, null, 0, -1, true, true);
现在我只需要弄清楚哪些已经被合并了。
偏好:
- 一次调用 repo 以获取所有合并的修订。 (或者更好的是:一次调用即可获取所有修订以及它们是否被合并。)
- 不希望本地结帐 SVN 存储库。
注意事项:
- 使用 SVNKIT v1.8.14,但未锁定特定版本。
【问题讨论】:
-
你使用的是哪个版本的 svnkit?
-
SVNKIT: v1.8.14