CreateStoreTest.php 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. <?php
  2. namespace Tests\Services\StoreService;
  3. use App\OracleBasCode;
  4. use App\OracleDOCASNDetail;
  5. use App\OracleDOCASNHeader;
  6. use App\Owner;
  7. use App\Services\CommodityService;
  8. use App\Services\StoreService;
  9. use App\Warehouse;
  10. use Illuminate\Support\Facades\DB;
  11. use Tests\TestCase;
  12. class CreateStoreTest extends TestCase
  13. {
  14. /** @var StoreService $service */
  15. public $service;
  16. public $asnHeaders;
  17. public $stores;
  18. private $data=[];
  19. public function setUp(): void
  20. {
  21. parent::setUp(); // TODO: Change the autogenerated stub
  22. cache()->flush();
  23. $this->service=app(StoreService::class);
  24. $this->data['warehouse'] = factory(Warehouse::class)->create(['code'=>'test_wh']);
  25. $this->data['owner'] = factory(Owner::class)->create(['code'=>'test_owner','name'=>'测试货主']);
  26. $wmsAsnHeader = factory(OracleDOCASNHeader::class)->make([
  27. 'customerid'=>'test_owner','warehouseid'=>'test_wh','asntype'=>'CSRK','asnstatus'=>'11',
  28. ]);
  29. $asnType = factory(OracleBasCode::class)->make(['codeid'=>'ASN_TYP','code'=>'CSRK','descr_c'=>'测试入库']);
  30. $asnStatus = factory(OracleBasCode::class)->make(['code'=>'11', 'codeid'=>'ASN_STS', 'codename_c'=>'测试状态']);
  31. $wmsAsnHeader->setRelation('asnType',$asnType);
  32. $wmsAsnHeader->setRelation('asnStatus',$asnStatus);
  33. $this->asnHeaders=collect();
  34. $this->asnHeaders->add($wmsAsnHeader);
  35. }
  36. public function testCreateStore(){
  37. if (!$this->asnHeaders) return null;
  38. $this->service->createStore($this->asnHeaders);
  39. $this->stores=$this->service->getByWms($this->asnHeaders);
  40. $this->assertNotnull($this->stores);
  41. $this->assertNotNull($this->asnHeaders);
  42. }
  43. public function tearDown(): void
  44. {
  45. $this->data['warehouse']->delete();
  46. $this->data['owner']->delete();
  47. $storeIds=[];
  48. foreach ($this->stores as $store){
  49. array_push($storeIds,$store->id);
  50. }
  51. $asnDetails=OracleDOCASNDetail::query()->whereIn('asnno',data_get($this->asnHeaders,'*.asnno'))->get();
  52. $maps = [];
  53. foreach ($asnDetails as $asnDetail) {
  54. $value = [
  55. 'owner_code' => $asnDetail->customerid,
  56. 'sku' => $asnDetail->sku,
  57. ];
  58. $maps[json_encode($value)] = $value;
  59. }
  60. /** CommodityService $commodityService */
  61. $commodityService=app(CommodityService::class);
  62. $commodities=$commodityService->getCommoditiesByMaps($maps);
  63. $commodity_ids=[];
  64. foreach ($commodities as $commodity){
  65. array_push($commodity_ids,$commodity->id);
  66. }
  67. DB::table('commodities')->whereIn('id',$commodity_ids)->delete();
  68. DB::table('stores')->whereIn('asn_code',data_get($this->asnHeaders,'*.asnno'))->delete();
  69. DB::table('store_items')->whereIn('store_id',$storeIds)->delete();
  70. cache()->flush();
  71. parent::tearDown(); // TODO: Change the autogenerated stub
  72. }
  73. }