TestExportOrder.php 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195
  1. <?php
  2. use PHPUnit\Framework\TestCase;
  3. use statistics\stat_refill;
  4. define('APP_ID', 'test');
  5. define('BASE_ROOT_PATH', str_replace('/test', '', dirname(__FILE__)));
  6. require_once(BASE_ROOT_PATH . '/global.php');
  7. require_once(BASE_CORE_PATH . '/lrlz.php');
  8. require_once(BASE_ROOT_PATH . '/fooder.php');
  9. require_once(BASE_HELPER_PATH . '/PHPExcel/PHPExcel.php');
  10. class TestExportOrder extends TestCase
  11. {
  12. public static function setUpBeforeClass() : void
  13. {
  14. Base::run_util();
  15. }
  16. public function testXingzhiyu()
  17. {
  18. $end_time = strtotime("2021-06-15");
  19. $this->exoprt(1093,null,$end_time);
  20. }
  21. public function exoprt($mchid,$start_time = null,$end_time = null)
  22. {
  23. $cond['mchid'] = $mchid;
  24. $cond['vr_order.order_state'] = 40;
  25. if(!is_null($start_time) && !is_null($end_time)) {
  26. $cond["refill_order.notify_time&refill_order.notify_time"] = ['_multi' => true, ['egt', $start_time], ['lt', $end_time]];
  27. }
  28. elseif(!is_null($start_time)) {
  29. $cond["refill_order.notify_time"] = ['egt', $start_time];
  30. }
  31. elseif(!is_null($end_time)) {
  32. $cond["refill_order.notify_time"] = ['lt', $end_time];
  33. }
  34. $path = BASE_DATA_PATH . "/log/{$mchid}.csv";
  35. $fp = fopen($path, 'w');
  36. fputcsv($fp,['序号','商户订单号','卡号','面额','流水号',"下单时间","回调时间"]);
  37. $count = 1000;
  38. $i = 0;
  39. $index = 0;
  40. while (true)
  41. {
  42. $start = $i * $count;
  43. $items = Model('')->table('refill_order,vr_order')
  44. ->field('mch_order,refill_order.card_no,refill_amount,mch_amount,official_sn,from_unixtime(order_time) as sorder_time,from_unixtime(notify_time) as snotify_time')
  45. ->join('inner')
  46. ->on('refill_order.order_id=vr_order.order_id')
  47. ->where($cond)
  48. ->limit("{$start},{$count}")
  49. ->select();
  50. if(empty($items)) {
  51. break;
  52. }
  53. $i++;
  54. foreach ($items as $item)
  55. {
  56. $index++;
  57. $data = [$index,$item['mch_order'],$item['card_no'],$item['refill_amount'],$item['mch_amount'],$item['official_sn'],$item['sorder_time'],$item['snotify_time']];
  58. fputcsv($fp,$data);
  59. }
  60. }
  61. fclose($fp);
  62. }
  63. public function testRefillTask()
  64. {
  65. $model_refill_task = Model('refill_task');
  66. $task = $model_refill_task->UnDispose();
  67. if (empty($task)) return false;
  68. $task_id = $task['task_id'];
  69. switch ($task['task_type']) {
  70. case 'order_export' :
  71. $result = $this->TaskOrderExport($task,$model_refill_task);
  72. break;
  73. default:
  74. $result = '任务类型匹配失败';
  75. break;
  76. }
  77. Log::record("refill task result:{$result}, task_id:{$task_id}");
  78. return true;
  79. }
  80. private function TaskOrderExport($task,$model_refill_task)
  81. {
  82. $task_id = $task['task_id'];
  83. $task_params = unserialize($task['task_params']);
  84. if (empty($task_params)) {
  85. Log::record("refill task condition unserialize err, task_id:{$task_id}");
  86. return false;
  87. }
  88. $model_refill_task->Dispose($task_id);
  89. [$state, $task_result] = $this->order_export($task_params, $task_id);
  90. if ($state) {
  91. $model_refill_task->DisposeFinish($task_id, $task_result);
  92. } else {
  93. $model_refill_task->DisposeErr($task_id, $task_result);
  94. }
  95. return $state;
  96. }
  97. /**
  98. * @throws PHPExcel_Exception
  99. */
  100. private function order_export($condition, $task_id)
  101. {
  102. $orders = Model('refill_order')->getAllOrders($condition);
  103. if (empty($orders)) {
  104. return [false, '统计数据为空'];
  105. }
  106. $merchants = [];
  107. $column_values = ['商户号', '商户名称', '商户订单号','平台单号', '面额', '充值卡号', '充值卡类型', '下单日期', '完成日期', '官方流水号', '订单状态', '扣款金额(下游)', '上游名称','上游订单号', '折扣金额(上游)'];
  108. $data_keys = ['mchid', 'mch_name', 'mch_order', 'order_sn', 'refill_amount', 'card_no', 'card_type_text', 'order_time_text', 'notify_time_text', 'official_sn', 'order_state_text', 'mch_amount', 'channel_name', 'ch_trade_no', 'channel_amount'];
  109. $merchant_list = Model('')->table('merchant')->limit(1000)->order('company_name asc')->select();
  110. foreach ($merchant_list as $value) {
  111. $merchants[$value['mchid']] = $value;
  112. }
  113. $column_key = 'A';
  114. for($index=0;$index<count($column_values);$index++){
  115. $column_keys[] = $column_key;
  116. $column_key++;
  117. }
  118. $objPHPExcel = new PHPExcel();
  119. $objPHPExcel->setActiveSheetIndex(0);
  120. $objPHPExcel->getDefaultStyle()->getFont()->setName('Arial')->setSize(10);
  121. foreach ($column_keys as $key => $column_key) {
  122. $objPHPExcel->getActiveSheet()->getColumnDimension($column_key)->setWidth(25);
  123. $cell_value = $column_key . 1;
  124. $objPHPExcel->getActiveSheet()->setCellValue($cell_value, $column_values[$key]);
  125. }
  126. $card_type_texts = [mtopcard\PetroChinaCard => '中石油', mtopcard\SinopecCard => '中石化', mtopcard\ChinaMobileCard => '中国移动', mtopcard\ChinaUnicomCard => '中国联通', mtopcard\ChinaTelecomCard => '中国电信'];
  127. foreach ($orders as $k => $order) {
  128. if(!empty($merchants)) {
  129. $order['mch_name'] = $merchants[$order['mchid']]['company_name'];
  130. }
  131. $order['card_type_text'] = $card_type_texts[$order['card_type']];
  132. $order['order_time_text'] = $order['order_time'] ? date('Y-m-d H:i:s', $order['order_time']) : '';
  133. $order['notify_time_text'] = $order['notify_time'] ? date('Y-m-d H:i:s', $order['notify_time']) : '';
  134. $order['order_state_text'] = orderState($order);
  135. foreach ($column_keys as $key => $column_key) {
  136. $field = $column_key . ($k + 2);
  137. $objPHPExcel->getActiveSheet()->setCellValueExplicit($field, $order[$data_keys[$key]]);
  138. }
  139. }
  140. try {
  141. $path = BASE_ROOT_PATH . "/data/upload/task/";
  142. if (!is_dir($path)) {
  143. mkdir($path, 0755);
  144. }
  145. $filename = date('YmdHis', time()) . "-任务导出-任务ID:{$task_id}.xlsx";
  146. $file_path = $path . $filename;
  147. $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007');
  148. $objWriter->save($file_path);
  149. return [true, $filename];
  150. } catch (Exception $e) {
  151. return [false, $e->getMessage()];
  152. }
  153. }
  154. public function testStrSer()
  155. {
  156. $str = 'a:3:{s:11:"is_transfer";b:1;s:11:"card_states";a:2:{i:0;i:0;i:1;i:5;}s:10:"card_types";a:1:{i:0;i:4;}}';
  157. $arr = unserialize($str);
  158. $j = 'A';
  159. for($index=0;$index<10;$index++){
  160. $j++;
  161. }
  162. $a1 = [1];
  163. $a = array_merge([0],$a1,[2]);
  164. }
  165. }
  166. //docker-compose run phpcli php /var/www/html/phpunit-9.2.5.phar --filter "/(TestExportOrder::testXingzhiyu)( .*)?$/" --test-suffix TestExportOrder.php /var/www/html/test