ColumnRangeTest.php 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. <?php
  2. namespace PhpOffice\PhpSpreadsheetTests\Cell;
  3. use PhpOffice\PhpSpreadsheet\Cell\ColumnRange;
  4. use PhpOffice\PhpSpreadsheet\Spreadsheet;
  5. use PHPUnit\Framework\TestCase;
  6. class ColumnRangeTest extends TestCase
  7. {
  8. public function testCreateColumnRange(): void
  9. {
  10. $columnRange = new ColumnRange('C', 'E');
  11. self::assertSame('C', $columnRange->from());
  12. self::assertSame('E', $columnRange->to());
  13. self::assertSame(3, $columnRange->fromIndex());
  14. self::assertSame(5, $columnRange->toIndex());
  15. self::assertSame('C:E', (string) $columnRange);
  16. self::assertSame(3, $columnRange->columnCount());
  17. self::assertSame('C1:E1048576', (string) $columnRange->toCellRange());
  18. }
  19. public function testCreateSingleColumnRange(): void
  20. {
  21. $columnRange = new ColumnRange('E');
  22. self::assertSame('E', $columnRange->from());
  23. self::assertSame('E', $columnRange->to());
  24. self::assertSame('E:E', (string) $columnRange);
  25. self::assertSame(1, $columnRange->columnCount());
  26. self::assertSame('E1:E1048576', (string) $columnRange->toCellRange());
  27. }
  28. public function testCreateColumnRangeWithWorksheet(): void
  29. {
  30. $spreadsheet = new Spreadsheet();
  31. $worksheet = $spreadsheet->getActiveSheet();
  32. $worksheet->setTitle("Mark's Worksheet");
  33. $columnRange = new ColumnRange('C', 'E', $worksheet);
  34. self::assertSame('C', $columnRange->from());
  35. self::assertSame('E', $columnRange->to());
  36. self::assertSame("'Mark''s Worksheet'!C:E", (string) $columnRange);
  37. self::assertSame("'Mark''s Worksheet'!C1:E1048576", (string) $columnRange->toCellRange());
  38. }
  39. public function testCreateColumnRangeFromArray(): void
  40. {
  41. $columnRange = ColumnRange::fromArray(['C', 'E']);
  42. self::assertSame('C', $columnRange->from());
  43. self::assertSame('E', $columnRange->to());
  44. self::assertSame('C:E', (string) $columnRange);
  45. self::assertSame(3, $columnRange->columnCount());
  46. self::assertSame('C1:E1048576', (string) $columnRange->toCellRange());
  47. }
  48. public function testCreateColumnRangeFromIndexes(): void
  49. {
  50. $columnRange = ColumnRange::fromColumnIndexes(3, 5);
  51. self::assertSame('C', $columnRange->from());
  52. self::assertSame('E', $columnRange->to());
  53. self::assertSame('C:E', (string) $columnRange);
  54. self::assertSame(3, $columnRange->columnCount());
  55. self::assertSame('C1:E1048576', (string) $columnRange->toCellRange());
  56. }
  57. public function testColumnRangeNext(): void
  58. {
  59. $columnRange = new ColumnRange('C', 'E');
  60. $columnRangeNext = $columnRange->shiftDown(3);
  61. self::assertSame('F', $columnRangeNext->from());
  62. self::assertSame('H', $columnRangeNext->to());
  63. // Check that original Column Range isn't changed
  64. self::assertSame('C:E', (string) $columnRange);
  65. }
  66. public function testColumnRangePrevious(): void
  67. {
  68. $columnRange = new ColumnRange('C', 'E');
  69. $columnRangeNext = $columnRange->shiftUp();
  70. self::assertSame('B', $columnRangeNext->from());
  71. self::assertSame('D', $columnRangeNext->to());
  72. // Check that original Column Range isn't changed
  73. self::assertSame('C:E', (string) $columnRange);
  74. }
  75. }