Fix value equality test to avoid toString

- The where statement can be something like {toString: 'not a function'}
- Avoid object string comparison

Signed-off-by: Raymond Feng <enjoyjava@gmail.com>
This commit is contained in:
Raymond Feng 2020-10-30 09:15:39 -07:00
parent 1e9ac69f2c
commit 454fd0f1b2
2 changed files with 44 additions and 4 deletions

View File

@ -613,8 +613,8 @@ function applyFilter(filter) {
return value.match(example);
}
if (example === undefined) {
return undefined;
if (example == null) {
return value == null;
}
if (typeof example === 'object' && example !== null) {
@ -682,9 +682,13 @@ function applyFilter(filter) {
return true;
}
}
// compare date
if (example instanceof Date && value instanceof Date) {
return example.getTime() === value.getTime();
}
// not strict equality
return (example !== null ? example.toString() : example) ==
(value != null ? value.toString() : value);
return example == value;
}
/**

View File

@ -339,6 +339,15 @@ describe('Memory connector', function() {
});
});
it('should successfully extract 1 user (Lennon) from the db by date', function(done) {
User.find({where: {birthday: new Date('1980-12-08')}},
function(err, users) {
should(users.length).be.equal(1);
should(users[0].name).be.equal('John Lennon');
done();
});
});
it('should successfully extract 2 users from the db', function(done) {
User.find({where: {birthday: {between: [new Date(1940, 0), new Date(1990, 0)]}}},
function(err, users) {
@ -565,6 +574,33 @@ describe('Memory connector', function() {
});
});
it('should handle constructor.prototype', function(done) {
User.find({where: {'constructor.prototype': {toString: 'Not a function'}}}, function(err,
users) {
should.not.exist(err);
users.length.should.equal(0);
done();
});
});
it('should handle constructor/prototype', function(done) {
User.find({where: {constructor: {prototype: {toString: 'Not a function'}}}}, function(err,
users) {
should.not.exist(err);
users.length.should.equal(0);
done();
});
});
it('should handle toString', function(done) {
User.find({where: {toString: 'Not a function'}}, function(err,
users) {
should.not.exist(err);
users.length.should.equal(0);
done();
});
});
function seed(done) {
const beatles = [
{