添加有效性規(guī)則
- 有效性規(guī)則可以避免我們向數(shù)據(jù)庫中添加無用的信息:
- 有效的用戶必須有名字
- 名字不少于3個字符。
打開user.js文件:
const UserSchema = new Schema({
name: String,
postCount: Number
});
添加規(guī)則:有效的用戶必須有名字
const UserSchema = new Schema({
name: {
type: String,
required: [true, 'Name is required.'] //向未命名的用戶傳遞信息
},
postCount: Number
});
規(guī)則1的有效性測試
在test中添加validation_test.js文件:
const assert = require('assert');
const User = require('../src/user');
describe('Validation records', () => {
it('requires a user name', () => {
const user = new User({name : undefined});
const validationResult = user.validateSync(); //validateSync()函數(shù)在測試有效性時,會同時返回有效性信息
// user.validate((validationResult) => {//validate()不會返回有效性信息,所以我們需要一個回調(diào)來傳遞有效性信息
// });
console.log(validationResult);
});
});
返回的有效信息可以看做一個object,所以我們要獲取我們需要的信息從而使用斷言:
const assert = require('assert');
const User = require('../src/user');
describe('Validation records', () => {
it('requires a user name', (done) => {
const user = new User({name : undefined});
const validationResult = user.validateSync(); //validateSync()函數(shù)在測試有效性時,會同時返回有效性信息
// user.validate((validationResult) => {//validate()不會返回有效性信息,所以我們需要一個回調(diào)來傳遞有效性信息
// });
//console.log(validationResult);
const message = validationResult.errors.name.message;
console.log(message);
assert(message === 'Name is required.');
done();
});
});
使用validate添加規(guī)則:名字不少于3個字符
打開user.js文件:
validate: {
//把validator對象賦值成一個函數(shù),函數(shù)參數(shù)為name屬性
validator: (name) => name.length > 2,
//當(dāng)validator檢測到錯誤的時候,返回message對象
message: 'Name must be longer than two charecters.'
},
規(guī)則2的有效性測試
在validation_test.js里面添加新的測試:
it('requires a user\'s name longer then two characters', (done) => {
const user = new User({name : 'Al'});
const validationResult = user.validateSync();
const {message} = validationResult.errors.name;
console.log(message);
assert(message === 'Name must be longer than two charecters.');
done();
});