api-open-multiple-times.c 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. #include "config.h"
  2. #include "../ntdb.h"
  3. #include "tap-interface.h"
  4. #include <stdlib.h>
  5. #include "logging.h"
  6. #include "../private.h"
  7. #include "helpapi-external-agent.h"
  8. int main(int argc, char *argv[])
  9. {
  10. unsigned int i;
  11. struct ntdb_context *ntdb, *ntdb2;
  12. NTDB_DATA key = { (unsigned char *)&i, sizeof(i) };
  13. NTDB_DATA data = { (unsigned char *)&i, sizeof(i) };
  14. NTDB_DATA d = { NULL, 0 }; /* Bogus GCC warning */
  15. int flags[] = { NTDB_DEFAULT, NTDB_NOMMAP,
  16. NTDB_CONVERT, NTDB_NOMMAP|NTDB_CONVERT };
  17. plan_tests(sizeof(flags) / sizeof(flags[0]) * 30);
  18. for (i = 0; i < sizeof(flags) / sizeof(flags[0]); i++) {
  19. ntdb = ntdb_open("run-open-multiple-times.ntdb",
  20. flags[i]|MAYBE_NOSYNC,
  21. O_RDWR|O_CREAT|O_TRUNC, 0600, &tap_log_attr);
  22. ok1(ntdb);
  23. if (!ntdb)
  24. continue;
  25. ntdb2 = ntdb_open("run-open-multiple-times.ntdb",
  26. flags[i]|MAYBE_NOSYNC,
  27. O_RDWR|O_CREAT, 0600, &tap_log_attr);
  28. ok1(ntdb_check(ntdb, NULL, NULL) == 0);
  29. ok1(ntdb_check(ntdb2, NULL, NULL) == 0);
  30. ok1((flags[i] & NTDB_NOMMAP) || ntdb2->file->map_ptr);
  31. /* Store in one, fetch in the other. */
  32. ok1(ntdb_store(ntdb, key, data, NTDB_REPLACE) == 0);
  33. ok1(ntdb_fetch(ntdb2, key, &d) == NTDB_SUCCESS);
  34. ok1(ntdb_deq(d, data));
  35. free(d.dptr);
  36. /* Vice versa, with delete. */
  37. ok1(ntdb_delete(ntdb2, key) == 0);
  38. ok1(ntdb_fetch(ntdb, key, &d) == NTDB_ERR_NOEXIST);
  39. /* OK, now close first one, check second still good. */
  40. ok1(ntdb_close(ntdb) == 0);
  41. ok1((flags[i] & NTDB_NOMMAP) || ntdb2->file->map_ptr);
  42. ok1(ntdb_store(ntdb2, key, data, NTDB_REPLACE) == 0);
  43. ok1(ntdb_fetch(ntdb2, key, &d) == NTDB_SUCCESS);
  44. ok1(ntdb_deq(d, data));
  45. free(d.dptr);
  46. /* Reopen */
  47. ntdb = ntdb_open("run-open-multiple-times.ntdb",
  48. flags[i]|MAYBE_NOSYNC,
  49. O_RDWR|O_CREAT, 0600, &tap_log_attr);
  50. ok1(ntdb);
  51. ok1(ntdb_transaction_start(ntdb2) == 0);
  52. /* Anything in the other one should fail. */
  53. ok1(ntdb_fetch(ntdb, key, &d) == NTDB_ERR_LOCK);
  54. ok1(tap_log_messages == 1);
  55. ok1(ntdb_store(ntdb, key, data, NTDB_REPLACE) == NTDB_ERR_LOCK);
  56. ok1(tap_log_messages == 2);
  57. ok1(ntdb_transaction_start(ntdb) == NTDB_ERR_LOCK);
  58. ok1(tap_log_messages == 3);
  59. ok1(ntdb_chainlock(ntdb, key) == NTDB_ERR_LOCK);
  60. ok1(tap_log_messages == 4);
  61. /* Transaciton should work as normal. */
  62. ok1(ntdb_store(ntdb2, key, data, NTDB_REPLACE) == NTDB_SUCCESS);
  63. /* Now... try closing with locks held. */
  64. ok1(ntdb_close(ntdb2) == 0);
  65. ok1(ntdb_fetch(ntdb, key, &d) == NTDB_SUCCESS);
  66. ok1(ntdb_deq(d, data));
  67. free(d.dptr);
  68. ok1(ntdb_close(ntdb) == 0);
  69. ok1(tap_log_messages == 4);
  70. tap_log_messages = 0;
  71. }
  72. return exit_status();
  73. }