105 lines
No EOL
2.5 KiB
D
105 lines
No EOL
2.5 KiB
D
module test.calendarwebapp.testauthenticator;
|
|
|
|
import calendarwebapp.authenticator;
|
|
|
|
import poodinis;
|
|
|
|
import unit_threaded.mock;
|
|
import unit_threaded.should;
|
|
|
|
import vibe.data.bson : Bson, BsonObjectID;
|
|
|
|
interface Collection
|
|
{
|
|
Bson[] find() @safe;
|
|
Bson findOne(string[string] query) @safe;
|
|
void insert(Bson document) @safe;
|
|
void remove(BsonObjectID[string] selector) @safe;
|
|
}
|
|
|
|
class CollectionInjector : ValueInjector!Collection
|
|
{
|
|
private:
|
|
Collection[string] collections;
|
|
|
|
public:
|
|
void add(string key, Collection collection)
|
|
{
|
|
collections[key] = collection;
|
|
}
|
|
|
|
override Collection get(string key) @safe
|
|
{
|
|
return collections[key];
|
|
}
|
|
}
|
|
|
|
@("MongoDBAuthenticator.checkUser")
|
|
@system unittest
|
|
{
|
|
auto collection = mock!Collection;
|
|
auto container = new shared DependencyContainer;
|
|
container.register!(ValueInjector!Collection, CollectionInjector);
|
|
container.resolve!CollectionInjector.add("users", collection);
|
|
container.register!(Authenticator, MongoDBAuthenticator!(Collection))(
|
|
RegistrationOption.doNotAddConcreteTypeRegistration);
|
|
|
|
auto userBson = Bson(["_id" : Bson(BsonObjectID.fromString("5988ef4ae6c19089a1a53b79")),
|
|
"username" : Bson("foo"), "passwordHash"
|
|
: Bson("$2a$10$9LBqOZV99ARiE4Nx.2b7GeYfqk2.0A32PWGu2cRGyW2hRJ0xeDfnO"), "privilege" : Bson(1)]);
|
|
|
|
collection.returnValue!"findOne"(Bson(null), userBson, userBson);
|
|
|
|
auto authenticator = container.resolve!(Authenticator);
|
|
authenticator.checkUser("", "").isNull.shouldBeTrue;
|
|
authenticator.checkUser("foo", "bar").isNull.shouldBeFalse;
|
|
authenticator.checkUser("foo", "baz").isNull.shouldBeTrue;
|
|
}
|
|
|
|
@("AuthInfo.isUser success")
|
|
@safe unittest
|
|
{
|
|
AuthInfo auth;
|
|
auth.privilege = Privilege.User;
|
|
auth.isUser.shouldBeTrue;
|
|
}
|
|
|
|
@("AuthInfo.isUser failure")
|
|
@safe unittest
|
|
{
|
|
AuthInfo auth;
|
|
auth.privilege = Privilege.None;
|
|
auth.isUser.shouldBeFalse;
|
|
}
|
|
|
|
@("AuthInfo.isAdmin success")
|
|
@safe unittest
|
|
{
|
|
AuthInfo auth;
|
|
auth.privilege = Privilege.Admin;
|
|
auth.isAdmin.shouldBeTrue;
|
|
}
|
|
|
|
@("AuthInfo.isAdmin failure")
|
|
@safe unittest
|
|
{
|
|
AuthInfo auth;
|
|
auth.privilege = Privilege.None;
|
|
auth.isAdmin.shouldBeFalse;
|
|
}
|
|
|
|
@("AuthInfo.isNone success")
|
|
@safe unittest
|
|
{
|
|
AuthInfo auth;
|
|
auth.privilege = Privilege.None;
|
|
auth.isNone.shouldBeTrue;
|
|
}
|
|
|
|
@("AuthInfo.isNone failure")
|
|
@safe unittest
|
|
{
|
|
AuthInfo auth;
|
|
auth.privilege = Privilege.User;
|
|
auth.isNone.shouldBeFalse;
|
|
} |