CreateStoreTest.php 2.9 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. $this->service=app(StoreService::class);
  23. $this->data['warehouse'] = factory(Warehouse::class)->create(['code'=>'test_wh']);
  24. $this->data['owner'] = factory(Owner::class)->create(['code'=>'test_owner','name'=>'测试货主']);
  25. $wmsAsnHeader = factory(OracleDOCASNHeader::class)->make([
  26. 'customerid'=>'test_owner','warehouseid'=>'test_wh','asntype'=>'CSRK','asnstatus'=>'11',
  27. ]);
  28. $asnType = factory(OracleBasCode::class)->make(['codeid'=>'ASN_TYP','code'=>'CSRK','descr_c'=>'测试入库']);
  29. $asnStatus = factory(OracleBasCode::class)->make(['code'=>'11', 'codeid'=>'ASN_STS', 'codename_c'=>'测试状态']);
  30. $wmsAsnHeader->setRelation('asnType',$asnType);
  31. $wmsAsnHeader->setRelation('asnStatus',$asnStatus);
  32. $this->asnHeaders=collect();
  33. $this->asnHeaders->add($wmsAsnHeader);
  34. }
  35. public function testCreateStore(){
  36. if (!$this->asnHeaders) return null;
  37. $this->service->createStore($this->asnHeaders);
  38. $this->stores=$this->service->getByWms($this->asnHeaders);
  39. $this->assertNotnull($this->stores);
  40. $this->assertNotNull($this->asnHeaders);
  41. }
  42. public function tearDown(): void
  43. {
  44. $this->data['warehouse']->delete();
  45. $this->data['owner']->delete();
  46. $storeIds=[];
  47. foreach ($this->stores as $store){
  48. array_push($storeIds,$store->id);
  49. }
  50. $asnDetails=OracleDOCASNDetail::query()->whereIn('asnno',data_get($this->asnHeaders,'*.asnno'))->get();
  51. $maps = [];
  52. foreach ($asnDetails as $asnDetail) {
  53. $value = [
  54. 'owner_code' => $asnDetail->customerid,
  55. 'sku' => $asnDetail->sku,
  56. ];
  57. $maps[json_encode($value)] = $value;
  58. }
  59. /** CommodityService $commodityService */
  60. $commodityService=app(CommodityService::class);
  61. $commodities=$commodityService->getCommoditiesByMaps($maps);
  62. $commodity_ids=[];
  63. foreach ($commodities as $commodity){
  64. array_push($commodity_ids,$commodity->id);
  65. }
  66. DB::table('commodities')->whereIn('id',$commodity_ids)->delete();
  67. DB::table('stores')->whereIn('asn_code',data_get($this->asnHeaders,'*.asnno'))->delete();
  68. DB::table('store_items')->whereIn('store_id',$storeIds)->delete();
  69. parent::tearDown(); // TODO: Change the autogenerated stub
  70. }
  71. }