5
* Copyright (c) 2002-2010, Sebastian Bergmann <sb@sebastian-bergmann.de>.
8
* Redistribution and use in source and binary forms, with or without
9
* modification, are permitted provided that the following conditions
12
* * Redistributions of source code must retain the above copyright
13
* notice, this list of conditions and the following disclaimer.
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
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.
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.
39
* @author Mike Lively <m@digitalsandwich.com>
40
* @copyright 2002-2010 Sebastian Bergmann <sb@sebastian-bergmann.de>
41
* @license http://www.opensource.org/licenses/bsd-license.php BSD License
42
* @link http://www.phpunit.de/
43
* @since File available since Release 3.4.0
46
require_once ('PHPUnit/Extensions/Database/DataSet/ISpec.php');
47
require_once ('PHPUnit/Extensions/Database/DataSet/CsvDataSet.php');
50
* Creates CsvDataSets based off of a spec string.
52
* The format of the spec string is as follows:
54
* <csv options>|table1:filename.csv,table2:filename2.csv
56
* The first portion of the spec including the pipe symbol '|' is optional.
57
* If the pipe option is included than it may be preceded by up to four
58
* characters specifying values for the following arguments in order:
59
* delimiter (defaults to ',',) enclosure (defaults to '"',) escape (defaults to '"',).
61
* Any additional characters in the csv options will be discarded.
65
* @author Mike Lively <m@digitalsandwich.com>
66
* @copyright 2010 Mike Lively <m@digitalsandwich.com>
67
* @license http://www.opensource.org/licenses/bsd-license.php BSD License
68
* @version Release: 3.4.14
69
* @link http://www.phpunit.de/
70
* @since Class available since Release 3.4.0
72
class PHPUnit_Extensions_Database_DataSet_Specs_Csv implements PHPUnit_Extensions_Database_DataSet_ISpec
76
* Creates CSV Data Set from a data set spec.
78
* @param string $dataSetSpec
79
* @return PHPUnit_Extensions_Database_DataSet_CsvDataSet
81
public function getDataSet($dataSetSpec)
83
$csvDataSetArgs = $this->getCsvOptions($dataSetSpec);
84
$csvDataSetRfl = new ReflectionClass('PHPUnit_Extensions_Database_DataSet_CsvDataSet');
85
$csvDataSet = $csvDataSetRfl->newInstanceArgs($csvDataSetArgs);
87
foreach ($this->getTableFileMap($dataSetSpec) as $tableName => $file) {
88
$csvDataSet->addTable($tableName, $file);
94
* Returns CSV options.
96
* Returns an array containing the options that will be passed to the
97
* PHPUnit_Extensions_Database_DataSet_CsvDataSet constructor. The options
98
* are determined by the given $dataSetSpec.
100
* @param string $dataSetSpec
103
protected function getCsvOptions($dataSetSpec)
105
list($csvOptStr, ) = explode('|', $dataSetSpec, 2);
106
return str_split($csvOptStr);
110
* Returns map of tables to files.
112
* Returns an associative array containing a mapping of tables (the key)
113
* to files (the values.) The tables and files are determined by the given
116
* @param string $dataSetSpec
119
protected function getTableFileMap($dataSetSpec)
122
foreach (explode(',', $dataSetSpec) as $csvfile) {
123
list($tableName, $file) = explode(':', $csvfile, 2);
124
$tables[$tableName] = $file;
b'\\ No newline at end of file'