|
| 1 | +<?php |
| 2 | + |
| 3 | +/** |
| 4 | + * Test: Latte\Essential\Filters::column() |
| 5 | + */ |
| 6 | + |
| 7 | +declare(strict_types=1); |
| 8 | + |
| 9 | +use Latte\Essential\Filters; |
| 10 | +use Tester\Assert; |
| 11 | + |
| 12 | +require __DIR__ . '/../bootstrap.php'; |
| 13 | + |
| 14 | + |
| 15 | +$data = [ |
| 16 | + ['id' => 1, 'name' => 'John', 'age' => 30], |
| 17 | + ['id' => 2, 'name' => 'Jane', 'age' => 25], |
| 18 | + ['id' => 3, 'name' => 'Bob', 'age' => 35], |
| 19 | +]; |
| 20 | + |
| 21 | +test('extracts single column', function () use ($data) { |
| 22 | + Assert::same(['John', 'Jane', 'Bob'], Filters::column($data, 'name')); |
| 23 | + Assert::same([1, 2, 3], Filters::column($data, 'id')); |
| 24 | + Assert::same([30, 25, 35], Filters::column($data, 'age')); |
| 25 | +}); |
| 26 | + |
| 27 | + |
| 28 | +test('extracts column with custom index', function () use ($data) { |
| 29 | + Assert::same([1 => 'John', 2 => 'Jane', 3 => 'Bob'], Filters::column($data, 'name', 'id')); |
| 30 | + Assert::same(['John' => 30, 'Jane' => 25, 'Bob' => 35], Filters::column($data, 'age', 'name')); |
| 31 | +}); |
| 32 | + |
| 33 | + |
| 34 | +test('extracts all values when column is null', function () use ($data) { |
| 35 | + Assert::same([ |
| 36 | + ['id' => 1, 'name' => 'John', 'age' => 30], |
| 37 | + ['id' => 2, 'name' => 'Jane', 'age' => 25], |
| 38 | + ['id' => 3, 'name' => 'Bob', 'age' => 35], |
| 39 | + ], Filters::column($data, null)); |
| 40 | +}); |
| 41 | + |
| 42 | + |
| 43 | +test('works with iterable', function () { |
| 44 | + $iterator = new ArrayIterator([ |
| 45 | + ['id' => 1, 'name' => 'Alice'], |
| 46 | + ['id' => 2, 'name' => 'Bob'], |
| 47 | + ]); |
| 48 | + |
| 49 | + Assert::same(['Alice', 'Bob'], Filters::column($iterator, 'name')); |
| 50 | +}); |
| 51 | + |
| 52 | + |
| 53 | +test('works with numeric keys', function () { |
| 54 | + $data = [ |
| 55 | + [10, 'John', 30], |
| 56 | + [20, 'Jane', 25], |
| 57 | + [30, 'Bob', 35], |
| 58 | + ]; |
| 59 | + |
| 60 | + Assert::same(['John', 'Jane', 'Bob'], Filters::column($data, 1)); |
| 61 | + Assert::same([10, 20, 30], Filters::column($data, 0)); |
| 62 | +}); |
0 commit comments