2
0

test_fs_namespace.c 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317
  1. /*
  2. This file is part of GNUnet.
  3. Copyright (C) 2005-2013 GNUnet e.V.
  4. GNUnet is free software: you can redistribute it and/or modify it
  5. under the terms of the GNU Affero General Public License as published
  6. by the Free Software Foundation, either version 3 of the License,
  7. or (at your option) any later version.
  8. GNUnet is distributed in the hope that it will be useful, but
  9. WITHOUT ANY WARRANTY; without even the implied warranty of
  10. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  11. Affero General Public License for more details.
  12. You should have received a copy of the GNU Affero General Public License
  13. along with this program. If not, see <http://www.gnu.org/licenses/>.
  14. SPDX-License-Identifier: AGPL3.0-or-later
  15. */
  16. /**
  17. * @file fs/test_fs_namespace.c
  18. * @brief Test for fs_namespace.c
  19. * @author Christian Grothoff
  20. */
  21. #include "platform.h"
  22. #include "gnunet_util_lib.h"
  23. #include "gnunet_testing_lib.h"
  24. #include "gnunet_fs_service.h"
  25. static struct GNUNET_CRYPTO_EcdsaPublicKey nsid;
  26. static struct GNUNET_FS_Uri *sks_expect_uri;
  27. static struct GNUNET_FS_Uri *ksk_expect_uri;
  28. static struct GNUNET_FS_Handle *fs;
  29. static struct GNUNET_FS_SearchContext *sks_search;
  30. static struct GNUNET_FS_SearchContext *ksk_search;
  31. static struct GNUNET_SCHEDULER_Task * kill_task;
  32. static int update_started;
  33. static int err;
  34. static void
  35. abort_ksk_search_task (void *cls)
  36. {
  37. if (ksk_search != NULL)
  38. {
  39. GNUNET_FS_search_stop (ksk_search);
  40. ksk_search = NULL;
  41. if (sks_search == NULL)
  42. {
  43. GNUNET_FS_stop (fs);
  44. if (NULL != kill_task)
  45. GNUNET_SCHEDULER_cancel (kill_task);
  46. }
  47. }
  48. }
  49. static void
  50. abort_sks_search_task (void *cls)
  51. {
  52. if (sks_search == NULL)
  53. return;
  54. GNUNET_FS_search_stop (sks_search);
  55. sks_search = NULL;
  56. if (ksk_search == NULL)
  57. {
  58. GNUNET_FS_stop (fs);
  59. if (NULL != kill_task)
  60. GNUNET_SCHEDULER_cancel (kill_task);
  61. }
  62. }
  63. static void
  64. do_timeout (void *cls)
  65. {
  66. err = 1;
  67. FPRINTF (stderr, "%s", "Operation timed out\n");
  68. kill_task = NULL;
  69. abort_sks_search_task (NULL);
  70. abort_ksk_search_task (NULL);
  71. }
  72. static void *
  73. progress_cb (void *cls, const struct GNUNET_FS_ProgressInfo *event)
  74. {
  75. switch (event->status)
  76. {
  77. case GNUNET_FS_STATUS_SEARCH_RESULT:
  78. if (sks_search == event->value.search.sc)
  79. {
  80. if (!GNUNET_FS_uri_test_equal
  81. (sks_expect_uri, event->value.search.specifics.result.uri))
  82. {
  83. FPRINTF (stderr, "%s", "Wrong result for sks search!\n");
  84. err = 1;
  85. }
  86. /* give system 1ms to initiate update search! */
  87. GNUNET_SCHEDULER_add_delayed (GNUNET_TIME_UNIT_MILLISECONDS,
  88. &abort_sks_search_task, NULL);
  89. }
  90. else if (ksk_search == event->value.search.sc)
  91. {
  92. if (!GNUNET_FS_uri_test_equal
  93. (ksk_expect_uri, event->value.search.specifics.result.uri))
  94. {
  95. FPRINTF (stderr, "%s", "Wrong result for ksk search!\n");
  96. err = 1;
  97. }
  98. GNUNET_SCHEDULER_add_now (&abort_ksk_search_task, NULL);
  99. }
  100. else
  101. {
  102. FPRINTF (stderr, "%s", "Unexpected search result received!\n");
  103. GNUNET_break (0);
  104. }
  105. break;
  106. case GNUNET_FS_STATUS_SEARCH_ERROR:
  107. FPRINTF (stderr, "Error searching file: %s\n",
  108. event->value.search.specifics.error.message);
  109. if (sks_search == event->value.search.sc)
  110. GNUNET_SCHEDULER_add_now (&abort_sks_search_task, NULL);
  111. else if (ksk_search == event->value.search.sc)
  112. GNUNET_SCHEDULER_add_now (&abort_ksk_search_task, NULL);
  113. else
  114. GNUNET_break (0);
  115. break;
  116. case GNUNET_FS_STATUS_SEARCH_START:
  117. GNUNET_assert ((NULL == event->value.search.cctx) ||
  118. (0 == strcmp ("sks_search", event->value.search.cctx)) ||
  119. (0 == strcmp ("ksk_search", event->value.search.cctx)));
  120. if (NULL == event->value.search.cctx)
  121. {
  122. GNUNET_assert (0 == strcmp ("sks_search", event->value.search.pctx));
  123. update_started = GNUNET_YES;
  124. }
  125. GNUNET_assert (1 == event->value.search.anonymity);
  126. break;
  127. case GNUNET_FS_STATUS_SEARCH_RESULT_STOPPED:
  128. return NULL;
  129. case GNUNET_FS_STATUS_SEARCH_STOPPED:
  130. return NULL;
  131. default:
  132. FPRINTF (stderr, "Unexpected event: %d\n", event->status);
  133. break;
  134. }
  135. return event->value.search.cctx;
  136. }
  137. static void
  138. publish_cont (void *cls, const struct GNUNET_FS_Uri *ksk_uri, const char *emsg)
  139. {
  140. char *msg;
  141. struct GNUNET_FS_Uri *sks_uri;
  142. char sbuf[1024];
  143. char buf[1024];
  144. char *ret;
  145. if (NULL != emsg)
  146. {
  147. FPRINTF (stderr, "Error publishing: %s\n", emsg);
  148. err = 1;
  149. GNUNET_FS_stop (fs);
  150. return;
  151. }
  152. ret = GNUNET_STRINGS_data_to_string (&nsid, sizeof (nsid), buf, sizeof (buf));
  153. GNUNET_assert (NULL != ret);
  154. ret[0] = '\0';
  155. GNUNET_snprintf (sbuf, sizeof (sbuf), "gnunet://fs/sks/%s/this", buf);
  156. sks_uri = GNUNET_FS_uri_parse (sbuf, &msg);
  157. if (NULL == sks_uri)
  158. {
  159. FPRINTF (stderr, "failed to parse URI `%s': %s\n", sbuf, msg);
  160. err = 1;
  161. GNUNET_FS_stop (fs);
  162. GNUNET_free_non_null (msg);
  163. return;
  164. }
  165. ksk_search =
  166. GNUNET_FS_search_start (fs, ksk_uri, 1, GNUNET_FS_SEARCH_OPTION_NONE,
  167. "ksk_search");
  168. sks_search =
  169. GNUNET_FS_search_start (fs, sks_uri, 1, GNUNET_FS_SEARCH_OPTION_NONE,
  170. "sks_search");
  171. GNUNET_FS_uri_destroy (sks_uri);
  172. }
  173. static void
  174. sks_cont (void *cls, const struct GNUNET_FS_Uri *uri, const char *emsg)
  175. {
  176. struct GNUNET_CONTAINER_MetaData *meta;
  177. struct GNUNET_FS_Uri *ksk_uri;
  178. char *msg;
  179. struct GNUNET_FS_BlockOptions bo;
  180. if (NULL == uri)
  181. {
  182. fprintf (stderr, "Error publishing: %s\n", emsg);
  183. err = 1;
  184. GNUNET_FS_stop (fs);
  185. return;
  186. }
  187. meta = GNUNET_CONTAINER_meta_data_create ();
  188. msg = NULL;
  189. ksk_uri = GNUNET_FS_uri_parse ("gnunet://fs/ksk/ns-search", &msg);
  190. GNUNET_assert (NULL == msg);
  191. ksk_expect_uri = GNUNET_FS_uri_dup (uri);
  192. bo.content_priority = 1;
  193. bo.anonymity_level = 1;
  194. bo.replication_level = 0;
  195. bo.expiration_time =
  196. GNUNET_TIME_relative_to_absolute (GNUNET_TIME_UNIT_MINUTES);
  197. GNUNET_FS_publish_ksk (fs, ksk_uri, meta, uri, &bo,
  198. GNUNET_FS_PUBLISH_OPTION_NONE, &publish_cont, NULL);
  199. GNUNET_FS_uri_destroy (ksk_uri);
  200. GNUNET_CONTAINER_meta_data_destroy (meta);
  201. }
  202. static void
  203. adv_cont (void *cls, const struct GNUNET_FS_Uri *uri, const char *emsg)
  204. {
  205. struct GNUNET_CONTAINER_MetaData *meta;
  206. struct GNUNET_CRYPTO_EcdsaPrivateKey *ns;
  207. struct GNUNET_FS_BlockOptions bo;
  208. if (NULL != emsg)
  209. {
  210. FPRINTF (stderr, "Error publishing: %s\n", emsg);
  211. err = 1;
  212. GNUNET_FS_stop (fs);
  213. return;
  214. }
  215. ns = GNUNET_CRYPTO_ecdsa_key_create ();
  216. meta = GNUNET_CONTAINER_meta_data_create ();
  217. sks_expect_uri = GNUNET_FS_uri_dup (uri);
  218. bo.content_priority = 1;
  219. bo.anonymity_level = 1;
  220. bo.replication_level = 0;
  221. bo.expiration_time =
  222. GNUNET_TIME_relative_to_absolute (GNUNET_TIME_UNIT_MINUTES);
  223. GNUNET_CRYPTO_ecdsa_key_get_public (ns, &nsid);
  224. GNUNET_FS_publish_sks (fs, ns, "this", "next", meta, uri,
  225. &bo, GNUNET_FS_PUBLISH_OPTION_NONE, &sks_cont, NULL);
  226. GNUNET_CONTAINER_meta_data_destroy (meta);
  227. GNUNET_free (ns);
  228. }
  229. static void
  230. testNamespace ()
  231. {
  232. struct GNUNET_CRYPTO_EcdsaPrivateKey *ns;
  233. struct GNUNET_FS_BlockOptions bo;
  234. struct GNUNET_CONTAINER_MetaData *meta;
  235. struct GNUNET_FS_Uri *ksk_uri;
  236. struct GNUNET_FS_Uri *sks_uri;
  237. ns = GNUNET_CRYPTO_ecdsa_key_create ();
  238. meta = GNUNET_CONTAINER_meta_data_create ();
  239. ksk_uri = GNUNET_FS_uri_parse ("gnunet://fs/ksk/testnsa", NULL);
  240. bo.content_priority = 1;
  241. bo.anonymity_level = 1;
  242. bo.replication_level = 0;
  243. bo.expiration_time =
  244. GNUNET_TIME_relative_to_absolute (GNUNET_TIME_UNIT_MINUTES);
  245. sks_uri = GNUNET_FS_uri_sks_create (&nsid, "root");
  246. GNUNET_FS_publish_ksk (fs,
  247. ksk_uri, meta, sks_uri,
  248. &bo, GNUNET_FS_PUBLISH_OPTION_NONE,
  249. &adv_cont, NULL);
  250. GNUNET_FS_uri_destroy (sks_uri);
  251. kill_task =
  252. GNUNET_SCHEDULER_add_delayed (GNUNET_TIME_UNIT_MINUTES, &do_timeout,
  253. NULL);
  254. GNUNET_FS_uri_destroy (ksk_uri);
  255. GNUNET_CONTAINER_meta_data_destroy (meta);
  256. GNUNET_free (ns);
  257. }
  258. static void
  259. run (void *cls,
  260. const struct GNUNET_CONFIGURATION_Handle *cfg,
  261. struct GNUNET_TESTING_Peer *peer)
  262. {
  263. fs = GNUNET_FS_start (cfg, "test-fs-namespace", &progress_cb, NULL,
  264. GNUNET_FS_FLAGS_NONE, GNUNET_FS_OPTIONS_END);
  265. testNamespace ();
  266. }
  267. int
  268. main (int argc, char *argv[])
  269. {
  270. if (0 != GNUNET_TESTING_peer_run ("test-fs-namespace",
  271. "test_fs_namespace_data.conf",
  272. &run, NULL))
  273. return 1;
  274. return err;
  275. }
  276. /* end of test_fs_namespace.c */