Skip to content

Commit

Permalink
Merge pull request #1951 from MartinNowak/mongo_errmsg
Browse files Browse the repository at this point in the history
throw useful error message on MongoDB query failures
  • Loading branch information
s-ludwig authored Oct 15, 2017
2 parents b3f5d2a + 31281f2 commit 37ba318
Showing 1 changed file with 5 additions and 5 deletions.
10 changes: 5 additions & 5 deletions mongodb/vibe/db/mongo/collection.d
Original file line number Diff line number Diff line change
Expand Up @@ -244,7 +244,7 @@ struct MongoCollection {
return 0;
});
auto ret = database.runCommand(cmd);
enforce(ret["ok"].get!double != 0, "findAndModifyExt failed.");
enforce(ret["ok"].get!double != 0, "findAndModifyExt failed: "~ret["errmsg"].opt!string);
return ret["value"];
}

Expand Down Expand Up @@ -278,7 +278,7 @@ struct MongoCollection {
cmd.count = m_name;
cmd.query = query;
auto reply = database.runCommand(cmd);
enforce(reply["ok"].opt!double == 1 || reply["ok"].opt!int == 1, "Count command failed.");
enforce(reply["ok"].opt!double == 1 || reply["ok"].opt!int == 1, "Count command failed: "~reply["errmsg"].opt!string);
switch (reply["n"].type) with (Bson.Type) {
default: assert(false, "Unsupported data type in BSON reply for COUNT");
case double_: return cast(ulong)reply["n"].get!double; // v2.x
Expand Down Expand Up @@ -320,7 +320,7 @@ struct MongoCollection {
cmd.pipeline = pipeline[0];
else cmd.pipeline.args = pipeline;
auto ret = database.runCommand(cmd);
enforce(ret["ok"].get!double == 1, "Aggregate command failed.");
enforce(ret["ok"].get!double == 1, "Aggregate command failed: "~ret["errmsg"].opt!string);
return ret["result"];
}

Expand Down Expand Up @@ -467,7 +467,7 @@ struct MongoCollection {
cmd.dropIndexes = m_name;
cmd.index = name;
auto reply = database.runCommand(cmd);
enforce(reply["ok"].get!double == 1, "dropIndex command failed.");
enforce(reply["ok"].get!double == 1, "dropIndex command failed: "~reply["errmsg"].opt!string);
}

void drop()
Expand All @@ -479,7 +479,7 @@ struct MongoCollection {
CMD cmd;
cmd.drop = m_name;
auto reply = database.runCommand(cmd);
enforce(reply["ok"].get!double == 1, "drop command failed.");
enforce(reply["ok"].get!double == 1, "drop command failed: "~reply["errmsg"].opt!string);
}
}

Expand Down

0 comments on commit 37ba318

Please sign in to comment.