CreateOrFindOrderInfoTest.php 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  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 Illuminate\Support\Facades\DB;
  20. use Tests\TestCase;
  21. class CreateOrFindOrderInfoTest extends TestCase
  22. {
  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. $wmsOrderHeader = factory(OracleDOCOrderHeader::class)->make([
  33. 'customerid'=>'TEST_OW','sostatus'=>99,'userdefine1'=>'TEST_CA','warehouseid'=>'WH_TEST'
  34. ]);
  35. $this->data['warehouse'] = factory(Warehouse::class)->create();
  36. $this->data['logistic'] = factory(Logistic::class)->create();
  37. // $this->data['owner'] = factory(Owner::class)->create(['code'=>'TEST_OW','name'=>'测试货主']);
  38. DB::insert('insert ignore into owners (code,name) values(?,?)',['TEST_OW','测试货主']);
  39. $this->data['owner'] = Owner::query()->where('code','TEST_OW')->where('name','测试货主')->first();
  40. $this->data['shop'] = factory(Shop::class)->create(['owner_id'=>$this->data['owner']['id']]);
  41. $code_BasCode = factory(OracleBasCode::class)->make(['codeid'=>'OW','code'=>'99','descr_c'=>'订单完成']);
  42. $orderType = factory(OracleBasCode::class)->make(['code'=>'sysy', 'codeid'=>'SO_TYP', 'codename_c'=>'测试状态']);
  43. $basSku1 = factory(OracleBasSKU::class)->make(['customerid' => 'TEST_OW']);
  44. $basSku2 = factory(OracleBasSKU::class)->make(['customerid' => 'TEST_OW']);
  45. $basSku3 = factory(OracleBasSKU::class)->make(['customerid' => 'TEST_OW']);
  46. $basSKU = collect([$basSku1,$basSku2,$basSku3]);
  47. $this->data['sku'] = [];
  48. $this->data['sku'][] = factory(Commodity::class)->create(['owner_id'=>$this->data['owner']['id'],'sku'=>$basSku1['sku']]);
  49. $this->data['sku'][] = factory(Commodity::class)->create(['owner_id'=>$this->data['owner']['id'],'sku'=>$basSku2['sku']]);
  50. $this->data['sku'][] = factory(Commodity::class)->create(['owner_id'=>$this->data['owner']['id'],'sku'=>$basSku3['sku']]);
  51. $oracleDOCOrderDetail1 = factory(OracleDOCOrderDetail::class)->make(['orderno'=>$wmsOrderHeader->orderno,'customerid'=>'TEST_OW','sku'=>$basSku1->sku]);
  52. $oracleDOCOrderDetail2 = factory(OracleDOCOrderDetail::class)->make(['orderno'=>$wmsOrderHeader->orderno,'customerid'=>'TEST_OW','sku'=>$basSku2->sku]);
  53. $oracleDOCOrderDetail3 = factory(OracleDOCOrderDetail::class)->make(['orderno'=>$wmsOrderHeader->orderno,'customerid'=>'TEST_OW','sku'=>$basSku3->sku]);
  54. $oracleDOCOrderDetails = collect([$oracleDOCOrderDetail1,$oracleDOCOrderDetail3,$oracleDOCOrderDetail2]);
  55. $wmsOrderHeader->setRelation('oracleDOCOrderDetails',$oracleDOCOrderDetails);
  56. $OracleActAllocationDetail1 = factory(OracleActAllocationDetails::class)->make(['orderno'=>$wmsOrderHeader->orderno,'customerid'=>'TEST_OW','sku'=>$basSku1->sku]);
  57. $OracleActAllocationDetail2 = factory(OracleActAllocationDetails::class)->make(['orderno'=>$wmsOrderHeader->orderno,'customerid'=>'TEST_OW','sku'=>$basSku2->sku]);
  58. $OracleActAllocationDetail3 = factory(OracleActAllocationDetails::class)->make(['orderno'=>$wmsOrderHeader->orderno,'customerid'=>'TEST_OW','sku'=>$basSku3->sku]);
  59. $OracleActAllocationDetails = collect([$OracleActAllocationDetail1,$OracleActAllocationDetail2,$OracleActAllocationDetail3]);
  60. $wmsOrderHeader->setRelation('actAllocationDetails',$OracleActAllocationDetails);
  61. $wmsOrderHeader->setRelation('orderType',$orderType);
  62. $wmsOrderHeader->setRelation('oracleBASCode',$code_BasCode);
  63. $this->data['orderHeader'] = $wmsOrderHeader;
  64. $this->mock(OracleBasSkuService::class,function($mock)use($basSKU){
  65. $mock->shouldReceive('get')->andReturn($basSKU);
  66. });
  67. }
  68. /**
  69. * @test
  70. */
  71. public function createOrFindOrderInfo()
  72. {
  73. $this->orderService->createOrFindOrderInfo($this->data['orderHeader']);
  74. $order = Order::query()->where('code',$this->data['orderHeader']['orderno'])->first();
  75. $this->assertNotNull($order);
  76. $this->assertEquals($order->code,$this->data['orderHeader']['orderno']);
  77. $orderPackages = OrderPackage::query()->where('order_id',$order['id'])->get();
  78. $orderPackagesCommodities = OrderPackageCommodities::query()->whereIn('order_package_id',data_get($orderPackages,'*.id'))->get();
  79. $this->assertNotEmpty($orderPackages);
  80. // $this->assertNotEmpty($orderPackagesCommodities);
  81. }
  82. public function tearDown(): void
  83. {
  84. foreach ($this->data['sku'] as $datum) {
  85. cache()->forget("owner_code_{$this->data['owner']['code']}_sku_{$datum['sku']}");
  86. }
  87. cache()->forget("getLogisticByCode_{$this->data['logistic']}");
  88. cache()->forget("getOwnerByCode_{$this->data['owner']}");
  89. cache()->forget("getShopByCodeMap_{$this->data['shop']}");
  90. cache()->forget("WareHouse_{$this->data['warehouse']}");
  91. Commodity::query()->whereIn('id',data_get($this->data['sku'],'*.id'))->delete();
  92. $order = Order::query()->where('code',$this->data['orderHeader']['orderno'])->first();
  93. $order->delete();
  94. $this->data['logistic']->forceDelete();
  95. Shop::query()->where('owner_id',$this->data['owner']['id'])->delete();
  96. $this->data['owner']->delete();
  97. $this->data['warehouse']->delete();
  98. parent::tearDown(); // TODO: Change the autogenerated stub
  99. }
  100. }