Merge pull request #1357 from ParsePlatform/schema-defaults
🚧 Inject the default schemas properties when loading it
This commit is contained in:
@@ -1511,5 +1511,20 @@ describe('schemas', () => {
|
|||||||
fail('should not fail');
|
fail('should not fail');
|
||||||
done();
|
done();
|
||||||
});
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it('can login when addFields is false (issue #1355)', (done) => {
|
||||||
|
setPermissionsOnClass('_User', {
|
||||||
|
'addField': {}
|
||||||
|
}).then(() => {
|
||||||
|
return Parse.User.signUp('foo', 'bar');
|
||||||
|
}).then((user) => {
|
||||||
|
expect(user.getUsername()).toBe('foo');
|
||||||
|
done()
|
||||||
|
}, (err) => {
|
||||||
|
console.error(err);
|
||||||
|
fail('should create user');
|
||||||
|
done();
|
||||||
|
})
|
||||||
})
|
})
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -263,6 +263,16 @@ class Schema {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
if (className) {
|
if (className) {
|
||||||
|
// merge with the default schema
|
||||||
|
let defaultClassData = Object.assign({}, defaultColumns._Default, defaultColumns[className]);
|
||||||
|
defaultClassData = Object.keys(defaultClassData).reduce((memo, key) => {
|
||||||
|
let type = schemaAPITypeToMongoFieldType(defaultClassData[key]).result;
|
||||||
|
if (type) {
|
||||||
|
memo[key] = type;
|
||||||
|
}
|
||||||
|
return memo;
|
||||||
|
}, {});
|
||||||
|
classData = Object.assign({}, defaultClassData, classData);
|
||||||
this.data[className] = classData;
|
this.data[className] = classData;
|
||||||
if (permsData) {
|
if (permsData) {
|
||||||
this.perms[className] = permsData;
|
this.perms[className] = permsData;
|
||||||
|
|||||||
Reference in New Issue
Block a user