mongodb にレコードを挿入するアプリケーションを作成しようとしています。
最初に私のテストを見てください:
test('Password test failed, not strong enough.', () {
Account.create({'name': 'eric', 'email': 'koston@mail.com', 'password': 'Test'})
.catchError((err) {
expect(err, throwsA(new isInstanceOf<DuplicateError>()));
});
});
パスワードの強度が十分でないため、このテストは失敗するはずです。そして、レコードを挿入しようとするコード。
static Future<String> create(Map account) {
var completer = new Completer();
String hashed_password;
var self = new Account();
if(self._signUpKeys.length != account.length) {
return completer.completeError(new LengthError(I18n.instance.getTextByMap('TEXT1')));
}
for(var singUpKey in self._signUpKeys) {
if (!account.containsKey(singUpKey)) {
return completer.completeError(new ArgumentError(I18n.instance.getTextByMap('TEXT1')));
}
}
// Try to find duplication
Future.wait([findAccountByField('name', account['name']),
findAccountByField('email', account['email'])])
.then((Iterable<Map<String, String>> lists) {
// Check of any duplications
lists.forEach((value){
value.forEach((String key, String value) {
switch(key) {
case('name'):
return completer.completeError(new DuplicateError(
I18n.instance.getTextWithMarker('TEXT2', {'&1': value})));
case('email'):
return completer.completeError(new DuplicateError(
I18n.instance.getTextWithMarker('TEXT3', {'&1': value})));
}
});
hashed_password = Account.generateHashPassword(account['password']);
self._insert(self._fillDbFields(name: account['name'], email: account['email'], hashed_password: hashed_password,
created_at: new DateTime.now(), activated: false))
.then((result) => completer.complete(result));
});
})
.catchError((err) {
completer.completeError(err);
});
return completer.future;
}
パスワードがセキュリティ要件に従っていないため、この割り当てはエラーをスローします。
hashed_password = Account.generateHashPassword(account['password']);
この部分はエラーをキャッチして完了する必要があります。
.catchError((err) {
completer.completeError(err);
});
しかし、テストでは NoSuchMethodError が発生しました。ここで、エラー オブジェクトがテストに渡されないのはなぜですか? 私はここで何を間違っていますか?