/libs/PHPUnit-3.4.2/PHPUnit/Extensions/Database/DataSet/TableMetaDataFilter.php

https://github.com/quimateur/SIFO · PHP · 176 lines · 53 code · 15 blank · 108 comment · 2 complexity · 4c76292f5df70facf0b3613dd8f9aa74 MD5 · raw file

  1. <?php
  2. /**
  3. * PHPUnit
  4. *
  5. * Copyright (c) 2002-2009, Sebastian Bergmann <sb@sebastian-bergmann.de>.
  6. * All rights reserved.
  7. *
  8. * Redistribution and use in source and binary forms, with or without
  9. * modification, are permitted provided that the following conditions
  10. * are met:
  11. *
  12. * * Redistributions of source code must retain the above copyright
  13. * notice, this list of conditions and the following disclaimer.
  14. *
  15. * * Redistributions in binary form must reproduce the above copyright
  16. * notice, this list of conditions and the following disclaimer in
  17. * the documentation and/or other materials provided with the
  18. * distribution.
  19. *
  20. * * Neither the name of Sebastian Bergmann nor the names of his
  21. * contributors may be used to endorse or promote products derived
  22. * from this software without specific prior written permission.
  23. *
  24. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  25. * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  26. * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
  27. * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
  28. * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
  29. * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
  30. * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
  31. * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
  32. * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  33. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
  34. * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
  35. * POSSIBILITY OF SUCH DAMAGE.
  36. *
  37. * @category Testing
  38. * @package PHPUnit
  39. * @author Mike Lively <m@digitalsandwich.com>
  40. * @copyright 2002-2009 Sebastian Bergmann <sb@sebastian-bergmann.de>
  41. * @license http://www.opensource.org/licenses/bsd-license.php BSD License
  42. * @version SVN: $Id: TableMetaDataFilter.php 4594 2009-02-01 06:48:11Z sb $
  43. * @link http://www.phpunit.de/
  44. * @since File available since Release 3.2.0
  45. */
  46. require_once 'PHPUnit/Framework.php';
  47. require_once 'PHPUnit/Util/Filter.php';
  48. require_once 'PHPUnit/Extensions/Database/DataSet/AbstractTableMetaData.php';
  49. PHPUnit_Util_Filter::addFileToFilter(__FILE__, 'PHPUNIT');
  50. /**
  51. * A TableMetaData decorator that allows filtering columns from another
  52. * metaData object.
  53. *
  54. * The if a whitelist (include) filter is specified, then only those columns
  55. * will be included.
  56. *
  57. * @category Testing
  58. * @package PHPUnit
  59. * @author Mike Lively <m@digitalsandwich.com>
  60. * @copyright 2009 Mike Lively <m@digitalsandwich.com>
  61. * @license http://www.opensource.org/licenses/bsd-license.php BSD License
  62. * @version Release: 3.4.2
  63. * @link http://www.phpunit.de/
  64. * @since Class available since Release 3.2.0
  65. */
  66. class PHPUnit_Extensions_Database_DataSet_TableMetaDataFilter extends PHPUnit_Extensions_Database_DataSet_AbstractTableMetaData
  67. {
  68. /**
  69. * The table meta data being decorated.
  70. * @var PHPUnit_Extensions_Database_DataSet_ITableMetaData
  71. */
  72. protected $originalMetaData;
  73. /**
  74. * The columns to exclude from the meta data.
  75. * @var Array
  76. */
  77. protected $excludeColumns = array();
  78. /**
  79. * The columns to include from the meta data.
  80. * @var Array
  81. */
  82. protected $includeColumns = array();
  83. /**
  84. * Creates a new filtered table meta data object filtering out
  85. * $excludeColumns.
  86. *
  87. * @param PHPUnit_Extensions_Database_DataSet_ITableMetaData $originalMetaData
  88. * @param array $excludeColumns - Deprecated. Use the set* methods instead.
  89. */
  90. public function __construct(PHPUnit_Extensions_Database_DataSet_ITableMetaData $originalMetaData, Array $excludeColumns = array())
  91. {
  92. $this->originalMetaData = $originalMetaData;
  93. $this->addExcludeColumns($excludeColumns);
  94. }
  95. /**
  96. * Returns the names of the columns in the table.
  97. *
  98. * @return array
  99. */
  100. public function getColumns()
  101. {
  102. if (!empty($this->includeColumns)) {
  103. return array_values(array_intersect($this->originalMetaData->getColumns(), $this->includeColumns));
  104. }
  105. elseif (!empty($this->excludeColumns)) {
  106. return array_values(array_diff($this->originalMetaData->getColumns(), $this->excludeColumns));
  107. }
  108. else {
  109. return $this->originalMetaData->getColumns();
  110. }
  111. }
  112. /**
  113. * Returns the names of the primary key columns in the table.
  114. *
  115. * @return array
  116. */
  117. public function getPrimaryKeys()
  118. {
  119. return $this->originalMetaData->getPrimaryKeys();
  120. }
  121. /**
  122. * Returns the name of the table.
  123. *
  124. * @return string
  125. */
  126. public function getTableName()
  127. {
  128. return $this->originalMetaData->getTableName();
  129. }
  130. /**
  131. * Sets the columns to include in the table.
  132. * @param Array $includeColumns
  133. */
  134. public function addIncludeColumns(Array $includeColumns)
  135. {
  136. $this->includeColumns = array_unique(array_merge($this->includeColumns, $includeColumns));
  137. }
  138. /**
  139. * Clears the included columns.
  140. */
  141. public function clearIncludeColumns()
  142. {
  143. $this->includeColumns = array();
  144. }
  145. /**
  146. * Sets the columns to exclude from the table.
  147. * @param Array $excludeColumns
  148. */
  149. public function addExcludeColumns(Array $excludeColumns)
  150. {
  151. $this->excludeColumns = array_unique(array_merge($this->excludeColumns, $excludeColumns));
  152. }
  153. /**
  154. * Clears the excluded columns.
  155. */
  156. public function clearExcludeColumns()
  157. {
  158. $this->excludeColumns = array();
  159. }
  160. }
  161. ?>