WithCustomQuerySizeTest.php 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. <?php
  2. namespace Maatwebsite\Excel\Tests\Concerns;
  3. use Maatwebsite\Excel\Tests\Data\Stubs\AfterQueueExportJob;
  4. use Maatwebsite\Excel\Tests\Data\Stubs\Database\Group;
  5. use Maatwebsite\Excel\Tests\Data\Stubs\Database\User;
  6. use Maatwebsite\Excel\Tests\Data\Stubs\FromQueryWithCustomQuerySize;
  7. use Maatwebsite\Excel\Tests\TestCase;
  8. class WithCustomQuerySizeTest extends TestCase
  9. {
  10. /**
  11. * Setup the test environment.
  12. */
  13. protected function setUp(): void
  14. {
  15. parent::setUp();
  16. $this->loadLaravelMigrations(['--database' => 'testing']);
  17. $this->loadMigrationsFrom(dirname(__DIR__) . '/Data/Stubs/Database/Migrations');
  18. $this->withFactories(dirname(__DIR__) . '/Data/Stubs/Database/Factories');
  19. factory(Group::class)->times(5)->create()->each(function ($group) {
  20. $group->users()->attach(factory(User::class)->times(rand(1, 3))->create());
  21. });
  22. config()->set('excel.exports.chunk_size', 2);
  23. }
  24. /**
  25. * @test
  26. */
  27. public function can_export_with_custom_count()
  28. {
  29. $export = new FromQueryWithCustomQuerySize();
  30. $export->queue('export-from-query-with-count.xlsx', null, 'Xlsx')->chain([
  31. new AfterQueueExportJob(dirname(__DIR__) . '/Data/Disks/Local/export-from-query-with-count.xlsx'),
  32. ]);
  33. $actual = $this->readAsArray(dirname(__DIR__) . '/Data/Disks/Local/export-from-query-with-count.xlsx', 'Xlsx');
  34. $this->assertCount(Group::count(), $actual);
  35. }
  36. }