summaryrefslogtreecommitdiff
path: root/tests/unit/mongo/sync/sync_cmd_user_remove.c
diff options
context:
space:
mode:
Diffstat (limited to 'tests/unit/mongo/sync/sync_cmd_user_remove.c')
-rw-r--r--tests/unit/mongo/sync/sync_cmd_user_remove.c92
1 files changed, 92 insertions, 0 deletions
diff --git a/tests/unit/mongo/sync/sync_cmd_user_remove.c b/tests/unit/mongo/sync/sync_cmd_user_remove.c
new file mode 100644
index 0000000..dc66063
--- /dev/null
+++ b/tests/unit/mongo/sync/sync_cmd_user_remove.c
@@ -0,0 +1,92 @@
+#include "test.h"
+#include "mongo.h"
+#include "config.h"
+
+#include <errno.h>
+#include <sys/socket.h>
+#include "libmongo-private.h"
+
+void
+test_mongo_sync_cmd_user_remove_net_secondary (void)
+{
+ mongo_sync_connection *c;
+ gboolean ret;
+
+ skip (!config.secondary_host, 1,
+ "Secondary server not configured");
+
+ c = mongo_sync_connect (config.secondary_host, config.secondary_port, TRUE);
+ mongo_sync_conn_set_auto_reconnect (c, TRUE);
+
+ mongo_sync_cmd_user_add (c, config.db, "test", "s3kr1+");
+ ret = mongo_sync_cmd_user_remove (c, config.db, "test");
+ ok (ret && mongo_sync_cmd_is_master (c),
+ "mongo_sync_cmd_user_remove() automatically reconnects to master");
+
+ mongo_sync_disconnect (c);
+
+ endskip;
+}
+
+void
+test_mongo_sync_cmd_user_remove_net (void)
+{
+ mongo_sync_connection *c;
+
+ begin_network_tests (3);
+
+ c = mongo_sync_connect (config.primary_host, config.primary_port, TRUE);
+ mongo_sync_conn_set_auto_reconnect (c, TRUE);
+
+ mongo_sync_cmd_user_add (c, config.db, "test", "s3kr1+");
+ ok (mongo_sync_cmd_user_remove (c, config.db, "test") == TRUE,
+ "mongo_sync_cmd_user_remove() works");
+
+ mongo_sync_cmd_user_add (c, config.db, "test", "s3kr1+");
+ shutdown (c->super.fd, SHUT_RDWR);
+ sleep (3);
+
+ ok (mongo_sync_cmd_user_remove (c, config.db, "test") == TRUE,
+ "mongo_sync_cmd_user_remove() automatically reconnects");
+
+ mongo_sync_disconnect (c);
+
+ test_mongo_sync_cmd_user_remove_net_secondary ();
+
+ end_network_tests ();
+}
+
+void
+test_mongo_sync_cmd_user_remove (void)
+{
+ mongo_sync_connection *c;
+
+ c = test_make_fake_sync_conn (-1, FALSE);
+
+ errno = 0;
+ ok (mongo_sync_cmd_user_remove (NULL, "test", "test") == FALSE,
+ "mongo_sync_cmd_user_remove() fails with a NULL connection");
+ cmp_ok (errno, "==", ENOTCONN,
+ "errno is set to ENOTCONN");
+
+ errno = 0;
+ ok (mongo_sync_cmd_user_remove (c, NULL, "test") == FALSE,
+ "mongo_sync_cmd_user_remove() fails with a NULL db");
+ cmp_ok (errno, "==", EINVAL,
+ "errno is set to EINVAL");
+
+ errno = 0;
+ ok (mongo_sync_cmd_user_remove (c, "test", NULL) == FALSE,
+ "mongo_sync_cmd_user_remove() fails with a NULL user");
+ cmp_ok (errno, "==", EINVAL,
+ "errno is set to EINVAL");
+
+ ok (mongo_sync_cmd_user_remove (c, "test", "test") == FALSE,
+ "mongo_sync_cmd_user_remove() fails with a bogus FD");
+
+ mongo_sync_disconnect (c);
+
+ test_mongo_sync_cmd_user_remove_net ();
+}
+
+RUN_TEST (10, mongo_sync_cmd_user_remove);