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

[LiskDAO] make objects ephemeral, aka read-only

Summary:
Make any Lisk object ephemeral, aka read-only, so that we can fiddle
around with their state safe in the knowledge that we'll never end up
writing that updated state back to the db.

Test Plan: Added a new test; ran test suite.

Reviewers: epriestley

Reviewed By: epriestley

CC: aran, epriestley

Differential Revision: https://secure.phabricator.com/D1836
This commit is contained in:
Edward Speyer 2012-03-08 14:35:12 -08:00
parent 579941b866
commit 3901c8493d
5 changed files with 59 additions and 1 deletions

View file

@ -401,6 +401,7 @@ phutil_register_library_map(array(
'JavelinViewExample' => 'applications/uiexample/examples/client', 'JavelinViewExample' => 'applications/uiexample/examples/client',
'JavelinViewExampleServerView' => 'applications/uiexample/examples/client', 'JavelinViewExampleServerView' => 'applications/uiexample/examples/client',
'LiskDAO' => 'storage/lisk/dao', 'LiskDAO' => 'storage/lisk/dao',
'LiskEphemeralObjectException' => 'storage/lisk/dao',
'LiskIsolationTestCase' => 'storage/lisk/dao/__tests__', 'LiskIsolationTestCase' => 'storage/lisk/dao/__tests__',
'LiskIsolationTestDAO' => 'storage/lisk/dao/__tests__', 'LiskIsolationTestDAO' => 'storage/lisk/dao/__tests__',
'LiskIsolationTestDAOException' => 'storage/lisk/dao/__tests__', 'LiskIsolationTestDAOException' => 'storage/lisk/dao/__tests__',

View file

@ -193,6 +193,8 @@ abstract class LiskDAO {
private static $processIsolationLevel = 0; private static $processIsolationLevel = 0;
private static $__checkedClasses = array(); private static $__checkedClasses = array();
private $__ephemeral = false;
/** /**
* Build an empty object. * Build an empty object.
* *
@ -778,6 +780,24 @@ abstract class LiskDAO {
/* -( Writing Objects )---------------------------------------------------- */ /* -( Writing Objects )---------------------------------------------------- */
/**
* Make an object read-only.
*
* Making an object ephemeral indicates that you will be changing state in
* such a way that you would never ever want it to be written to back to the
* storage.
*/
public function makeEphemeral() {
$this->__ephemeral = true;
return $this;
}
private function isEphemeralCheck() {
if ($this->__ephemeral) {
throw new LiskEphemeralObjectException();
}
}
/** /**
* Persist this object to the database. In most cases, this is the only * Persist this object to the database. In most cases, this is the only
* method you need to call to do writes. If the object has not yet been * method you need to call to do writes. If the object has not yet been
@ -805,6 +825,7 @@ abstract class LiskDAO {
* @task save * @task save
*/ */
public function replace() { public function replace() {
$this->isEphemeralCheck();
return $this->insertRecordIntoDatabase('REPLACE'); return $this->insertRecordIntoDatabase('REPLACE');
} }
@ -818,6 +839,7 @@ abstract class LiskDAO {
* @task save * @task save
*/ */
public function insert() { public function insert() {
$this->isEphemeralCheck();
return $this->insertRecordIntoDatabase('INSERT'); return $this->insertRecordIntoDatabase('INSERT');
} }
@ -831,6 +853,7 @@ abstract class LiskDAO {
* @task save * @task save
*/ */
public function update() { public function update() {
$this->isEphemeralCheck();
$use_locks = $this->getConfigOption(self::CONFIG_OPTIMISTIC_LOCKS); $use_locks = $this->getConfigOption(self::CONFIG_OPTIMISTIC_LOCKS);
$this->willSaveObject(); $this->willSaveObject();
@ -899,6 +922,7 @@ abstract class LiskDAO {
* @task save * @task save
*/ */
public function delete() { public function delete() {
$this->isEphemeralCheck();
$this->willDelete(); $this->willDelete();
$conn = $this->establishConnection('w'); $conn = $this->establishConnection('w');

View file

@ -0,0 +1,19 @@
<?php
/*
* Copyright 2012 Facebook, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
final class LiskEphemeralObjectException extends Exception {}

View file

@ -16,3 +16,4 @@ phutil_require_module('phutil', 'utils');
phutil_require_source('LiskDAO.php'); phutil_require_source('LiskDAO.php');
phutil_require_source('LiskEphemeralObjectException.php');

View file

@ -1,7 +1,7 @@
<?php <?php
/* /*
* Copyright 2011 Facebook, Inc. * Copyright 2012 Facebook, Inc.
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -38,6 +38,19 @@ class LiskIsolationTestCase extends PhabricatorTestCase {
$this->assertEqual($phid, $dao->getPHID(), 'Expect PHID unchanged.'); $this->assertEqual($phid, $dao->getPHID(), 'Expect PHID unchanged.');
} }
public function testEphemeral() {
$dao = new LiskIsolationTestDAO();
$dao->save();
$dao->makeEphemeral();
$this->assertException(
'LiskEphemeralObjectException',
function() use ($dao) {
$dao->save();
}
);
}
public function testIsolationContainment() { public function testIsolationContainment() {
$dao = new LiskIsolationTestDAO(); $dao = new LiskIsolationTestDAO();