Make notEqual work on relations
* ⚡ regression tests for #1349 * 🎉 fixes #1349 * Adds support for multiple constraints on the same key
This commit is contained in:
@@ -23,6 +23,105 @@ describe('Parse.Query testing', () => {
|
||||
});
|
||||
});
|
||||
|
||||
it("notEqualTo with Relation is working", function(done) {
|
||||
var user = new Parse.User();
|
||||
user.setPassword("asdf");
|
||||
user.setUsername("zxcv");
|
||||
|
||||
var user1 = new Parse.User();
|
||||
user1.setPassword("asdf");
|
||||
user1.setUsername("qwerty");
|
||||
|
||||
var user2 = new Parse.User();
|
||||
user2.setPassword("asdf");
|
||||
user2.setUsername("asdf");
|
||||
|
||||
var Cake = Parse.Object.extend("Cake");
|
||||
var cake1 = new Cake();
|
||||
var cake2 = new Cake();
|
||||
var cake3 = new Cake();
|
||||
|
||||
|
||||
user.signUp().then(function(){
|
||||
return user1.signUp();
|
||||
}).then(function(){
|
||||
return user2.signUp();
|
||||
}).then(function(){
|
||||
var relLike1 = cake1.relation("liker");
|
||||
relLike1.add([user, user1]);
|
||||
|
||||
var relDislike1 = cake1.relation("hater");
|
||||
relDislike1.add(user2);
|
||||
return cake1.save();
|
||||
}).then(function(){
|
||||
var rellike2 = cake2.relation("liker");
|
||||
rellike2.add([user, user1]);
|
||||
|
||||
var relDislike2 = cake2.relation("hater");
|
||||
relDislike2.add(user2);
|
||||
|
||||
return cake2.save();
|
||||
}).then(function(){
|
||||
var rellike3 = cake3.relation("liker");
|
||||
rellike3.add(user);
|
||||
|
||||
var relDislike3 = cake3.relation("hater");
|
||||
relDislike3.add([user1, user2]);
|
||||
return cake3.save();
|
||||
}).then(function(){
|
||||
var query = new Parse.Query(Cake);
|
||||
// User2 likes nothing so we should receive 0
|
||||
query.equalTo("liker", user2);
|
||||
return query.find().then(function(results){
|
||||
equal(results.length, 0);
|
||||
});
|
||||
}).then(function(){
|
||||
var query = new Parse.Query(Cake);
|
||||
// User1 likes two of three cakes
|
||||
query.equalTo("liker", user1);
|
||||
return query.find().then(function(results){
|
||||
// It should return 2 -> cake 1 and cake 2
|
||||
equal(results.length, 2);
|
||||
});
|
||||
}).then(function(){
|
||||
var query = new Parse.Query(Cake);
|
||||
// We want to know which cake the user1 is not appreciating -> cake3
|
||||
query.notEqualTo("liker", user1);
|
||||
return query.find().then(function(results){
|
||||
// Should return 1 -> the cake 3
|
||||
equal(results.length, 1);
|
||||
});
|
||||
}).then(function(){
|
||||
var query = new Parse.Query(Cake);
|
||||
// User2 is a hater of everything so we should receive 0
|
||||
query.notEqualTo("hater", user2);
|
||||
return query.find().then(function(results){
|
||||
equal(results.length, 0);
|
||||
});
|
||||
}).then(function(){
|
||||
var query = new Parse.Query(Cake);
|
||||
// Only cake3 is liked by user
|
||||
query.notContainedIn("liker", [user1]);
|
||||
return query.find().then(function(results){
|
||||
equal(results.length, 1);
|
||||
});
|
||||
}).then(function(){
|
||||
var query = new Parse.Query(Cake);
|
||||
// All the users
|
||||
query.containedIn("liker", [user, user1, user2]);
|
||||
// Exclude user 1
|
||||
query.notEqualTo("liker", user1);
|
||||
// Only cake3 is liked only by user1
|
||||
return query.find().then(function(results){
|
||||
equal(results.length, 1);
|
||||
let cake = results[0];
|
||||
expect(cake.id).toBe(cake3.id);
|
||||
});
|
||||
}).then(function(){
|
||||
done();
|
||||
})
|
||||
});
|
||||
|
||||
it("query with limit", function(done) {
|
||||
var baz = new TestObject({ foo: 'baz' });
|
||||
var qux = new TestObject({ foo: 'qux' });
|
||||
|
||||
Reference in New Issue
Block a user