TestExportOrder.php 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257
  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. class TestExportOrder extends TestCase
  10. {
  11. public static function setUpBeforeClass() : void
  12. {
  13. Base::run_util();
  14. }
  15. public function testXingzhiyu()
  16. {
  17. $end_time = strtotime("2021-06-15");
  18. $this->exoprt(10132,null,$end_time);
  19. }
  20. public function exoprt($mchid,$start_time = null,$end_time = null)
  21. {
  22. $cond['mchid'] = $mchid;
  23. $cond['vr_order.order_state'] = 40;
  24. if(!is_null($start_time) && !is_null($end_time)) {
  25. $cond["refill_order.notify_time&refill_order.notify_time"] = ['_multi' => true, ['egt', $start_time], ['lt', $end_time]];
  26. }
  27. elseif(!is_null($start_time)) {
  28. $cond["refill_order.notify_time"] = ['egt', $start_time];
  29. }
  30. elseif(!is_null($end_time)) {
  31. $cond["refill_order.notify_time"] = ['lt', $end_time];
  32. }
  33. $path = BASE_DATA_PATH . "/log/{$mchid}.csv";
  34. $fp = fopen($path, 'w');
  35. fputcsv($fp,['序号','商户订单号','卡号','面额','流水号',"下单时间","回调时间"]);
  36. $count = 1000;
  37. $i = 0;
  38. $index = 0;
  39. while (true)
  40. {
  41. $start = $i * $count;
  42. $items = Model('')->table('refill_order,vr_order')
  43. ->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')
  44. ->join('inner')
  45. ->on('refill_order.order_id=vr_order.order_id')
  46. ->where($cond)
  47. ->limit("{$start},{$count}")
  48. ->select();
  49. if(empty($items)) {
  50. break;
  51. }
  52. $i++;
  53. foreach ($items as $item)
  54. {
  55. $index++;
  56. $data = [$index,$item['mch_order'],$item['card_no'],$item['refill_amount'],$item['mch_amount'],$item['official_sn'],$item['sorder_time'],$item['snotify_time']];
  57. fputcsv($fp,$data);
  58. }
  59. }
  60. fclose($fp);
  61. }
  62. public function testRefillTask()
  63. {
  64. $model_refill_task = Model('refill_task');
  65. $task = $model_refill_task->UnDispose('order_export');
  66. if (empty($task)) return false;
  67. $task_id = $task['task_id'];
  68. $task_condition = unserialize($task['task_condition']);
  69. if (empty($task_condition)) {
  70. Log::record("refill task condition unserialize err, task_id:{$task_id}");
  71. return false;
  72. }
  73. $type = $task['type'];
  74. $cid = $task['cid'];
  75. if ($type === 'merchant') {
  76. $condition['refill_order.mchid'] = $cid;
  77. } elseif ($type === 'provider') {
  78. $condition['vr_order.store_id'] = $cid;
  79. } else {
  80. Log::record("refill task type err, task_id:{$task_id}");
  81. return false;
  82. }
  83. $order_time_type = $task_condition['order_time_type'];
  84. $start_unixtime = $task_condition['start_unixtime'];
  85. $end_unixtime = $task_condition['end_unixtime'];
  86. $order_state = $task_condition['order_state'];
  87. if ($start_unixtime > 0 && $end_unixtime > $start_unixtime) {
  88. $condition["refill_order.{$order_time_type}"] = [['egt', $start_unixtime], ['lt', $end_unixtime], 'and'];
  89. $condition['vr_order.add_time'] = ['egt', $start_unixtime-1];
  90. } elseif ($start_unixtime > 0) {
  91. $condition["refill_order.{$order_time_type}"] = ['egt', $start_unixtime];
  92. $condition['vr_order.add_time'] = ['egt', $start_unixtime-1];
  93. }
  94. if (in_array($order_state, ['0', '10', '20', '30', '40'], true)) {
  95. $condition['order_state'] = $order_state;
  96. }
  97. $model_refill_task->Dispose($task_id);
  98. [$state, $task_result] = $this->order_export($condition, $type, $task_id);
  99. if ($state) {
  100. $model_refill_task->DisposeFinish($task_id, $task_result);
  101. } else {
  102. $model_refill_task->DisposeErr($task_id, $task_result);
  103. }
  104. return true;
  105. }
  106. /**
  107. * @throws PHPExcel_Exception
  108. */
  109. private function order_export($condition, $type, $task_id)
  110. {
  111. $orders = $this->getAllOrders($condition);
  112. if(empty($orders)) {
  113. return [false, '统计数据为空'];
  114. }
  115. $orders = $this->orderFormat($orders);
  116. $objPHPExcel = new PHPExcel();
  117. if ($type === 'merchant') {
  118. $column_keys = ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K'];
  119. $column_values = ['商户号', '客户订单号', '平台单号', '面额', '充值卡号', '充值卡类型', '下单日期', '完成日期', '官方流水号', '订单状态', '扣款金额'];
  120. $data_keys = ['mchid', 'mch_order', 'order_sn', 'refill_amount', 'card_no', 'card_type_text', 'order_time_text', 'notify_time_text', 'official_sn', 'order_state_text', 'mch_amount'];
  121. } elseif ($type === 'provider') {
  122. $column_keys = ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J'];
  123. $column_values = ['上游订单号', '平台单号', '面额', '充值卡号', '充值卡类型', '下单日期', '完成日期', '官方流水号', '订单状态', '扣款金额'];
  124. $data_keys = ['ch_trade_no', 'order_sn', 'refill_amount', 'card_no', 'card_type_text', 'order_time_text', 'notify_time_text', 'official_sn', 'order_state_text', 'channel_amount'];
  125. } else {
  126. return [false, '主体类型错误'];
  127. }
  128. $objPHPExcel->setActiveSheetIndex(0);
  129. $objPHPExcel->getDefaultStyle()->getFont()->setName('Arial')->setSize(10);
  130. foreach ($column_keys as $key => $column_key) {
  131. $objPHPExcel->getActiveSheet()->getColumnDimension($column_key)->setWidth(25);
  132. $cell_value = $column_key . 1;
  133. $objPHPExcel->getActiveSheet()->setCellValue($cell_value, $column_values[$key]);
  134. }
  135. foreach ($orders as $k => $order) {
  136. foreach ($column_keys as $key => $column_key) {
  137. $field = $column_key.($k+2);
  138. $objPHPExcel->getActiveSheet()->setCellValueExplicit($field, $order[$data_keys[$key]],
  139. PHPExcel_Cell_DataType::TYPE_STRING);
  140. }
  141. }
  142. try {
  143. $path = BASE_ROOT_PATH . "/data/upload/task/";
  144. if(!is_dir($path)){
  145. mkdir($path, 0755);
  146. }
  147. $filename = date('YmdHis',time())."-任务导出-任务ID:{$task_id}.xlsx";
  148. $file_path = $path . $filename;
  149. $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007');
  150. $objWriter->save($file_path);
  151. return [true, $filename];
  152. } catch (Exception $e) {
  153. return [false, $e->getMessage()];
  154. }
  155. }
  156. private function getAllOrders($condition): array
  157. {
  158. $len = 1000;
  159. $i = 0;
  160. $orders = [];
  161. while (true)
  162. {
  163. $start = $i * $len;
  164. $items = Model('')->table('refill_order,vr_order')
  165. ->field('refill_order.*,vr_order.order_state')
  166. ->join('inner')
  167. ->on('refill_order.order_id=vr_order.order_id')
  168. ->where($condition)
  169. ->order('refill_order.order_time desc')
  170. ->limit("{$start},{$len}")
  171. ->select();
  172. $orders = array_merge($orders,$items);
  173. if (empty($items) || count($items) < $len) {
  174. break;
  175. }
  176. $i++;
  177. }
  178. return $orders;
  179. }
  180. private function orderFormat($orders): array
  181. {
  182. $card_type_texts = [mtopcard\PetroChinaCard => '中石油', mtopcard\SinopecCard => '中石化', mtopcard\ChinaMobileCard => '中国移动', mtopcard\ChinaUnicomCard => '中国联通', mtopcard\ChinaTelecomCard => '中国电信'];
  183. $orderState = function ($order_info) {
  184. $is_retrying = $order_info['is_retrying'];
  185. switch ($order_info['order_state']) {
  186. case ORDER_STATE_CANCEL:
  187. if ($is_retrying) {
  188. $order_state = '重试中';
  189. } else {
  190. $order_state = '已取消';
  191. }
  192. break;
  193. case ORDER_STATE_NEW:
  194. $order_state = '待付款';
  195. break;
  196. case ORDER_STATE_PAY:
  197. $order_state = '待发货';
  198. break;
  199. case ORDER_STATE_SEND:
  200. $order_state = '待收货';
  201. break;
  202. case ORDER_STATE_SUCCESS:
  203. $order_state = '交易完成';
  204. break;
  205. default :
  206. $order_state = '未知状态';
  207. }
  208. return $order_state;
  209. };
  210. foreach($orders as $key => $order)
  211. {
  212. $orders[$key]['card_type_text'] = $card_type_texts[$order['card_type']];
  213. $orders[$key]['order_time_text'] = $order['order_time'] ? date('Y-m-d H:i:s', $order['order_time']) : '';
  214. $orders[$key]['notify_time_text'] = $order['notify_time'] ? date('Y-m-d H:i:s', $order['notify_time']) : '';
  215. $orders[$key]['order_state_text'] = $orderState($order);
  216. }
  217. return $orders;
  218. }
  219. public function testStrSer()
  220. {
  221. $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;}}';
  222. $arr = unserialize($str);
  223. }
  224. }
  225. //docker-compose run phpcli php /var/www/html/phpunit-9.2.5.phar --filter "/(TestExportOrder::testXingzhiyu)( .*)?$/" --test-suffix TestExportOrder.php /var/www/html/test