TestOrder.php 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: stanley-king
  5. * Date: 2017/1/13
  6. * Time: 下午11:46
  7. */
  8. define('BASE_ROOT_PATH',str_replace('/test','',dirname(__FILE__)));
  9. require_once (BASE_ROOT_PATH . '/fooder.php');
  10. require_once (BASE_ROOT_PATH . '/helper/util_helper.php');
  11. require_once (BASE_ROOT_PATH . '/helper/order_helper.php');
  12. class TestOrder extends PHPUnit_Framework_TestCase
  13. {
  14. public static function setUpBeforeClass()
  15. {
  16. Base::run_util();
  17. }
  18. public static function tearDownAfterClass()
  19. {
  20. }
  21. public function testCancelOms()
  22. {
  23. $oms = Logic('delivery');
  24. $oms->cancel_oms('9000000002963603');
  25. }
  26. public static function testSuccess()
  27. {
  28. $model_order = Model('order');
  29. $logic_order = Logic('order');
  30. $condition = array();
  31. $condition['order_state'] = ORDER_STATE_SEND;
  32. $condition['lock_state'] = 0;
  33. //$condition['delay_time'] = array('lt',time() - ORDER_AUTO_RECEIVE_DAY * 86400);
  34. $condition['order_id'] = 6591;
  35. //分批,每批处理100个订单,最多处理5W个订单
  36. $order_list = $model_order->getOrderList($condition, '', '*', 'delay_time asc', 100);
  37. foreach ($order_list as $order_info) {
  38. $result = $logic_order->changeOrderStateReceive($order_info,'system','系统','超期未收货系统自动完成订单');
  39. }
  40. }
  41. public function testSend()
  42. {
  43. $order_sn = '9000000001035202';
  44. $status = 1;
  45. $consign_time = '2017-01-15 18:07:05.0';
  46. $logistics_no = '3322415835338';
  47. $logistics_company = '申通快递';
  48. $express = Model('express')->field('id')->where(array('e_name' => $logistics_company))->select();
  49. if (empty($express) || count($express) == 0) {
  50. echo 'FAIL';
  51. return;
  52. }
  53. $express_id = $express[0]['id'];
  54. $time = strtotime($consign_time);
  55. }
  56. public function testInitOrder()
  57. {
  58. $mod_member = Model('member');
  59. $i = 0;
  60. while (true)
  61. {
  62. $start = $i * 1000;
  63. $items = Model()->table('member')->field('member_id')->order('member_id asc')->limit("{$start},1000")->select();
  64. if(empty($items)) {
  65. return;
  66. }
  67. $i++;
  68. foreach ($items as $item)
  69. {
  70. $member_id = intval($item['member_id']);
  71. if($member_id <= 0) continue;
  72. $result = $this->stat_order($member_id);
  73. if($result == false) continue;
  74. $order_num = intval($result['order_num']);
  75. $lasted_time = intval($result['lastest_time']);
  76. $mod_member->editMember(['member_id' => $member_id],['order_num' => $order_num,'lastest_order' => $lasted_time]);
  77. }
  78. }
  79. }
  80. private function stat_order($member_id)
  81. {
  82. $items = Model()->table('order')
  83. ->field('count(*) as order_num,max(payment_time) lastest_time')
  84. ->where(['buyer_id' => $member_id,'order_state' => array('in',[20,30,40])])
  85. ->select();
  86. if(empty($items)) {
  87. return false;
  88. }
  89. else
  90. {
  91. if($items[0]['order_num'] == 0){
  92. return false;
  93. } else {
  94. return $items[0];
  95. }
  96. }
  97. }
  98. public function testMemberOrder()
  99. {
  100. $mod_member = Model('member');
  101. $this->mStartm = strtotime(date('Y-m-d',time()));
  102. $this->mEndtm = $this->mStartm + 86400 - 1;
  103. $cond['payment_time'] = ['between',"{$this->mStartm},{$this->mEndtm}"];
  104. $cond['order_state'] = array('in',[20,30,40]);
  105. $i = 0;
  106. while (true)
  107. {
  108. $start = $i * 1000;
  109. $items = Model()->table('order')->field('buyer_id,payment_time')->where($cond)->order('payment_time asc')->limit("{$start},1000")->select();
  110. if(empty($items)) {
  111. return;
  112. }
  113. $i++;
  114. foreach ($items as $item)
  115. {
  116. $member_id = intval($item['buyer_id']);
  117. if($member_id <= 0) continue;
  118. $payment_time = intval($item['payment_time']);
  119. if($payment_time <= 0) continue;
  120. $mod_member->editMember(['member_id' => $member_id],['order_num' => array('exp', 'order_num+1'),'lastest_order' => $payment_time]);
  121. }
  122. }
  123. }
  124. public function testStatCall()
  125. {
  126. $x = 'a:4:{s:8:"function";a:16:{s:10:"app_update";a:2:{s:13:"check_version";a:1:{s:5:"count";i:7;}s:4:"area";a:1:{s:5:"count";i:7;}}s:6:"config";a:1:{s:11:"getconfigex";a:1:{s:5:"count";i:9;}}s:11:"member_info";a:2:{s:3:"get";a:1:{s:5:"count";i:7;}s:4:"edit";a:1:{s:5:"count";i:1;}}s:7:"special";a:1:{s:5:"index";a:1:{s:5:"count";i:10;}}s:5:"index";a:2:{s:6:"splash";a:1:{s:5:"count";i:8;}s:4:"tabs";a:1:{s:5:"count";i:8;}}s:5:"login";a:1:{s:6:"status";a:1:{s:5:"count";i:8;}}s:12:"member_order";a:1:{s:15:"orderCountState";a:1:{s:5:"count";i:5;}}s:12:"member_bonus";a:1:{s:5:"topup";a:1:{s:5:"count";i:16;}}s:13:"member_logout";a:1:{s:5:"index";a:1:{s:5:"count";i:2;}}s:14:"member_address";a:1:{s:12:"address_list";a:1:{s:5:"count";i:1;}}s:7:"bonusex";a:1:{s:4:"open";a:1:{s:5:"count";i:2;}}s:6:"search";a:3:{s:13:"suggest_words";a:1:{s:5:"count";i:4;}s:5:"index";a:1:{s:5:"count";i:7;}s:7:"history";a:1:{s:5:"count";i:1;}}s:12:"goods_common";a:1:{s:5:"index";a:1:{s:5:"count";i:2;}}s:5:"fcode";a:2:{s:5:"index";a:1:{s:5:"count";i:4;}s:4:"open";a:1:{s:5:"count";i:4;}}s:5:"mshop";a:1:{s:7:"signurl";a:1:{s:5:"count";i:3;}}s:4:"cart";a:2:{s:5:"addex";a:1:{s:5:"count";i:1;}s:10:"rate_money";a:1:{s:5:"count";i:1;}}}s:5:"other";a:3:{s:10:"goods_4919";a:1:{s:5:"count";i:1;}s:10:"goods_6212";a:1:{s:5:"count";i:1;}s:11:"special_466";a:1:{s:5:"count";i:1;}}s:9:"app_count";i:107;s:9:"wap_count";i:11;}';
  127. $y = unserialize($x);
  128. $x = json_encode($y);
  129. $x = json_decode($x,true);
  130. }
  131. public function testBonusRate()
  132. {
  133. $data = 'a:2:{i:50;d:5.1799999999999997;i:30;d:17.59;}';
  134. $x = unserialize($data);
  135. }
  136. public function testRefund()
  137. {
  138. //SELECT * FROM lrlz_order WHERE add_time > UNIX_TIMESTAMP(DATE ('2017-09-28 00:00:00')) AND order_state = 0;
  139. $items = Model()->query('SELECT * FROM lrlz_order WHERE pd_amount=0 AND LENGTH(bonus_rate) > 0 AND add_time > UNIX_TIMESTAMP(DATE (\'2017-09-01 00:00:00\')) AND order_state = 0');
  140. foreach ($items as $item) {
  141. $order_sn = $item['order_sn'];
  142. $member_id = intval($item['buyer_id']);
  143. account_helper::order_cancel($order_sn,$member_id,true);
  144. }
  145. }
  146. public function testVOrder()
  147. {
  148. $model_vr_order = Model('vr_order');
  149. $order_list = $model_vr_order->getOrderList(['order_id' => 1]);
  150. $page_count = $model_vr_order->gettotalpage();
  151. $helper = new vorder_helper($order_list);
  152. $result = $helper->format();
  153. }
  154. }