| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182 |
- <?php
- namespace Tests\Services\StationTaskCommodityService;
- use App\Batch;
- use App\Order;
- use App\OrderBin;
- use App\OrderCommodity;
- use App\Services\StationRuleBatchService;
- use App\Services\StationTaskCommodityService;
- use App\Services\StationTypeService;
- use Tests\TestCase;
- use App\StationTaskCommodity;
- class CreateByBatchTest extends TestCase
- {
- /** @var StationTaskCommodityService $service */
- public $service;
- private $data;
- private $batchAmount=1;
- private $orderAmount=4;
- private $orderCommodityAmount=8;
- function setUp(): void
- {
- parent::setUp();
- $this->service = app('StationTaskCommodityService');
- $this->data['batches'] =
- factory(Batch::class,
- $this->batchAmount)
- ->create([
- 'status'=>'未处理',
- ]);
- $this->data['orders'] =
- factory(Order::class,
- $this->orderAmount)
- ->create([
- 'status'=>'未处理',
- 'batch_id'=>(function(){
- if(!isset($this->data['temBatchId_orders'])){
- $this->data['temBatchId_orders']=$this->batchAmount;
- }
- $this->data['temBatchId_orders']++;
- if($this->data['temBatchId_orders']>=$this->batchAmount)$this->data['temBatchId_orders']=0;
- return $this->data['batches'][$this->data['temBatchId_orders']];
- })(),
- ]);
- $this->data['orderBins'] =
- factory(OrderBin::class,
- $this->orderAmount)
- ->create([
- 'order_id'=>(function(){
- if(!isset($this->data['temOrderId_ordersBins'])){
- $this->data['temOrderId_ordersBins']=-1;
- }
- $this->data['temOrderId_ordersBins']++;
- return $this->data['orders'][$this->data['temOrderId_ordersBins']];
- })(),
- 'number'=>(function(){
- if(!isset($this->data['temNumber_ordersBins'])){
- $this->data['temNumber_ordersBins']=-1;
- }
- $this->data['temNumber_ordersBins']++;
- return $this->data['temNumber_ordersBins'];
- })(),
- ]);
- $this->data['orderCommodities'] =
- factory(OrderCommodity::class,
- $this->orderCommodityAmount)
- ->create([
- 'order_id'=>(function(){
- if(!isset($this->data['temOrderId_orderCommodities'])){
- $this->data['temOrderId_orderCommodities']=$this->orderAmount;
- }
- $this->data['temOrderId_orderCommodities']++;
- if($this->data['temOrderId_orderCommodities']>=$this->orderAmount)$this->data['temOrderId_orderCommodities']=0;
- return $this->data['orders'][$this->data['temOrderId_orderCommodities']];
- })(),
- ]);
- }
- function subMock(array $serviceDefinition){
- $mockingService=$this->createPartialMock(
- $serviceDefinition['class'],
- array_keys($serviceDefinition['methods'])
- );
- foreach ($serviceDefinition['methods'] as $mName=>$mVal){
- $mockingService->method($mName)->willReturn($mVal);
- }
- foreach ($serviceDefinition['subServices'] as $subService){
- $mockingService->instant(
- $subService['serviceName'],
- ($subServiceMock=function()use($subService){
- $subServiceMock=$this->createPartialMock(
- $subService['class'],
- array_keys($subService['methods'])
- );
- foreach ($subService['methods'] as $methodName=>$methodVal){
- $subServiceMock->method($methodName)->willReturn($methodVal);
- }
- return $subServiceMock;
- })()
- );
- }
- return $mockingService;
- }
- public function testReturned()
- {
- $stationTypeServiceMock=$this->subMock([
- 'class'=>StationTypeService::class,
- 'methods'=>[
- // 'getByBatch'=>111,
- ],
- 'subServices'=>[
- [
- 'serviceName'=>'stationRuleBatchService',
- 'class'=>stationRuleBatchService::class,
- 'methods'=>[
- 'getByBatch'=>4242,
- 'aaa'=>222,
- ],
- ],
- ]
- ]);
- dd($stationTypeServiceMock->getByBatch(new Batch()));
- // $stationTypeServiceMock=( function (){
- // $stationTypeServiceMock=$this->createPartialMock(
- // StationTypeService::class,
- // ['aaa']
- // );
- // $stationRuleBatchServiceStr = 'stationRuleBatchService';
- // $stationTypeServiceMock->instant(
- // $stationRuleBatchServiceStr,
- // ($stationRuleBatchServiceMock=function(){
- // $mock=$this->createPartialMock(
- // StationRuleBatchService::class,
- // ['getByBatch']
- // );
- // $mock->method('getByBatch')->willReturn('ddd');
- // return $mock;
- // })()
- // );
- // return $stationTypeServiceMock;
- // })();
- $this->data['stationTaskCommodities']
- =(function(){
- if(!isset($this->data['stationTaskCommodities']))
- $this->data['stationTaskCommodities'] = collect();
- foreach($this->data['batches'] as $batch){
- $this->data['stationTaskCommodities']
- =$this->data['stationTaskCommodities']->merge(
- $this->service->createByBatch($batch)//<<---testing it
- );
- }
- return $this->data['stationTaskCommodities'];
- })();
- $this->assertEquals($this->orderCommodityAmount, $this->data['stationTaskCommodities']->count());
- }
- function tearDown(): void
- {
- StationTaskCommodity::query()
- ->whereIn('id',data_get($this->data['stationTaskCommodities'],'*.id')??[])
- ->delete();
- Batch::query()
- ->whereIn('id',data_get($this->data['batches'],'*.id')??[])
- ->delete();
- Order::query()
- ->whereIn('id',data_get($this->data['orders'],'*.id')??[])
- ->delete();
- OrderBin::query()
- ->whereIn('id',data_get($this->data['orderBins'],'*.id')??[])
- ->delete();
- OrderCommodity::query()
- ->whereIn('id',data_get($this->data['orderCommodities'],'*.id')??[])
- ->delete();
- parent::tearDown();
- }
- }
|