Duplicate code is one of the most pungent code smells. A rule that is often used is to re-structure code once it is duplicated in three or more places.
Common duplication problems, and corresponding solutions are:
| 1 | <?php |
||
| 21 | View Code Duplication | class InputStreamReaderTest extends \PHPUnit_Framework_TestCase |
|
|
|
|||
| 22 | { |
||
| 23 | use InputStreamReaderProvider; |
||
| 24 | |||
| 25 | /** |
||
| 26 | * 正常系 |
||
| 27 | * バイト単位で読み込みできること |
||
| 28 | * EOFを超えるサイズの読み込み時は、ファイルの場合改行が含まれる |
||
| 29 | * @test |
||
| 30 | * @dataProvider readCharProvider |
||
| 31 | */ |
||
| 32 | public function okReadChar($stream, $result, $byteLength) |
||
| 37 | |||
| 38 | /** |
||
| 39 | * 正常系 |
||
| 40 | * 行単位でデータが読み込めること |
||
| 41 | * @test |
||
| 42 | * @dataProvider readLineProvider |
||
| 43 | */ |
||
| 44 | public function okReadLine($stream, $result1, $result2) |
||
| 51 | |||
| 52 | /** |
||
| 53 | * 正常系 |
||
| 54 | * 入力ストリームをクローズできること |
||
| 55 | * @test |
||
| 56 | * @dataProvider closeProvider |
||
| 57 | */ |
||
| 58 | public function okClose($stream) |
||
| 64 | |||
| 65 | /** |
||
| 66 | * 正常系 |
||
| 67 | * 指定バイト数だけスキップできること |
||
| 68 | * EOFを超えるサイズの読み込み時は、ファイルの場合改行が含まれる |
||
| 69 | * @test |
||
| 70 | * @dataProvider skipProvider |
||
| 71 | */ |
||
| 72 | public function okSkip($stream, $result, $pos) |
||
| 78 | |||
| 79 | /** |
||
| 80 | * 正常系 |
||
| 81 | * 終端を越えたスキップをしたとき |
||
| 82 | * 1回目のreadは空文字を返し、2回目のreadはnullを返すこと |
||
| 83 | * @test |
||
| 84 | * @dataProvider overSkipAndReadProvider |
||
| 85 | */ |
||
| 86 | public function okOverSkipAndRead($stream, $skipNum) |
||
| 93 | |||
| 94 | /** |
||
| 95 | * 正常系 |
||
| 96 | * ポインタを後方に移動できること |
||
| 97 | * @test |
||
| 98 | * @dataProvider frontSkipProvider |
||
| 99 | */ |
||
| 100 | public function okFrontSkip($stream, $skipNum1, $skipNum2, $result) |
||
| 107 | |||
| 108 | /** |
||
| 109 | * 正常系 |
||
| 110 | * ポインタ位置が負になった場合、移動量は常に-1になること |
||
| 111 | * @test |
||
| 112 | * @dataProvider overFrontSkipProvider |
||
| 113 | */ |
||
| 114 | public function okOverFrontSkip($stream, $pos) |
||
| 119 | |||
| 120 | /** |
||
| 121 | * 正常系 |
||
| 122 | * リセットすると初期位置にポインタが移動すること |
||
| 123 | * @test |
||
| 124 | * @dataProvider resetProvider |
||
| 125 | */ |
||
| 126 | public function okReset($stream, $skipNum, $result) |
||
| 133 | |||
| 134 | /** |
||
| 135 | * 正常系 |
||
| 136 | * リセットするとマーク位置にポインタが移動すること |
||
| 137 | * @test |
||
| 138 | * @dataProvider markAndResetProvider |
||
| 139 | */ |
||
| 140 | public function okMarkAndReset($stream, $skipNum, $result) |
||
| 148 | |||
| 149 | /** |
||
| 150 | * 異常系 |
||
| 151 | * 読み込みサイズに不正値を渡した時、例外が発生すること |
||
| 152 | * @test |
||
| 153 | * @dataProvider invalidLengthProvider |
||
| 154 | * @expectedException WebStream\Exception\Extend\InvalidArgumentException |
||
| 155 | */ |
||
| 156 | public function ngInvalidLength($stream) |
||
| 162 | } |
||
| 163 |
Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.
You can also find more detailed suggestions in the “Code” section of your repository.