From 16b54a6e769c62ccec9d99d8180c15f10f3e9412 Mon Sep 17 00:00:00 2001 From: epriestley Date: Fri, 3 May 2013 16:00:22 -0700 Subject: [PATCH] Successfully Generated Mocks Summary: Ref T2903 Test Plan: Pholio Mocks are being generated successfully. Reviewers: epriestley Reviewed By: epriestley CC: AnhNhan, aran, Korvin Maniphest Tasks: T2903 Differential Revision: https://secure.phabricator.com/D5818 --- ...PhabricatorPholioMockTestDataGenerator.php | 102 ++++++++++++++++++ 1 file changed, 102 insertions(+) create mode 100644 src/applications/pholio/lipsum/PhabricatorPholioMockTestDataGenerator.php diff --git a/src/applications/pholio/lipsum/PhabricatorPholioMockTestDataGenerator.php b/src/applications/pholio/lipsum/PhabricatorPholioMockTestDataGenerator.php new file mode 100644 index 0000000000..e87c2f4c1d --- /dev/null +++ b/src/applications/pholio/lipsum/PhabricatorPholioMockTestDataGenerator.php @@ -0,0 +1,102 @@ +loadPhabrictorUserPHID(); + $author = id(new PhabricatorUser()) + ->loadOneWhere('phid = %s', $authorPHID); + $mock = id(new PholioMock()) + ->setAuthorPHID($authorPHID); + $content_source = PhabricatorContentSource::newForSource( + PhabricatorContentSource::SOURCE_UNKNOWN, + array()); + $template = id(new PholioTransaction()) + ->setContentSource($content_source); + + // Accumulate Transactions + $changes = array(); + $changes[PholioTransactionType::TYPE_NAME] = + $this->generateTitle(); + $changes[PholioTransactionType::TYPE_DESCRIPTION] = + $this->generateDescription(); + $changes[PhabricatorTransactions::TYPE_VIEW_POLICY] = + PhabricatorPolicies::POLICY_PUBLIC; + $changes[PhabricatorTransactions::TYPE_SUBSCRIBERS] = + array('=' => $this->getCCPHIDs()); + + // Get Files and make Images + $filePHIDS = $this->generateImages(); + $files = id(new PhabricatorFileQuery()) + ->setViewer($author) + ->withPHIDs($filePHIDS) + ->execute(); + $mock->setCoverPHID(head($files)->getPHID()); + $sequence = 0; + $images = array(); + foreach ($files as $file) { + $image = new PholioImage(); + $image->setFilePHID($file->getPHID()); + $image->setSequence($sequence++); + $images[] = $image; + } + + // Apply Transactions + $transactions = array(); + foreach ($changes as $type => $value) { + $transaction = clone $template; + $transaction->setTransactionType($type); + $transaction->setNewValue($value); + $transactions[] = $transaction; + } + $mock->openTransaction(); + $editor = id(new PholioMockEditor()) + ->setContentSource($content_source) + ->setContinueOnNoEffect(true) + ->setActor($author) + ->applyTransactions($mock, $transactions); + foreach ($images as $image) { + $image->setMockID($mock->getID()); + $image->save(); + } + + $mock->saveTransaction(); + return $mock->save(); + } + + private function loadPhabrictorUserPHID() { + return $this->loadOneRandom("PhabricatorUser")->getPHID(); + } + + public function generateTitle() { + return id(new PhutilLipsumContextFreeGrammar()) + ->generate(); + } + + public function generateDescription() { + return id(new PhutilLipsumContextFreeGrammar()) + ->generateSeveral(rand(30, 40)); + } + + public function getCCPHIDs() { + $ccs = array(); + for ($i = 0; $i < rand(1, 4);$i++) { + $ccs[] = $this->loadPhabrictorUserPHID(); + } + return $ccs; + } + + public function generateImages() { + $images = newv("PhabricatorFile", array()) + ->loadAllWhere("mimeType = %s", "image/jpeg"); + $rand_images = array(); + $quantity = rand(1, 10); + foreach (array_rand($images, $quantity) as $random) { + $rand_images[] = $images[$random]->getPHID(); + } + return $rand_images; + } + + +}