1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-04 11:51:02 +01:00

Projects - smooth out scenarios around renaming a project and slugs

Summary:
Fixes T7092. When you name project "Foo" which has primary hashtag "foo" to "Foobar", post this patch the hashtag "foo" gets added as a secondary hashtag. Also makes sure we don't normalize the hashtags in the query function as the wikimedia folks were hitting an issue around capitalization on the hashtag.

Note that T6909 remains "broken" in that you get an error that you can't do that, though if you just omit the additional hashtag it would work fine. I think if a fix is necessary here the best bet would be to simply detect this particular scenario and let things proceed; its a bit tricky though since its about two transactions about to be applied and how they interact with one another...

Test Plan: Made project "Foo" which has primary hashtag "foo". Renamed it to "Foobar" and verified "foo" was added as a secondary hashtag and "foobar" was the primary hashtag. Renamed it again to "Foo" and noted that the hashtags all ended up correct.

Reviewers: epriestley

Reviewed By: epriestley

Subscribers: Korvin, epriestley

Maniphest Tasks: T7092, T6909

Differential Revision: https://secure.phabricator.com/D11697
This commit is contained in:
Bob Trahan 2015-02-09 15:48:17 -08:00
parent 5b1ea8c8d5
commit ac504f232f
2 changed files with 12 additions and 26 deletions

View file

@ -82,6 +82,7 @@ final class PhabricatorProjectTransactionEditor
switch ($xaction->getTransactionType()) { switch ($xaction->getTransactionType()) {
case PhabricatorProjectTransaction::TYPE_NAME: case PhabricatorProjectTransaction::TYPE_NAME:
$object->setName($xaction->getNewValue()); $object->setName($xaction->getNewValue());
// TODO - this is really "setPrimarySlug"
$object->setPhrictionSlug($xaction->getNewValue()); $object->setPhrictionSlug($xaction->getNewValue());
return; return;
case PhabricatorProjectTransaction::TYPE_SLUGS: case PhabricatorProjectTransaction::TYPE_SLUGS:
@ -127,19 +128,12 @@ final class PhabricatorProjectTransactionEditor
switch ($xaction->getTransactionType()) { switch ($xaction->getTransactionType()) {
case PhabricatorProjectTransaction::TYPE_NAME: case PhabricatorProjectTransaction::TYPE_NAME:
// First, remove the old and new slugs. Removing the old slug is // First, add the old name as a secondary slug; this is helpful
// important when changing the project's capitalization or punctuation. // for renames and generally a good thing to do.
// Removing the new slug is important when changing the project's name
// so that one of its secondary slugs is now the primary slug.
if ($old !== null) { if ($old !== null) {
$this->removeSlug($object, $old); $this->addSlug($object, $old);
} }
$this->removeSlug($object, $new); $this->addSlug($object, $new);
$new_slug = id(new PhabricatorProjectSlug())
->setSlug($object->getPrimarySlug())
->setProjectPHID($object->getPHID())
->save();
return; return;
case PhabricatorProjectTransaction::TYPE_SLUGS: case PhabricatorProjectTransaction::TYPE_SLUGS:
@ -429,7 +423,7 @@ final class PhabricatorProjectTransactionEditor
return parent::extractFilePHIDsFromCustomTransaction($object, $xaction); return parent::extractFilePHIDsFromCustomTransaction($object, $xaction);
} }
private function removeSlug( private function addSlug(
PhabricatorLiskDAO $object, PhabricatorLiskDAO $object,
$name) { $name) {
@ -441,16 +435,13 @@ final class PhabricatorProjectTransactionEditor
'slug = %s', 'slug = %s',
$slug); $slug);
if (!$slug_object) { if ($slug_object) {
return; return;
} }
if ($slug_object->getProjectPHID() != $object->getPHID()) { $new_slug = id(new PhabricatorProjectSlug())
throw new Exception( ->setSlug($slug)
pht('Trying to remove slug owned by another project!')); ->setProjectPHID($object->getPHID())
->save();
} }
$slug_object->delete();
}
} }

View file

@ -278,15 +278,10 @@ final class PhabricatorProjectQuery
} }
if ($this->slugs !== null) { if ($this->slugs !== null) {
$slugs = array();
foreach ($this->slugs as $slug) {
$slugs[] = rtrim(PhabricatorSlug::normalize($slug), '/');
}
$where[] = qsprintf( $where[] = qsprintf(
$conn_r, $conn_r,
'slug.slug IN (%Ls)', 'slug.slug IN (%Ls)',
$slugs); $this->slugs);
} }
if ($this->phrictionSlugs !== null) { if ($this->phrictionSlugs !== null) {