CreateOrFindOrderInfoTest.php 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  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\OracleBasSKU;
  8. use App\OracleDOCOrderDetail;
  9. use App\OracleDOCOrderHeader;
  10. use App\Order;
  11. use App\OrderPackage;
  12. use App\OrderPackageCommodities;
  13. use App\Owner;
  14. use App\Services\OracleBasSkuService;
  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. /**
  23. * @var OrderService $orderService
  24. */
  25. public $orderService;
  26. private $data = [];
  27. public function setUp(): void
  28. {
  29. parent::setUp(); // TODO: Change the autogenerated stub
  30. $this->orderService = app('OrderService');
  31. $wmsOrderHeader = factory(OracleDOCOrderHeader::class)->make([
  32. 'customerid'=>'TEST_OW','sostatus'=>99,'userdefine1'=>'TEST_CA','warehouseid'=>'WH_TEST'
  33. ]);
  34. $this->data['warehouse'] = factory(Warehouse::class)->create(['code'=>'WH_TEST']);
  35. $this->data['logistic'] = factory(Logistic::class)->create(['code'=>'TEST_CA','name'=>'测试承运商']);
  36. $this->data['owner'] = factory(Owner::class)->create(['code'=>'TEST_OW','name'=>'测试货主']);
  37. $this->data['shop'] = factory(Shop::class)->create(['owner_id'=>$this->data['owner']['id']]);
  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. $basSku1 = factory(OracleBasSKU::class)->make(['customerid' => 'TEST_OW']);
  41. $basSku2 = factory(OracleBasSKU::class)->make(['customerid' => 'TEST_OW']);
  42. $basSku3 = factory(OracleBasSKU::class)->make(['customerid' => 'TEST_OW']);
  43. $basSKU = collect([$basSku1,$basSku2,$basSku3]);
  44. $this->data['sku'] = [];
  45. $this->data['sku'][] = factory(Commodity::class)->create(['owner_id'=>$this->data['owner']['id'],'sku'=>$basSku1['sku']]);
  46. $this->data['sku'][] = factory(Commodity::class)->create(['owner_id'=>$this->data['owner']['id'],'sku'=>$basSku2['sku']]);
  47. $this->data['sku'][] = factory(Commodity::class)->create(['owner_id'=>$this->data['owner']['id'],'sku'=>$basSku3['sku']]);
  48. $oracleDOCOrderDetail1 = factory(OracleDOCOrderDetail::class)->make(['orderno'=>$wmsOrderHeader->orderno,'customerid'=>'TEST_OW','sku'=>$basSku1->sku]);
  49. $oracleDOCOrderDetail2 = factory(OracleDOCOrderDetail::class)->make(['orderno'=>$wmsOrderHeader->orderno,'customerid'=>'TEST_OW','sku'=>$basSku2->sku]);
  50. $oracleDOCOrderDetail3 = factory(OracleDOCOrderDetail::class)->make(['orderno'=>$wmsOrderHeader->orderno,'customerid'=>'TEST_OW','sku'=>$basSku3->sku]);
  51. $oracleDOCOrderDetails = collect([$oracleDOCOrderDetail1,$oracleDOCOrderDetail3,$oracleDOCOrderDetail2]);
  52. $wmsOrderHeader->setRelation('oracleDOCOrderDetails',$oracleDOCOrderDetails);
  53. $OracleActAllocationDetail1 = factory(OracleActAllocationDetails::class)->make(['orderno'=>$wmsOrderHeader->orderno,'customerid'=>'TEST_OW','sku'=>$basSku1->sku]);
  54. $OracleActAllocationDetail2 = factory(OracleActAllocationDetails::class)->make(['orderno'=>$wmsOrderHeader->orderno,'customerid'=>'TEST_OW','sku'=>$basSku2->sku]);
  55. $OracleActAllocationDetail3 = factory(OracleActAllocationDetails::class)->make(['orderno'=>$wmsOrderHeader->orderno,'customerid'=>'TEST_OW','sku'=>$basSku3->sku]);
  56. $OracleActAllocationDetails = collect([$OracleActAllocationDetail1,$OracleActAllocationDetail2,$OracleActAllocationDetail3]);
  57. $wmsOrderHeader->setRelation('actAllocationDetails',$OracleActAllocationDetails);
  58. $wmsOrderHeader->setRelation('orderType',$orderType);
  59. $wmsOrderHeader->setRelation('oracleBASCode',$code_BasCode);
  60. $this->data['orderHeader'] = $wmsOrderHeader;
  61. $this->mock(OracleBasSkuService::class,function($mock)use($basSKU){
  62. $mock->shouldReceive('get')->andReturn($basSKU);
  63. });
  64. }
  65. /**
  66. * @test
  67. */
  68. public function createOrFindOrderInfo()
  69. {
  70. $this->orderService->createOrFindOrderInfo($this->data['orderHeader']);
  71. $order = Order::query()->where('code',$this->data['orderHeader']['orderno'])->first();
  72. $this->assertNotNull($order);
  73. $this->assertEquals($order->code,$this->data['orderHeader']['orderno']);
  74. $orderPackages = OrderPackage::query()->where('order_id',$order['id'])->get();
  75. $orderPackagesCommodities = OrderPackageCommodities::query()->whereIn('order_package_id',data_get($orderPackages,'*.id'))->get();
  76. $this->assertNotEmpty($orderPackages);
  77. $this->assertNotEmpty($orderPackagesCommodities);
  78. }
  79. public function tearDown(): void
  80. {
  81. foreach ($this->data['sku'] as $datum) {
  82. cache()->forget("owner_code_{$this->data['owner']['code']}_sku_{$datum['sku']}");
  83. }
  84. cache()->forget("getLogisticByCode_{$this->data['logistic']}");
  85. cache()->forget("getOwnerByCode_{$this->data['owner']}");
  86. cache()->forget("getShopByCodeMap_{$this->data['shop']}");
  87. cache()->forget("WareHouse_{$this->data['warehouse']}");
  88. Commodity::query()->whereIn('id',data_get($this->data['sku'],'*.id'))->delete();
  89. $order = Order::query()->where('code',$this->data['orderHeader']['orderno'])->first();
  90. $order->delete();
  91. $this->data['logistic']->delete();
  92. $this->data['owner']->delete();
  93. $this->data['shop']->delete();
  94. $this->data['warehouse']->delete();
  95. parent::tearDown(); // TODO: Change the autogenerated stub
  96. }
  97. }