AutomatedTestCaseGroupModule.class.php 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227
  1. <?php
  2. /**
  3. * @name eolinker ams open source,eolinker开源版本
  4. * @link https://www.eolinker.com/
  5. * @package eolinker
  6. * @author www.eolinker.com 广州银云信息科技有限公司 ©2015-2018
  7. * eoLinker是目前全球领先、国内最大的在线API接口管理平台,提供自动生成API文档、API自动化测试、Mock测试、团队协作等功能,旨在解决由于前后端分离导致的开发效率低下问题。
  8. * 如在使用的过程中有任何问题,欢迎加入用户讨论群进行反馈,我们将会以最快的速度,最好的服务态度为您解决问题。
  9. *
  10. * eoLinker AMS开源版的开源协议遵循Apache License 2.0,如需获取最新的eolinker开源版以及相关资讯,请访问:https://www.eolinker.com/#/os/download
  11. *
  12. * 官方网站:https://www.eolinker.com/
  13. * 官方博客以及社区:http://blog.eolinker.com/
  14. * 使用教程以及帮助:http://help.eolinker.com/
  15. * 商务合作邮箱:market@eolinker.com
  16. * 用户讨论QQ群:284421832
  17. */
  18. class AutomatedTestCaseGroupModule
  19. {
  20. /**
  21. * 获取用户权限类型
  22. * @param $group_id
  23. * @return bool|int
  24. */
  25. public function getUserType(&$group_id)
  26. {
  27. $group_dao = new AutomatedTestCaseGroupDao();
  28. if (!($project_id = $group_dao->checkAutomatedTestCaseGroupPermission($group_id, $_SESSION['userID']))) {
  29. return -1;
  30. }
  31. $auth_dao = new AuthorizationDao();
  32. $result = $auth_dao->getProjectUserType($_SESSION['userID'], $project_id);
  33. if ($result === FALSE) {
  34. return -1;
  35. }
  36. return $result;
  37. }
  38. /**
  39. * 添加用例分组
  40. * @param $project_id
  41. * @param $user_id
  42. * @param $group_name
  43. * @param $parent_group_id
  44. * @return bool
  45. */
  46. public function addGroup(&$project_id, &$user_id, &$group_name, &$parent_group_id)
  47. {
  48. $project_dao = new ProjectDao();
  49. $group_dao = new AutomatedTestCaseGroupDao();
  50. if (!$project_dao->checkProjectPermission($project_id, $user_id)) {
  51. return FALSE;
  52. }
  53. // 判断是否有父分组
  54. if (!$parent_group_id) {
  55. // 没有父分组
  56. $group_id = $group_dao->addGroup($project_id, $group_name);
  57. $desc = "添加用例分组:'{$group_name}'";
  58. } else {
  59. if (!$group_dao->checkAutomatedTestCaseGroupPermission($parent_group_id, $user_id)) {
  60. return FALSE;
  61. }
  62. // 有父分组
  63. $group_id = $group_dao->addChildGroup($project_id, $group_name, $parent_group_id);
  64. $parent_group_name = $group_dao->getGroupName($parent_group_id);
  65. $desc = "添加用例子分组:'{$parent_group_name}>>{$group_name}'";
  66. }
  67. if ($group_id) {
  68. // 更新项目的更新时间
  69. $project_dao->updateProjectUpdateTime($project_id);
  70. // 将操作写入日志
  71. $log_dao = new ProjectLogDao();
  72. $log_dao->addOperationLog($project_id, $user_id, ProjectLogDao::$OP_TARGET_AUTOMATED_TEST_CASE_GROUP, $group_id, ProjectLogDao::$OP_TYPE_ADD, $desc, date("Y-m-d H:i:s", time()));
  73. // 返回分组的groupID
  74. return $group_id;
  75. } else {
  76. return FALSE;
  77. }
  78. }
  79. /**
  80. * 删除用例分组
  81. * @param $user_id
  82. * @param $group_id
  83. * @return bool
  84. */
  85. public function deleteGroup(&$user_id, &$group_id)
  86. {
  87. $group_dao = new AutomatedTestCaseGroupDao();
  88. if (!($project_id = $group_dao->checkAutomatedTestCaseGroupPermission($group_id, $user_id))) {
  89. return FALSE;
  90. }
  91. $group_name = $group_dao->getGroupName($group_id);
  92. if ($group_dao->deleteGroup($project_id, $group_id)) {
  93. // 更新项目的更新时间
  94. $project_dao = new ProjectDao();
  95. $project_dao->updateProjectUpdateTime($project_id);
  96. // 将操作写入日志
  97. $log_dao = new ProjectLogDao();
  98. $log_dao->addOperationLog($project_id, $user_id, ProjectLogDao::$OP_TARGET_AUTOMATED_TEST_CASE_GROUP, $group_id, ProjectLogDao::$OP_TYPE_DELETE, "删除用例分组:'$group_name'", date("Y-m-d H:i:s", time()));
  99. return TRUE;
  100. } else {
  101. return FALSE;
  102. }
  103. }
  104. /**
  105. * 获取用例分组
  106. * @param $project_id
  107. * @param $user_id
  108. * @return bool
  109. */
  110. public function getGroupList(&$project_id, &$user_id)
  111. {
  112. $project_dao = new ProjectDao();
  113. if (!$project_dao->checkProjectPermission($project_id, $user_id)) {
  114. return FALSE;
  115. }
  116. $group_dao = new AutomatedTestCaseGroupDao();
  117. return $group_dao->getGroupList($project_id);
  118. }
  119. /**
  120. * 修改用例分组
  121. * @param $user_id
  122. * @param $group_id
  123. * @param $group_name
  124. * @param $parent_group_id
  125. * @return bool
  126. */
  127. public function editGroup(&$user_id, &$group_id, &$group_name, &$parent_group_id)
  128. {
  129. $group_dao = new AutomatedTestCaseGroupDao();
  130. if (!($project_id = $group_dao->checkAutomatedTestCaseGroupPermission($group_id, $user_id))) {
  131. return FALSE;
  132. }
  133. if ($parent_group_id && !$group_dao->checkAutomatedTestCaseGroupPermission($parent_group_id, $user_id)) {
  134. return FALSE;
  135. }
  136. if ($group_dao->editGroup($project_id, $group_id, $group_name, $parent_group_id)) {
  137. // 更新项目的更新时间
  138. $project_dao = new ProjectDao();
  139. $project_dao->updateProjectUpdateTime($project_id);
  140. // 将操作写入日志
  141. $log_dao = new ProjectLogDao();
  142. $log_dao->addOperationLog($project_id, $user_id, ProjectLogDao::$OP_TARGET_AUTOMATED_TEST_CASE_GROUP, $group_id, ProjectLogDao::$OP_TYPE_UPDATE, "修改用例分组:'{$group_name}'", date("Y-m-d H:i:s", time()));
  143. return TRUE;
  144. } else {
  145. return FALSE;
  146. }
  147. }
  148. /**
  149. * 分组排序
  150. * @param $project_id
  151. * @param $order_list
  152. * @param $user_id
  153. * @return bool
  154. */
  155. public function sortGroup(&$project_id, &$order_list, &$user_id)
  156. {
  157. $project_dao = new ProjectDao();
  158. if (!$project_dao->checkProjectPermission($project_id, $user_id)) {
  159. return FALSE;
  160. }
  161. $group_dao = new AutomatedTestCaseGroupDao();
  162. $result = $group_dao->updateGroupOrder($project_id, $order_list);
  163. if ($result) {
  164. return TRUE;
  165. } else {
  166. return FALSE;
  167. }
  168. }
  169. /**
  170. * 获取用例分组数据
  171. * @param $group_id
  172. * @param $user_id
  173. * @return array|bool
  174. */
  175. public function exportTestCaseGroup(&$group_id, &$user_id)
  176. {
  177. $group_dao = new AutomatedTestCaseGroupDao();
  178. if (!($projectID = $group_dao->checkAutomatedTestCaseGroupPermission($group_id, $user_id))) {
  179. return FALSE;
  180. } else {
  181. $data = json_encode($group_dao->getTestCaseGroupData($group_id));
  182. $fileName = 'eolinker_test_case_group_dump_' . $_SESSION['userName'] . '_' . time() . '.export';
  183. if (file_put_contents(realpath('./dump') . DIRECTORY_SEPARATOR . $fileName, $data)) {
  184. //将操作写入日志
  185. $log_dao = new ProjectLogDao();
  186. $log_dao->addOperationLog($projectID, $_SESSION['userID'], ProjectLogDao::$OP_TARGET_AUTOMATED_TEST_CASE_GROUP, $group_id, ProjectLogDao::$OP_TYPE_OTHERS, "导出自动化测试用例分组", date("Y-m-d H:i:s", time()));
  187. return $fileName;
  188. } else {
  189. return FALSE;
  190. }
  191. }
  192. }
  193. /**
  194. * 导出用例分组数据
  195. * @param $project_id
  196. * @param $user_id
  197. * @param $data
  198. * @return bool
  199. */
  200. public function importTestCaseGroup(&$project_id, &$user_id, &$data)
  201. {
  202. $project_dao = new ProjectDao();
  203. if (!($projectID = $project_dao->checkProjectPermission($project_id, $user_id))) {
  204. return FALSE;
  205. }
  206. $group_dao = new AutomatedTestCaseGroupDao();
  207. if ($group_dao->importTestCaseGroup($project_id, $user_id, $data)) {
  208. //将操作写入日志
  209. $log_dao = new ProjectLogDao();
  210. $log_dao->addOperationLog($projectID, $_SESSION['userID'], ProjectLogDao::$OP_TARGET_AUTOMATED_TEST_CASE_GROUP, $project_id, ProjectLogDao::$OP_TYPE_ADD, "导入自动化测试用例分组:" . $data['groupName'], date("Y-m-d H:i:s", time()));
  211. return TRUE;
  212. } else {
  213. return FALSE;
  214. }
  215. }
  216. }