TestHistoryDao.class.php 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  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 TestHistoryDao
  19. {
  20. /**
  21. * 添加测试记录
  22. * @param $projectID int 项目ID
  23. * @param $apiID int 接口ID
  24. * @param $requestInfo string 测试请求信息
  25. * @param $resultInfo string 测试结果信息
  26. * @param $testTime string 测试时间
  27. * @return bool|int
  28. */
  29. public function addTestHistory(&$projectID, &$apiID, &$requestInfo, &$resultInfo, &$testTime)
  30. {
  31. $db = getDatabase();
  32. $db->prepareExecute('INSERT INTO eo_api_test_history (eo_api_test_history.projectID,eo_api_test_history.apiID,eo_api_test_history.requestInfo,eo_api_test_history.resultInfo,eo_api_test_history.testTime) VALUES (?,?,?,?,?);', array(
  33. $projectID,
  34. $apiID,
  35. $requestInfo,
  36. $resultInfo,
  37. $testTime
  38. ));
  39. if ($db->getAffectRow() < 1)
  40. return FALSE;
  41. else {
  42. return $db->getLastInsertID();
  43. }
  44. }
  45. /**
  46. * 删除测试记录
  47. * @param $testID int 测试记录ID
  48. * @return bool
  49. */
  50. public function deleteTestHistory(&$testID)
  51. {
  52. $db = getDatabase();
  53. $db->prepareExecute('DELETE FROM eo_api_test_history WHERE eo_api_test_history.testID =?;', array($testID));
  54. if ($db->getAffectRow() < 1)
  55. return FALSE;
  56. else
  57. return TRUE;
  58. }
  59. /**
  60. * 获取测试记录信息
  61. * @param $testID int 测试记录ID
  62. * @return bool|array
  63. */
  64. public function getTestHistory(&$testID)
  65. {
  66. $db = getDatabase();
  67. $result = $db->prepareExecute('SELECT eo_api_test_history.projectID,eo_api_test_history.apiID,eo_api_test_history.testID,eo_api_test_history.requestInfo,eo_api_test_history.resultInfo,eo_api_test_history.testTime FROM eo_api_test_history WHERE testID =?;', array($testID));
  68. if (empty($result))
  69. return FALSE;
  70. else
  71. return $result;
  72. }
  73. /**
  74. * 检查测试记录与用户的联系
  75. * @param $testID int 测试记录ID
  76. * @param $userID int 用户ID
  77. * @return bool|int
  78. */
  79. public function checkTestHistoryPermission(&$testID, &$userID)
  80. {
  81. $db = getDatabase();
  82. $result = $db->prepareExecute('SELECT eo_conn_project.projectID FROM eo_api_test_history INNER JOIN eo_api INNER JOIN eo_conn_project ON eo_api.projectID = eo_conn_project.projectID AND eo_api.apiID = eo_api_test_history.apiID WHERE eo_api_test_history.testID = ? AND eo_conn_project.userID = ?;', array(
  83. $testID,
  84. $userID
  85. ));
  86. if (empty($result))
  87. return FALSE;
  88. else
  89. return $result['projectID'];
  90. }
  91. /**
  92. * 删除所有测试记录
  93. * @param $apiID int 接口ID
  94. * @return bool
  95. */
  96. public function deleteAllTestHistory(&$apiID)
  97. {
  98. $db = getDatabase();
  99. $db->prepareExecuteAll('DELETE FROM eo_api_test_history WHERE apiID = ?;', array($apiID));
  100. if ($db->getAffectRow() < 1) {
  101. return FALSE;
  102. } else {
  103. return TRUE;
  104. }
  105. }
  106. }
  107. ?>