FromQueryTest.php 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297
  1. <?php
  2. namespace Maatwebsite\Excel\Tests\Concerns;
  3. use Illuminate\Support\Facades\DB;
  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\FromGroupUsersQueuedQueryExport;
  7. use Maatwebsite\Excel\Tests\Data\Stubs\FromNestedArraysQueryExport;
  8. use Maatwebsite\Excel\Tests\Data\Stubs\FromNonEloquentQueryExport;
  9. use Maatwebsite\Excel\Tests\Data\Stubs\FromUsersQueryExport;
  10. use Maatwebsite\Excel\Tests\Data\Stubs\FromUsersQueryExportWithEagerLoad;
  11. use Maatwebsite\Excel\Tests\Data\Stubs\FromUsersQueryExportWithPrepareRows;
  12. use Maatwebsite\Excel\Tests\Data\Stubs\FromUsersScoutExport;
  13. use Maatwebsite\Excel\Tests\TestCase;
  14. class FromQueryTest extends TestCase
  15. {
  16. /**
  17. * Setup the test environment.
  18. */
  19. protected function setUp(): void
  20. {
  21. parent::setUp();
  22. $this->loadLaravelMigrations(['--database' => 'testing']);
  23. $this->withFactories(__DIR__ . '/../Data/Stubs/Database/Factories');
  24. $this->loadMigrationsFrom(dirname(__DIR__) . '/Data/Stubs/Database/Migrations');
  25. $group = factory(Group::class)->create([
  26. 'name' => 'Group 1',
  27. ]);
  28. factory(User::class)->times(100)->create()->each(function (User $user) use ($group) {
  29. $user->groups()->save($group);
  30. });
  31. $group_two = factory(Group::class)->create([
  32. 'name' => 'Group 2',
  33. ]);
  34. factory(User::class)->times(5)->create()->each(function (User $user) use ($group_two) {
  35. $user->groups()->save($group_two);
  36. });
  37. }
  38. /**
  39. * @test
  40. */
  41. public function can_export_from_query()
  42. {
  43. $export = new FromUsersQueryExport;
  44. $response = $export->store('from-query-store.xlsx');
  45. $this->assertTrue($response);
  46. $contents = $this->readAsArray(__DIR__ . '/../Data/Disks/Local/from-query-store.xlsx', 'Xlsx');
  47. $allUsers = $export->query()->get()->map(function (User $user) {
  48. return array_values($user->toArray());
  49. })->toArray();
  50. $this->assertEquals($allUsers, $contents);
  51. }
  52. /**
  53. * @test
  54. */
  55. public function can_export_from_relation_query_queued()
  56. {
  57. $export = new FromGroupUsersQueuedQueryExport();
  58. $export->queue('from-query-store.xlsx');
  59. $contents = $this->readAsArray(__DIR__ . '/../Data/Disks/Local/from-query-store.xlsx', 'Xlsx');
  60. $allUsers = $export->query()->get()->map(function ($row) use ($export) {
  61. return $export->map($row);
  62. })->toArray();
  63. $this->assertEquals($allUsers, $contents);
  64. }
  65. /**
  66. * @test
  67. */
  68. public function can_export_from_query_with_eager_loads()
  69. {
  70. DB::connection()->enableQueryLog();
  71. $export = new FromUsersQueryExportWithEagerLoad();
  72. $response = $export->store('from-query-with-eager-loads.xlsx');
  73. $this->assertTrue($response);
  74. // Should be 2 queries:
  75. // 1) select all users
  76. // 2) eager load query for groups
  77. $this->assertCount(2, DB::getQueryLog());
  78. DB::connection()->disableQueryLog();
  79. $contents = $this->readAsArray(__DIR__ . '/../Data/Disks/Local/from-query-with-eager-loads.xlsx', 'Xlsx');
  80. $allUsers = $export->query()->get()->map(function (User $user) use ($export) {
  81. return $export->map($user);
  82. })->toArray();
  83. $this->assertEquals($allUsers, $contents);
  84. }
  85. /**
  86. * @test
  87. */
  88. public function can_export_from_query_with_eager_loads_and_queued()
  89. {
  90. DB::connection()->enableQueryLog();
  91. $export = new FromUsersQueryExportWithEagerLoad();
  92. $export->queue('from-query-with-eager-loads.xlsx');
  93. // Should be 3 queries:
  94. // 1) Count users to create chunked queues
  95. // 2) select all users
  96. // 3) eager load query for groups
  97. $this->assertCount(3, DB::getQueryLog());
  98. DB::connection()->disableQueryLog();
  99. $contents = $this->readAsArray(__DIR__ . '/../Data/Disks/Local/from-query-with-eager-loads.xlsx', 'Xlsx');
  100. $allUsers = $export->query()->get()->map(function (User $user) use ($export) {
  101. return $export->map($user);
  102. })->toArray();
  103. $this->assertEquals($allUsers, $contents);
  104. }
  105. /**
  106. * @test
  107. */
  108. public function can_export_from_query_builder_without_using_eloquent()
  109. {
  110. $export = new FromNonEloquentQueryExport();
  111. $response = $export->store('from-query-without-eloquent.xlsx');
  112. $this->assertTrue($response);
  113. $contents = $this->readAsArray(__DIR__ . '/../Data/Disks/Local/from-query-without-eloquent.xlsx', 'Xlsx');
  114. $allUsers = $export->query()->get()->map(function ($row) {
  115. return array_values((array) $row);
  116. })->all();
  117. $this->assertEquals($allUsers, $contents);
  118. }
  119. /**
  120. * @test
  121. */
  122. public function can_export_from_query_builder_without_using_eloquent_and_queued()
  123. {
  124. $export = new FromNonEloquentQueryExport();
  125. $export->queue('from-query-without-eloquent.xlsx');
  126. $contents = $this->readAsArray(__DIR__ . '/../Data/Disks/Local/from-query-without-eloquent.xlsx', 'Xlsx');
  127. $allUsers = $export->query()->get()->map(function ($row) {
  128. return array_values((array) $row);
  129. })->all();
  130. $this->assertEquals($allUsers, $contents);
  131. }
  132. /**
  133. * @test
  134. */
  135. public function can_export_from_query_builder_with_nested_arrays()
  136. {
  137. $export = new FromNestedArraysQueryExport();
  138. $response = $export->store('from-query-with-nested-arrays.xlsx');
  139. $this->assertTrue($response);
  140. $contents = $this->readAsArray(__DIR__ . '/../Data/Disks/Local/from-query-with-nested-arrays.xlsx', 'Xlsx');
  141. $this->assertEquals($this->format_nested_arrays_expected_data($export->query()->get()), $contents);
  142. }
  143. /**
  144. * @test
  145. */
  146. public function can_export_from_query_builder_with_nested_arrays_queued()
  147. {
  148. $export = new FromNestedArraysQueryExport();
  149. $export->queue('from-query-with-nested-arrays.xlsx');
  150. $contents = $this->readAsArray(__DIR__ . '/../Data/Disks/Local/from-query-with-nested-arrays.xlsx', 'Xlsx');
  151. $this->assertEquals($this->format_nested_arrays_expected_data($export->query()->get()), $contents);
  152. }
  153. /**
  154. * @test
  155. */
  156. public function can_export_from_query_with_batch_caching()
  157. {
  158. config()->set('excel.cache.driver', 'batch');
  159. $export = new FromUsersQueryExport;
  160. $response = $export->store('from-query-store.xlsx');
  161. $this->assertTrue($response);
  162. $contents = $this->readAsArray(__DIR__ . '/../Data/Disks/Local/from-query-store.xlsx', 'Xlsx');
  163. $allUsers = $export->query()->get()->map(function (User $user) {
  164. return array_values($user->toArray());
  165. })->toArray();
  166. $this->assertEquals($allUsers, $contents);
  167. }
  168. /**
  169. * @test
  170. */
  171. public function can_export_from_query_with_prepare_rows()
  172. {
  173. $export = new FromUsersQueryExportWithPrepareRows;
  174. $this->assertTrue(method_exists($export, 'prepareRows'));
  175. $response = $export->store('from-query-store.xlsx');
  176. $this->assertTrue($response);
  177. $contents = $this->readAsArray(__DIR__ . '/../Data/Disks/Local/from-query-store.xlsx', 'Xlsx');
  178. $allUsers = $export->query()->get()->map(function (User $user) {
  179. $user->name .= '_prepared_name';
  180. return array_values($user->toArray());
  181. })->toArray();
  182. $this->assertEquals($allUsers, $contents);
  183. }
  184. /**
  185. * @test
  186. */
  187. public function can_export_from_scout()
  188. {
  189. if (!class_exists('\Laravel\Scout\Engines\DatabaseEngine')) {
  190. $this->markTestSkipped('Laravel Scout is too old');
  191. return;
  192. }
  193. $export = new FromUsersScoutExport;
  194. $response = $export->store('from-scout-store.xlsx');
  195. $this->assertTrue($response);
  196. $contents = $this->readAsArray(__DIR__ . '/../Data/Disks/Local/from-scout-store.xlsx', 'Xlsx');
  197. $allUsers = $export->query()->get()->map(function (User $user) {
  198. return array_values($user->toArray());
  199. })->toArray();
  200. $this->assertEquals($allUsers, $contents);
  201. }
  202. protected function format_nested_arrays_expected_data($groups)
  203. {
  204. $expected = [];
  205. foreach ($groups as $group) {
  206. $group_row = [$group->name, ''];
  207. foreach ($group->users as $key => $user) {
  208. if ($key === 0) {
  209. $group_row[1] = $user->email;
  210. $expected[] = $group_row;
  211. continue;
  212. }
  213. $expected[] = ['', $user->email];
  214. }
  215. }
  216. return $expected;
  217. }
  218. }