TestMember.php 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: stanley-king
  5. * Date: 2018/1/4
  6. * Time: 上午11:20
  7. */
  8. use bonus\account;
  9. define('BASE_ROOT_PATH',str_replace('/test','',dirname(__FILE__)));
  10. require_once(BASE_ROOT_PATH . '/fooder.php');
  11. class TestMember extends PHPUnit_Framework_TestCase
  12. {
  13. public static function setUpBeforeClass()
  14. {
  15. Base::run_util();
  16. }
  17. public function testInitbind()
  18. {
  19. $mod_member = Model('member');
  20. $i = 0;
  21. while (true)
  22. {
  23. $start = $i * 1000;
  24. $items = $mod_member->field('*')->order('member_id asc')->limit("{$start},1000")->select();
  25. if(empty($items)) {
  26. return;
  27. }
  28. $i++;
  29. foreach ($items as $item)
  30. {
  31. $mobile = $item['member_mobile'];
  32. $member_id = intval($item['member_id']);
  33. if(empty($mobile)) {
  34. $mobile_bind = 0;
  35. } else {
  36. $mobile_bind = 1;
  37. }
  38. $openid = $item['member_wxopenid'];
  39. $unionid = $item['member_wxunionid'];
  40. if(empty($openid) && empty($unionid)) {
  41. $wxunion_bind = 0;
  42. } else {
  43. $wxunion_bind = 1;
  44. }
  45. $ret = $mod_member->editMember(['member_id' => $member_id],['member_mobile_bind' => $mobile_bind,'member_wechat_bind' => $wxunion_bind]);
  46. if($ret && $mod_member->affected_rows() >= 0) {
  47. Log::record("user: {$member_id} edit ok",Log::DEBUG);
  48. } else {
  49. Log::record("user: {$member_id} edit fail",Log::ERR);
  50. }
  51. }
  52. }
  53. }
  54. public function testInitRewaredInviter()
  55. {
  56. $mod_member = Model('member');
  57. $i = 0;
  58. while (true)
  59. {
  60. $start = $i * 1000;
  61. $items = $mod_member->field('*')->order('member_id asc')->limit("{$start},1000")->select();
  62. if(empty($items)) {
  63. return;
  64. }
  65. $i++;
  66. foreach ($items as $item)
  67. {
  68. $member_id = intval($item['member_id']);
  69. $ret = $mod_member->editMember(['member_id' => $member_id],['rewared_inviter' => 1]);
  70. if($ret && $mod_member->affected_rows() >= 0) {
  71. Log::record("user: {$member_id} edit ok",Log::DEBUG);
  72. } else {
  73. Log::record("user: {$member_id} edit fail",Log::ERR);
  74. }
  75. }
  76. }
  77. }
  78. public function testExuser()
  79. {
  80. $user = member_helper::exmembers(array(array('member_mobile' => '13911129867','member_id' => 36490)),true,true);
  81. $user = member_helper::exmembers(array(array('member_mobile' => '13911129867','member_id' => 36490)),true,false);
  82. $user = member_helper::exmembers(array(array('member_mobile' => '13911129867','member_id' => 36490)),false,true);
  83. }
  84. public function testInitbonus()
  85. {
  86. $mod_member = Model('member');
  87. $i = 0;
  88. while (true)
  89. {
  90. $start = $i * 1000;
  91. $items = Model()->table('member')->field('*')->order('member_id asc')->limit("{$start},1000")->select();
  92. if(empty($items)) {
  93. return;
  94. }
  95. $i++;
  96. foreach ($items as $item)
  97. {
  98. $member_id = $item['member_id'];
  99. $pred = new account($member_id);
  100. $amount = $pred->total_bonus();
  101. $mod_member->editMember(['member_id' => $member_id],['available_bonus' => $amount]);
  102. }
  103. }
  104. }
  105. public function testInitinviter()
  106. {
  107. $i = 0;
  108. while (true)
  109. {
  110. $start = $i * 1000;
  111. $items = Model()->table('member_relation')->field('member_id,invited_user')->order('member_mobile asc')->limit("{$start},1000")->select();
  112. if(empty($items)) {
  113. return;
  114. }
  115. $i++;
  116. foreach ($items as $item)
  117. {
  118. $member_id = intval($item['member_id']);
  119. if($member_id <= 0) continue;
  120. $invitees = unserialize($item['invited_user']);
  121. if(empty($invitees)) continue;
  122. foreach ($invitees as $userid) {
  123. $this->update_invitee($member_id,$userid);
  124. }
  125. }
  126. }
  127. }
  128. private function update_invitee($invitorid,$userid)
  129. {
  130. $mod = Model('member');
  131. $invitee = $mod->where(['member_id' => $userid])->find();
  132. if(empty($invitee)) return false;
  133. $inviter_id = intval($invitee['inviter_id']);
  134. if($inviter_id > 0) return false;
  135. $ret = $mod->editMember(['member_id' => $userid],['inviter_id' => $invitorid]);
  136. if($ret == false) {
  137. Log::record(__METHOD__ . " update {$userid} invitor id err",Log::ERR);
  138. }
  139. else {
  140. Log::record(__METHOD__ . " update {$userid} invitor id success",Log::DEBUG);
  141. }
  142. }
  143. }