mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-11 15:21:03 +01:00
Produce a more tailored checkout URI for Subversion
Summary: For imported SVN repositories with an "Import Only" path, we produce a `/path/to/root/` URI, but should produce `/path/to/root/then/to/import/only/`. As it is, the URI instructs the user to check out the whole repository. Also, don't show the "Clone As" fragment in the URI for remote repositories, and prevent it from being edited for nonhosted repositories. This is generally more consistent with user expectation. Test Plan: - Created a remote SVN repository with "Import Only", saw path include it. - Verified no "Clone As" options, no "Clone As" in URI. - Switched it to hosted, saw "Clone As" options appear and work properly. Reviewers: btrahan Reviewed By: btrahan CC: aran, staticshock Differential Revision: https://secure.phabricator.com/D8375
This commit is contained in:
parent
d86bb086ca
commit
a3c1dcb928
5 changed files with 72 additions and 21 deletions
|
@ -560,10 +560,16 @@ final class DiffusionRepositoryController extends DiffusionController {
|
|||
$uri);
|
||||
break;
|
||||
case PhabricatorRepositoryType::REPOSITORY_TYPE_SVN:
|
||||
if ($repository->isHosted()) {
|
||||
$command = csprintf(
|
||||
'svn checkout %R %R',
|
||||
$uri,
|
||||
$repository->getCloneName());
|
||||
} else {
|
||||
$command = csprintf(
|
||||
'svn checkout %R',
|
||||
$uri);
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
||||
|
|
|
@ -36,7 +36,10 @@ final class DiffusionRepositoryEditBasicController
|
|||
$v_name = $request->getStr('name');
|
||||
$v_desc = $request->getStr('description');
|
||||
$v_projects = $request->getArr('projectPHIDs');
|
||||
|
||||
if ($repository->isHosted()) {
|
||||
$v_clone_name = $request->getStr('cloneName');
|
||||
}
|
||||
|
||||
if (!strlen($v_name)) {
|
||||
$e_name = pht('Required');
|
||||
|
@ -99,7 +102,10 @@ final class DiffusionRepositoryEditBasicController
|
|||
->setName('name')
|
||||
->setLabel(pht('Name'))
|
||||
->setValue($v_name)
|
||||
->setError($e_name))
|
||||
->setError($e_name));
|
||||
|
||||
if ($repository->isHosted()) {
|
||||
$form
|
||||
->appendChild(
|
||||
id(new AphrontFormTextControl())
|
||||
->setName('cloneName')
|
||||
|
@ -108,7 +114,10 @@ final class DiffusionRepositoryEditBasicController
|
|||
->setCaption(
|
||||
pht(
|
||||
'Optional directory name to use when cloning or checking out '.
|
||||
'this repository.')))
|
||||
'this repository.')));
|
||||
}
|
||||
|
||||
$form
|
||||
->appendChild(
|
||||
id(new PhabricatorRemarkupControl())
|
||||
->setName('description')
|
||||
|
|
|
@ -256,11 +256,13 @@ final class DiffusionRepositoryEditMainController
|
|||
|
||||
$clone_name = $repository->getDetail('clone-name');
|
||||
|
||||
if ($repository->isHosted()) {
|
||||
$view->addProperty(
|
||||
pht('Clone/Checkout As'),
|
||||
$clone_name
|
||||
? $clone_name.'/'
|
||||
: phutil_tag('em', array(), $repository->getCloneName().'/'));
|
||||
}
|
||||
|
||||
$project_phids = PhabricatorEdgeQuery::loadDestinationPHIDs(
|
||||
$repository->getPHID(),
|
||||
|
|
|
@ -789,8 +789,29 @@ final class PhabricatorRepository extends PhabricatorRepositoryDAO
|
|||
*/
|
||||
public function getCloneURIObject() {
|
||||
if (!$this->isHosted()) {
|
||||
if ($this->isSVN()) {
|
||||
// Make sure we pick up the "Import Only" path for Subversion, so
|
||||
// the user clones the repository starting at the correct path, not
|
||||
// from the root.
|
||||
$base_uri = $this->getSubversionBaseURI();
|
||||
$base_uri = new PhutilURI($base_uri);
|
||||
$path = $base_uri->getPath();
|
||||
if (!$path) {
|
||||
$path = '/';
|
||||
}
|
||||
|
||||
// If the trailing "@" is not required to escape the URI, strip it for
|
||||
// readability.
|
||||
if (!preg_match('/@.*@/', $path)) {
|
||||
$path = rtrim($path, '@');
|
||||
}
|
||||
|
||||
$base_uri->setPath($path);
|
||||
return $base_uri;
|
||||
} else {
|
||||
return $this->getRemoteURIObject();
|
||||
}
|
||||
}
|
||||
|
||||
// Choose the best URI: pick a read/write URI over a URI which is not
|
||||
// read/write, and SSH over HTTP.
|
||||
|
|
|
@ -90,6 +90,19 @@ final class PhabricatorRepositoryURITestCase
|
|||
$this->assertEqual('git@example.com:path.git',
|
||||
$repo->getRemoteURIEnvelope()->openEnvelope());
|
||||
|
||||
// Test SVN "Import Only" paths.
|
||||
|
||||
$repo->setDetail('remote-uri', 'http://example.com/');
|
||||
$repo->setVersionControlSystem($svn);
|
||||
$repo->setDetail('svn-subpath', 'projects/example/');
|
||||
|
||||
$this->assertEqual('http://example.com/', $repo->getRemoteURI());
|
||||
$this->assertEqual(
|
||||
'http://example.com/projects/example/',
|
||||
$repo->getPublicCloneURI());
|
||||
$this->assertEqual('http://example.com/',
|
||||
$repo->getRemoteURIEnvelope()->openEnvelope());
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue