ProtobufControllerTest.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369
  1. <?php
  2. namespace Tests\Unit;
  3. use Tests\TestCase;
  4. use GuzzleHttp\Client;
  5. use Uraus\App\Request;
  6. use Uraus\App\Response;
  7. use UCore\Model\RequestLog;
  8. use Uraus\App\Common\RESPONSE_CODE;
  9. use Illuminate\Support\Facades\Log;
  10. class ProtobufControllerTest extends TestCase
  11. {
  12. private Client $client;
  13. private string $baseUrl = ''; // 修改为实际运行的服务器地址
  14. public function setUp(): void
  15. { parent::setUp();
  16. $this->baseUrl=env('UNITTEST_URL','http://localhost:8000');
  17. $this->client = new Client([
  18. 'base_uri' => $this->baseUrl,
  19. 'timeout' => 5.0,
  20. 'http_errors' => false,
  21. 'verify' => false // 禁用 SSL 验证
  22. ]);
  23. Log::info('测试开始,设置客户端配置', [
  24. 'base_uri' => $this->baseUrl
  25. ]);
  26. }
  27. /**
  28. * 测试 Hello 模块的 AreYouOk 请求
  29. */
  30. public function testHelloAreYouOk()
  31. {
  32. Log::info('准备 Hello/AreYouOk 测试数据');
  33. // 1. 准备 Protobuf 请求数据
  34. $areYouOk = new Request\RequestHello\ResponseHelloAreYouOk();
  35. $areYouOk->setMsg("你好".uniqid());
  36. $areYouOk->setTimes(time());
  37. $requestData = $areYouOk->serializeToString();
  38. Log::info('序列化请求数据完成', [
  39. 'data_length' => strlen($requestData)
  40. ]);
  41. // 2. 发送真实的 HTTP 请求
  42. Log::info('发送 HTTP 请求');
  43. $response = $this->client->post('/api/protobuf', [
  44. 'body' => $requestData,
  45. 'headers' => [
  46. 'Content-Type' => 'application/x-protobuf',
  47. 'Accept' => 'application/x-protobuf'
  48. ]
  49. ]);
  50. Log::info('收到 HTTP 响应', [
  51. 'status_code' => $response->getStatusCode(),
  52. 'headers' => $response->getHeaders()
  53. ]);
  54. // 3. 验证 HTTP 响应状态码
  55. $this->assertEquals(200, $response->getStatusCode());
  56. // 4. 解析响应数据
  57. $responseContent = $response->getBody()->getContents();
  58. Log::info('获取响应内容', [
  59. 'content_length' => strlen($responseContent)
  60. ]);
  61. $protoResponse = new Response();
  62. $protoResponse->mergeFromString($responseContent);
  63. // 5. 验证基本响应字段
  64. $this->assertEquals(RESPONSE_CODE::OK, $protoResponse->getCode());
  65. $runUnid = $protoResponse->getRunUnid();
  66. $this->assertNotEmpty($runUnid);
  67. $this->assertGreaterThanOrEqual(0, $protoResponse->getRunMs());
  68. // 6. 验证请求日志记录
  69. $requestLog = RequestLog::where('request_unid', $runUnid)->first();
  70. $this->assertNotNull($requestLog);
  71. $this->assertEquals('api/protobuf', $requestLog->path);
  72. $this->assertEquals('POST', $requestLog->method);
  73. $this->assertNotEmpty($requestLog->headers);
  74. $this->assertNotEmpty($requestLog->ipaddress);
  75. $this->assertNotEmpty($requestLog->host);
  76. $this->assertEquals($protoResponse->serializeToJsonString(), $requestLog->response);
  77. $this->assertEquals($protoResponse->getRunMs(), $requestLog->run_ms);
  78. // 6. 验证业务响应数据
  79. $this->assertTrue($protoResponse->hasHello());
  80. $helloResponse = $protoResponse->getHello();
  81. $this->assertTrue($helloResponse->hasAreYouOk());
  82. $areYouOkResponse = $helloResponse->getAreYouOk();
  83. $this->assertStringStartsWith( $areYouOk->getMsg(),$areYouOkResponse->getMsg());
  84. $this->assertEquals($request->getHello()->getAreYouOk()->getTimes(), $areYouOkResponse->getTimes());
  85. Log::info('测试完成');
  86. }
  87. /**
  88. * 测试 Hello 模块的 AreYouOk 请求, Validation错误
  89. */
  90. public function testHelloAreYouOk1()
  91. {
  92. Log::info('准备 Hello/AreYouOk 测试数据');
  93. // 1. 准备 Protobuf 请求数据
  94. $areYouOk = new Request\RequestHello\RequestHelloAreYouOk();
  95. $areYouOk->setMsg("你好".uniqid());
  96. $areYouOk->setTimes(1);
  97. $hello = new Request\RequestHello();
  98. $hello->setAreYouOk($areYouOk);
  99. $request = new Request();
  100. $request->setHello($hello);
  101. $requestData = $request->serializeToString();
  102. Log::info('序列化请求数据完成', [
  103. 'data_length' => strlen($requestData)
  104. ]);
  105. // 2. 发送真实的 HTTP 请求
  106. Log::info('发送 HTTP 请求');
  107. $response = $this->client->post('/api/protobuf', [
  108. 'body' => $requestData,
  109. 'headers' => [
  110. 'Content-Type' => 'application/x-protobuf',
  111. 'Accept' => 'application/x-protobuf'
  112. ]
  113. ]);
  114. Log::info('收到 HTTP 响应', [
  115. 'status_code' => $response->getStatusCode(),
  116. 'headers' => $response->getHeaders()
  117. ]);
  118. // 3. 验证 HTTP 响应状态码
  119. $this->assertEquals(200, $response->getStatusCode());
  120. // 4. 解析响应数据
  121. $responseContent = $response->getBody()->getContents();
  122. Log::info('获取响应内容', [
  123. 'content_length' => strlen($responseContent)
  124. ]);
  125. $protoResponse = new Response();
  126. $protoResponse->mergeFromString($responseContent);
  127. Log::info('解析响应数据完成', [
  128. 'response_code' => $protoResponse->getCode(),
  129. 'run_ms' => $protoResponse->getRunMs(),
  130. 'json'=>$protoResponse->serializeToJsonString()
  131. ]);
  132. // 5. 验证基本响应字段
  133. $this->assertEquals(RESPONSE_CODE::VALIDATE_ERROR, $protoResponse->getCode());
  134. // 6. 验证错误日志记录
  135. $requestLog = RequestLog::where('request_unid', $protoResponse->getRunUnid())->first();
  136. $this->assertNotNull($requestLog);
  137. $this->assertNotEmpty($requestLog->error);
  138. Log::info('测试完成');
  139. }
  140. /**
  141. * 测试msg不存在数值
  142. * @return void
  143. * @throws \GuzzleHttp\Exception\GuzzleException
  144. */
  145. public function testHelloAreYouOk2()
  146. {
  147. Log::info('准备 Hello/AreYouOk 测试数据');
  148. // 1. 准备 Protobuf 请求数据
  149. $areYouOk = new Request\RequestHello\RequestHelloAreYouOk();
  150. $areYouOk->setTimes(100);
  151. $hello = new Request\RequestHello();
  152. $hello->setAreYouOk($areYouOk);
  153. $request = new Request();
  154. $request->setHello($hello);
  155. $requestData = $request->serializeToString();
  156. Log::info('序列化请求数据完成', [
  157. 'data_length' => strlen($requestData)
  158. ]);
  159. // 2. 发送真实的 HTTP 请求
  160. Log::info('发送 HTTP 请求');
  161. $response = $this->client->post('/api/protobuf', [
  162. 'body' => $requestData,
  163. 'headers' => [
  164. 'Content-Type' => 'application/x-protobuf',
  165. 'Accept' => 'application/x-protobuf'
  166. ]
  167. ]);
  168. Log::info('收到 HTTP 响应', [
  169. 'status_code' => $response->getStatusCode(),
  170. 'headers' => $response->getHeaders()
  171. ]);
  172. // 3. 验证 HTTP 响应状态码
  173. $this->assertEquals(200, $response->getStatusCode());
  174. // 4. 解析响应数据
  175. $responseContent = $response->getBody()->getContents();
  176. Log::info('获取响应内容', [
  177. 'content_length' => strlen($responseContent)
  178. ]);
  179. $protoResponse = new Response();
  180. $protoResponse->mergeFromString($responseContent);
  181. Log::info('解析响应数据完成', [
  182. 'response_code' => $protoResponse->getCode(),
  183. 'run_ms' => $protoResponse->getRunMs(),
  184. 'json'=>$protoResponse->serializeToJsonString()
  185. ]);
  186. // 5. 验证基本响应字段
  187. $this->assertEquals(RESPONSE_CODE::VALIDATE_ERROR, $protoResponse->getCode());
  188. // 6. 验证错误日志记录
  189. $requestLog = RequestLog::where('request_unid', $protoResponse->getRunUnid())->first();
  190. $this->assertNotNull($requestLog);
  191. $this->assertNotEmpty($requestLog->error);
  192. Log::info('测试完成');
  193. }
  194. /**
  195. * 测试无效的请求数据
  196. */
  197. public function testInvalidRequest()
  198. {
  199. Log::info('开始测试无效请求');
  200. // 1. 发送无效数据
  201. $response = $this->client->post('/api/protobuf', [
  202. 'body' => 'invalid data',
  203. 'headers' => [
  204. 'Content-Type' => 'application/x-protobuf'
  205. ]
  206. ]);
  207. Log::info('收到无效请求响应', [
  208. 'status_code' => $response->getStatusCode()
  209. ]);
  210. // 2. 验证 HTTP 响应状态码
  211. $this->assertEquals(200, $response->getStatusCode());
  212. // 3. 解析响应数据
  213. $protoResponse = new Response();
  214. $protoResponse->mergeFromString($response->getBody()->getContents());
  215. // 4. 验证错误响应
  216. $this->assertEquals(RESPONSE_CODE::SERVER_ERROR, $protoResponse->getCode());
  217. // 5. 验证错误日志记录
  218. $requestLog = RequestLog::where('request_unid', $protoResponse->getRunUnid())->first();
  219. $this->assertNotNull($requestLog);
  220. $this->assertNotEmpty($requestLog->error);
  221. Log::info('无效请求测试完成');
  222. }
  223. /**
  224. * 测试空请求数据
  225. */
  226. public function testEmptyRequest()
  227. {
  228. Log::info('开始测试空请求');
  229. // 1. 发送空数据
  230. $response = $this->client->post('/api/protobuf', [
  231. 'body' => '',
  232. 'headers' => [
  233. 'Content-Type' => 'application/x-protobuf'
  234. ]
  235. ]);
  236. Log::info('收到空请求响应', [
  237. 'status_code' => $response->getStatusCode()
  238. ]);
  239. // 2. 验证 HTTP 响应状态码
  240. $this->assertEquals(200, $response->getStatusCode());
  241. // 3. 解析响应数据
  242. $protoResponse = new Response();
  243. $protoResponse->mergeFromString($response->getBody()->getContents());
  244. // 4. 验证错误响应
  245. $this->assertEquals(RESPONSE_CODE::SERVER_ERROR, $protoResponse->getCode());
  246. // 5. 验证错误日志记录
  247. $requestLog = RequestLog::where('request_unid', $protoResponse->getRunUnid())->first();
  248. $this->assertNotNull($requestLog);
  249. $this->assertNotEmpty($requestLog->error);
  250. Log::info('空请求测试完成');
  251. }
  252. /**
  253. * 测试未知模块
  254. */
  255. public function testUnknownModule()
  256. {
  257. Log::info('开始测试未知模块请求');
  258. // 1. 准备一个空的请求对象
  259. $request = new Request();
  260. $requestData = $request->serializeToString();
  261. // 2. 发送请求
  262. $response = $this->client->post('/api/protobuf', [
  263. 'body' => $requestData,
  264. 'headers' => [
  265. 'Content-Type' => 'application/x-protobuf'
  266. ]
  267. ]);
  268. Log::info('收到未知模块响应', [
  269. 'status_code' => $response->getStatusCode()
  270. ]);
  271. // 3. 验证 HTTP 响应状态码
  272. $this->assertEquals(200, $response->getStatusCode());
  273. // 4. 解析响应数据
  274. $protoResponse = new Response();
  275. $protoResponse->mergeFromString($response->getBody()->getContents());
  276. // 5. 验证错误响应
  277. $this->assertEquals(RESPONSE_CODE::SERVER_ERROR, $protoResponse->getCode());
  278. // 6. 验证错误日志记录
  279. $requestLog = RequestLog::where('request_unid', $protoResponse->getRunUnid())->first();
  280. $this->assertNotNull($requestLog);
  281. $this->assertNotEmpty($requestLog->error);
  282. Log::info('未知模块测试完成');
  283. }
  284. }