mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-02 02:40:58 +01:00
Fix an issue with SVN path construction in the presence of subpath configuration
Summary: D7590 made path construction more consistent, but affected this callsite if a subpath is configured. Currently, we end up with double `@@` in the URI. Test Plan: - Ran unit tests. - Ran `bin/repostitory discover`. Reviewers: staticshock, btrahan Reviewed By: btrahan CC: aran Differential Revision: https://secure.phabricator.com/D7619
This commit is contained in:
parent
3a035c02e7
commit
e99c53da2e
3 changed files with 15 additions and 5 deletions
|
@ -88,10 +88,9 @@ final class PhabricatorRepositoryDiscoveryEngine
|
||||||
|
|
||||||
try {
|
try {
|
||||||
list($xml, $stderr) = $repository->execxRemoteCommand(
|
list($xml, $stderr) = $repository->execxRemoteCommand(
|
||||||
'log --xml --quiet --limit %d %s@%s',
|
'log --xml --quiet --limit %d %s',
|
||||||
$limit,
|
$limit,
|
||||||
$repository->getSubversionBaseURI(),
|
$repository->getSubversionBaseURI($at_rev));
|
||||||
$at_rev);
|
|
||||||
} catch (CommandException $ex) {
|
} catch (CommandException $ex) {
|
||||||
$stderr = $ex->getStdErr();
|
$stderr = $ex->getStdErr();
|
||||||
if (preg_match('/(path|File) not found/', $stderr)) {
|
if (preg_match('/(path|File) not found/', $stderr)) {
|
||||||
|
|
|
@ -155,12 +155,12 @@ final class PhabricatorRepository extends PhabricatorRepositoryDAO
|
||||||
return $this->getDetail('local-path');
|
return $this->getDetail('local-path');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getSubversionBaseURI() {
|
public function getSubversionBaseURI($commit = null) {
|
||||||
$subpath = $this->getDetail('svn-subpath');
|
$subpath = $this->getDetail('svn-subpath');
|
||||||
if (!strlen($subpath)) {
|
if (!strlen($subpath)) {
|
||||||
$subpath = null;
|
$subpath = null;
|
||||||
}
|
}
|
||||||
return $this->getSubversionPathURI($subpath);
|
return $this->getSubversionPathURI($subpath, $commit);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getSubversionPathURI($path = null, $commit = null) {
|
public function getSubversionPathURI($path = null, $commit = null) {
|
||||||
|
|
|
@ -94,6 +94,17 @@ final class PhabricatorRepositoryTestCase
|
||||||
$this->assertEqual(
|
$this->assertEqual(
|
||||||
'file:///var/repo/SVN/%3F@22',
|
'file:///var/repo/SVN/%3F@22',
|
||||||
$repo->getSubversionPathURI('?', 22));
|
$repo->getSubversionPathURI('?', 22));
|
||||||
|
|
||||||
|
$repo->setDetail('svn-subpath', 'quack/trunk/');
|
||||||
|
|
||||||
|
$this->assertEqual(
|
||||||
|
'file:///var/repo/SVN/quack/trunk/@',
|
||||||
|
$repo->getSubversionBaseURI());
|
||||||
|
|
||||||
|
$this->assertEqual(
|
||||||
|
'file:///var/repo/SVN/quack/trunk/@HEAD',
|
||||||
|
$repo->getSubversionBaseURI('HEAD'));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue