test-ip-rule.cc 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305
  1. /*************************************************************************
  2. *
  3. * Copyright (C) 2018-2024 Ruilin Peng (Nick) <[email protected]>.
  4. *
  5. * smartdns is free software: you can redistribute it and/or modify
  6. * it under the terms of the GNU General Public License as published by
  7. * the Free Software Foundation, either version 3 of the License, or
  8. * (at your option) any later version.
  9. *
  10. * smartdns is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. * GNU General Public License for more details.
  14. *
  15. * You should have received a copy of the GNU General Public License
  16. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  17. */
  18. #include "client.h"
  19. #include "dns.h"
  20. #include "include/utils.h"
  21. #include "server.h"
  22. #include "gtest/gtest.h"
  23. class IPRule : public ::testing::Test
  24. {
  25. protected:
  26. virtual void SetUp() {}
  27. virtual void TearDown() {}
  28. };
  29. TEST_F(IPRule, white_list)
  30. {
  31. smartdns::MockServer server_upstream;
  32. smartdns::MockServer server_upstream2;
  33. smartdns::Server server;
  34. server_upstream.Start("udp://0.0.0.0:61053", [](struct smartdns::ServerRequestContext *request) {
  35. if (request->qtype != DNS_T_A) {
  36. return smartdns::SERVER_REQUEST_SOA;
  37. }
  38. smartdns::MockServer::AddIP(request, request->domain.c_str(), "1.2.3.4", 611);
  39. return smartdns::SERVER_REQUEST_OK;
  40. });
  41. server_upstream2.Start("udp://0.0.0.0:62053", [](struct smartdns::ServerRequestContext *request) {
  42. if (request->qtype != DNS_T_A) {
  43. return smartdns::SERVER_REQUEST_SOA;
  44. }
  45. smartdns::MockServer::AddIP(request, request->domain.c_str(), "4.5.6.7", 611);
  46. return smartdns::SERVER_REQUEST_OK;
  47. });
  48. /* this ip will be discard, but is reachable */
  49. server.MockPing(PING_TYPE_ICMP, "1.2.3.4", 60, 10);
  50. server.Start(R"""(bind [::]:60053
  51. server udp://127.0.0.1:61053 -whitelist-ip
  52. server udp://127.0.0.1:62053 -whitelist-ip
  53. whitelist-ip 4.5.6.7/24
  54. )""");
  55. smartdns::Client client;
  56. ASSERT_TRUE(client.Query("a.com", 60053));
  57. std::cout << client.GetResult() << std::endl;
  58. ASSERT_EQ(client.GetAnswerNum(), 1);
  59. EXPECT_EQ(client.GetStatus(), "NOERROR");
  60. EXPECT_EQ(client.GetAnswer()[0].GetName(), "a.com");
  61. EXPECT_EQ(client.GetAnswer()[0].GetData(), "4.5.6.7");
  62. }
  63. TEST_F(IPRule, white_list_not_in)
  64. {
  65. smartdns::MockServer server_upstream;
  66. smartdns::MockServer server_upstream2;
  67. smartdns::Server server;
  68. server_upstream.Start("udp://0.0.0.0:61053", [](struct smartdns::ServerRequestContext *request) {
  69. if (request->qtype != DNS_T_A) {
  70. return smartdns::SERVER_REQUEST_SOA;
  71. }
  72. smartdns::MockServer::AddIP(request, request->domain.c_str(), "1.2.3.4", 611);
  73. return smartdns::SERVER_REQUEST_OK;
  74. });
  75. server_upstream2.Start("udp://0.0.0.0:62053", [](struct smartdns::ServerRequestContext *request) {
  76. if (request->qtype != DNS_T_A) {
  77. return smartdns::SERVER_REQUEST_SOA;
  78. }
  79. smartdns::MockServer::AddIP(request, request->domain.c_str(), "9.10.11.12", 611);
  80. return smartdns::SERVER_REQUEST_OK;
  81. });
  82. /* this ip will be discard, but is reachable */
  83. server.MockPing(PING_TYPE_ICMP, "1.2.3.4", 60, 10);
  84. server.Start(R"""(bind [::]:60053
  85. server udp://127.0.0.1:61053 -whitelist-ip
  86. server udp://127.0.0.1:62053 -whitelist-ip
  87. whitelist-ip 4.5.6.7/24
  88. )""");
  89. smartdns::Client client;
  90. ASSERT_TRUE(client.Query("a.com", 60053));
  91. std::cout << client.GetResult() << std::endl;
  92. ASSERT_EQ(client.GetAnswerNum(), 0);
  93. EXPECT_EQ(client.GetStatus(), "SERVFAIL");
  94. }
  95. TEST_F(IPRule, black_list)
  96. {
  97. smartdns::MockServer server_upstream;
  98. smartdns::MockServer server_upstream2;
  99. smartdns::Server server;
  100. server_upstream.Start("udp://0.0.0.0:61053", [](struct smartdns::ServerRequestContext *request) {
  101. if (request->qtype != DNS_T_A) {
  102. return smartdns::SERVER_REQUEST_SOA;
  103. }
  104. smartdns::MockServer::AddIP(request, request->domain.c_str(), "1.2.3.4", 611);
  105. return smartdns::SERVER_REQUEST_OK;
  106. });
  107. server_upstream2.Start("udp://0.0.0.0:62053", [](struct smartdns::ServerRequestContext *request) {
  108. if (request->qtype != DNS_T_A) {
  109. return smartdns::SERVER_REQUEST_SOA;
  110. }
  111. smartdns::MockServer::AddIP(request, request->domain.c_str(), "4.5.6.7", 611);
  112. return smartdns::SERVER_REQUEST_OK;
  113. });
  114. /* this ip will be discard, but is reachable */
  115. server.MockPing(PING_TYPE_ICMP, "4.5.6.7", 60, 10);
  116. server.Start(R"""(bind [::]:60053
  117. server udp://127.0.0.1:61053 -blacklist-ip
  118. server udp://127.0.0.1:62053 -blacklist-ip
  119. blacklist-ip 4.5.6.7/24
  120. )""");
  121. smartdns::Client client;
  122. ASSERT_TRUE(client.Query("a.com", 60053));
  123. std::cout << client.GetResult() << std::endl;
  124. ASSERT_EQ(client.GetAnswerNum(), 1);
  125. EXPECT_EQ(client.GetStatus(), "NOERROR");
  126. EXPECT_EQ(client.GetAnswer()[0].GetName(), "a.com");
  127. EXPECT_EQ(client.GetAnswer()[0].GetData(), "1.2.3.4");
  128. }
  129. TEST_F(IPRule, ignore_ip)
  130. {
  131. smartdns::MockServer server_upstream;
  132. smartdns::MockServer server_upstream2;
  133. smartdns::Server server;
  134. server_upstream.Start("udp://0.0.0.0:61053", [](struct smartdns::ServerRequestContext *request) {
  135. if (request->qtype != DNS_T_A) {
  136. return smartdns::SERVER_REQUEST_SOA;
  137. }
  138. smartdns::MockServer::AddIP(request, request->domain.c_str(), "1.2.3.4", 611);
  139. smartdns::MockServer::AddIP(request, request->domain.c_str(), "4.5.6.7", 611);
  140. smartdns::MockServer::AddIP(request, request->domain.c_str(), "7.8.9.10", 611);
  141. return smartdns::SERVER_REQUEST_OK;
  142. });
  143. /* this ip will be discard, but is reachable */
  144. server.MockPing(PING_TYPE_ICMP, "1.2.3.4", 60, 10);
  145. server.MockPing(PING_TYPE_ICMP, "4.5.6.7", 60, 90);
  146. server.MockPing(PING_TYPE_ICMP, "7.8.9.10", 60, 40);
  147. server.Start(R"""(bind [::]:60053
  148. server udp://127.0.0.1:61053 -blacklist-ip
  149. ignore-ip 1.2.3.0/24
  150. )""");
  151. smartdns::Client client;
  152. ASSERT_TRUE(client.Query("a.com", 60053));
  153. std::cout << client.GetResult() << std::endl;
  154. ASSERT_EQ(client.GetAnswerNum(), 1);
  155. EXPECT_EQ(client.GetStatus(), "NOERROR");
  156. EXPECT_EQ(client.GetAnswer()[0].GetName(), "a.com");
  157. EXPECT_EQ(client.GetAnswer()[0].GetData(), "7.8.9.10");
  158. }
  159. TEST_F(IPRule, ignore_ip_set)
  160. {
  161. smartdns::MockServer server_upstream;
  162. smartdns::MockServer server_upstream2;
  163. smartdns::Server server;
  164. std::string file = "/tmp/smartdns_test_ip_set.list" + smartdns::GenerateRandomString(5);
  165. std::ofstream ofs(file);
  166. ASSERT_TRUE(ofs.is_open());
  167. Defer
  168. {
  169. ofs.close();
  170. unlink(file.c_str());
  171. };
  172. server_upstream.Start("udp://0.0.0.0:61053", [](struct smartdns::ServerRequestContext *request) {
  173. if (request->qtype != DNS_T_A) {
  174. return smartdns::SERVER_REQUEST_SOA;
  175. }
  176. smartdns::MockServer::AddIP(request, request->domain.c_str(), "1.2.3.4", 611);
  177. smartdns::MockServer::AddIP(request, request->domain.c_str(), "4.5.6.7", 611);
  178. smartdns::MockServer::AddIP(request, request->domain.c_str(), "7.8.9.10", 611);
  179. return smartdns::SERVER_REQUEST_OK;
  180. });
  181. /* this ip will be discard, but is reachable */
  182. server.MockPing(PING_TYPE_ICMP, "1.2.3.4", 60, 10);
  183. server.MockPing(PING_TYPE_ICMP, "4.5.6.7", 60, 90);
  184. server.MockPing(PING_TYPE_ICMP, "7.8.9.10", 60, 40);
  185. std::string ipset_list = R"""(
  186. 1.2.3.0/24
  187. 4.5.6.0/24
  188. )""";
  189. ofs.write(ipset_list.c_str(), ipset_list.length());
  190. ofs.flush();
  191. server.Start(R"""(bind [::]:60053
  192. server udp://127.0.0.1:61053 -blacklist-ip
  193. ip-set -name ip-list -file )""" +
  194. file + R"""(
  195. ignore-ip ip-set:ip-list
  196. speed-check-mode none
  197. )""");
  198. smartdns::Client client;
  199. ASSERT_TRUE(client.Query("a.com", 60053));
  200. std::cout << client.GetResult() << std::endl;
  201. ASSERT_EQ(client.GetAnswerNum(), 1);
  202. EXPECT_EQ(client.GetStatus(), "NOERROR");
  203. EXPECT_EQ(client.GetAnswer()[0].GetName(), "a.com");
  204. EXPECT_EQ(client.GetAnswer()[0].GetData(), "7.8.9.10");
  205. }
  206. TEST_F(IPRule, ip_alias_ip_set)
  207. {
  208. smartdns::MockServer server_upstream;
  209. smartdns::MockServer server_upstream2;
  210. smartdns::Server server;
  211. std::string file = "/tmp/smartdns_test_ip_set.list" + smartdns::GenerateRandomString(5);
  212. std::string file_ip = "/tmp/smartdns_test_ip_set_ip.list" + smartdns::GenerateRandomString(5);
  213. std::ofstream ofs(file);
  214. std::ofstream ofs_ip(file_ip);
  215. ASSERT_TRUE(ofs.is_open());
  216. ASSERT_TRUE(ofs_ip.is_open());
  217. Defer
  218. {
  219. ofs.close();
  220. unlink(file.c_str());
  221. ofs_ip.close();
  222. unlink(file_ip.c_str());
  223. };
  224. server_upstream.Start("udp://0.0.0.0:61053", [](struct smartdns::ServerRequestContext *request) {
  225. if (request->qtype != DNS_T_A) {
  226. return smartdns::SERVER_REQUEST_SOA;
  227. }
  228. smartdns::MockServer::AddIP(request, request->domain.c_str(), "1.2.3.4", 611);
  229. smartdns::MockServer::AddIP(request, request->domain.c_str(), "4.5.6.7", 611);
  230. smartdns::MockServer::AddIP(request, request->domain.c_str(), "7.8.9.10", 611);
  231. return smartdns::SERVER_REQUEST_OK;
  232. });
  233. server.MockPing(PING_TYPE_ICMP, "1.2.3.4", 60, 10);
  234. server.MockPing(PING_TYPE_ICMP, "4.5.6.7", 60, 90);
  235. server.MockPing(PING_TYPE_ICMP, "7.8.9.10", 60, 40);
  236. std::string ipset_list = R"""(
  237. 1.2.3.0/24
  238. 4.5.6.0/24
  239. 7.8.9.0/24
  240. )""";
  241. ofs.write(ipset_list.c_str(), ipset_list.length());
  242. ofs.flush();
  243. std::string ipset_list_ip = R"""(
  244. 1.1.1.1
  245. )""";
  246. ofs_ip.write(ipset_list_ip.c_str(), ipset_list_ip.length());
  247. ofs_ip.flush();
  248. server.Start(R"""(bind [::]:60053
  249. server udp://127.0.0.1:61053 -blacklist-ip
  250. ip-set -name ip-list -file )""" +
  251. file + R"""(
  252. ip-set -name ip-list-ip -file )""" +
  253. file_ip + R"""(
  254. ip-alias ip-set:ip-list ip-set:ip-list-ip
  255. speed-check-mode none
  256. )""");
  257. smartdns::Client client;
  258. ASSERT_TRUE(client.Query("a.com", 60053));
  259. std::cout << client.GetResult() << std::endl;
  260. ASSERT_EQ(client.GetAnswerNum(), 1);
  261. EXPECT_EQ(client.GetStatus(), "NOERROR");
  262. EXPECT_EQ(client.GetAnswer()[0].GetName(), "a.com");
  263. EXPECT_EQ(client.GetAnswer()[0].GetData(), "1.1.1.1");
  264. }