CreateOrFindOrderInfoTest.php 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. <?php
  2. namespace Tests\Services\OrderService;
  3. use App\Commodity;
  4. use App\Logistic;
  5. use App\OracleActAllocationDetails;
  6. use App\OracleBasCode;
  7. use App\OracleBasCustomer;
  8. use App\OracleBasSKU;
  9. use App\OracleDOCOrderDetail;
  10. use App\OracleDOCOrderHeader;
  11. use App\Order;
  12. use App\OrderPackage;
  13. use App\OrderPackageCommodities;
  14. use App\Owner;
  15. use App\Services\OrderService;
  16. use App\Shop;
  17. use App\Warehouse;
  18. use Illuminate\Foundation\Testing\RefreshDatabase;
  19. use Tests\TestCase;
  20. class CreateOrFindOrderInfoTest extends TestCase
  21. {
  22. use RefreshDatabase;
  23. /**
  24. * @var OrderService $orderService
  25. */
  26. public $orderService;
  27. private $data = [];
  28. public function setUp(): void
  29. {
  30. parent::setUp(); // TODO: Change the autogenerated stub
  31. $this->orderService = app('OrderService');
  32. $basSku1 = factory(OracleBasSKU::class)->make(['customerid' => 'TEST_OW']);
  33. $basSku2 = factory(OracleBasSKU::class)->make(['customerid' => 'TEST_OW']);
  34. $basSku3 = factory(OracleBasSKU::class)->make(['customerid' => 'TEST_OW']);
  35. $this->data['warehouse'] = factory(Warehouse::class)->create(['code'=>'WH_TEST']);
  36. $logistic_BasCustomer = factory(OracleBasCustomer::class)->make(['customer_type'=>'CA','customerid'=>'TEST_CA','descr_c'=>'测试承运商']);
  37. $owner_basCustomer = factory(OracleBasCustomer::class)->make(['customer_type'=>'OW','customerid'=>'TEST_OW','descr_c'=>'测试货主']);
  38. $code_BasCode = factory(OracleBasCode::class)->make(['codeid'=>'OW','code'=>'99','descr_c'=>'订单完成']);
  39. $orderType = factory(OracleBasCode::class)->make(['code'=>'sysy', 'codeid'=>'SO_TYP', 'codename_c'=>'测试状态']);
  40. $wmsOrderHeader = factory(OracleDOCOrderHeader::class)->make(['customerid'=>'TEST_OW','sostatus'=>99,'orderType'=>'sysy','userdefine1'=>'TEST_CA','warehouseid'=>$this->data['warehouse']['code']]);
  41. $oracleDOCOrderDetail1 = factory(OracleDOCOrderDetail::class)->make(['orderno'=>$wmsOrderHeader->orderno,'customerid'=>'TEST_CA','sku'=>$basSku1->sku]);
  42. $oracleDOCOrderDetail2 = factory(OracleDOCOrderDetail::class)->make(['orderno'=>$wmsOrderHeader->orderno,'customerid'=>'TEST_CA','sku'=>$basSku2->sku]);
  43. $oracleDOCOrderDetail3 = factory(OracleDOCOrderDetail::class)->make(['orderno'=>$wmsOrderHeader->orderno,'customerid'=>'TEST_CA','sku'=>$basSku3->sku]);
  44. $oracleDOCOrderDetails = collect([$oracleDOCOrderDetail1,$oracleDOCOrderDetail3,$oracleDOCOrderDetail2]);
  45. $OracleActAllocationDetail1 = factory(OracleActAllocationDetails::class)->make(['orderno'=>$wmsOrderHeader->orderno,'customerid'=>'TEST_CA','sku'=>$basSku1->sku]);
  46. $OracleActAllocationDetail2 = factory(OracleActAllocationDetails::class)->make(['orderno'=>$wmsOrderHeader->orderno,'customerid'=>'TEST_CA','sku'=>$basSku2->sku]);
  47. $OracleActAllocationDetail3 = factory(OracleActAllocationDetails::class)->make(['orderno'=>$wmsOrderHeader->orderno,'customerid'=>'TEST_CA','sku'=>$basSku3->sku]);
  48. $OracleActAllocationDetails = collect([$OracleActAllocationDetail1,$OracleActAllocationDetail2,$OracleActAllocationDetail3]);
  49. $wmsOrderHeader->setRelation('oracleDOCOrderDetails',$oracleDOCOrderDetails);
  50. $wmsOrderHeader->setRelation('actAllocationDetails',$OracleActAllocationDetails);
  51. $wmsOrderHeader->setRelation('orderType',$orderType);
  52. $wmsOrderHeader->setRelation('orderType',$orderType);
  53. $wmsOrderHeader->setRelation('oracleBASCode',$code_BasCode);
  54. $this->data['orderHeader'] = $wmsOrderHeader;
  55. $this->data['logistic'] = factory(Logistic::class)->create(['code'=>$logistic_BasCustomer->customerid,'name'=>$logistic_BasCustomer->descr_c]);
  56. $this->data['owner'] = factory(Owner::class)->create(['code'=>$owner_basCustomer->customerid,'name'=>$owner_basCustomer->descr_c]);
  57. $this->data['shop'] = factory(Shop::class)->create(['owner_id'=>$this->data['owner']['id']]);
  58. $this->data['sku'] = [];
  59. $this->data['sku'][] = factory(Commodity::class)->create(['owner_id'=>$this->data['owner']['id'],'sku'=>$basSku1['sku']]);
  60. $this->data['sku'][] = factory(Commodity::class)->create(['owner_id'=>$this->data['owner']['id'],'sku'=>$basSku2['sku']]);
  61. $this->data['sku'][] = factory(Commodity::class)->create(['owner_id'=>$this->data['owner']['id'],'sku'=>$basSku3['sku']]);
  62. }
  63. /**
  64. * @test
  65. */
  66. public function createOrFindOrderInfo()
  67. {
  68. $this->orderService->createOrFindOrderInfo($this->data['orderHeader']);
  69. $order = Order::query()->where('code',$this->data['orderHeader']['orderno'])->first();
  70. $this->assertNotNull($order);
  71. $this->assertEquals($order->code,$this->data['orderHeader']['orderno']);
  72. $orderPackages = OrderPackage::query()->where('order_id',$order['id'])->get();
  73. $orderPackagesCommodities = OrderPackageCommodities::query()->whereIn('order_package_id',data_get($orderPackages,'*.id'))->get();
  74. $this->assertNotEmpty($orderPackages);
  75. $this->assertNotEmpty($orderPackagesCommodities);
  76. }
  77. public function tearDown(): void
  78. {
  79. cache()->flush();
  80. Commodity::query()->whereIn('id',data_get($this->data['sku'],'*.id'))->delete();
  81. $order = Order::query()->where('code',$this->data['orderHeader']['orderno'])->first();
  82. $order->delete();
  83. $this->data['logistic']->delete();
  84. $this->data['owner']->delete();
  85. $this->data['logistic']->delete();
  86. $this->data['shop']->delete();
  87. parent::tearDown(); // TODO: Change the autogenerated stub
  88. }
  89. }