diff options
author | Vincent Petry <pvince81@owncloud.com> | 2016-01-27 10:52:00 +0100 |
---|---|---|
committer | Vincent Petry <pvince81@owncloud.com> | 2016-01-27 11:09:43 +0100 |
commit | cfba90a78dbb011ff268ec3053f15ca764939c78 (patch) | |
tree | 2c647086202268d4e62ca5e2f11ccc85151753c6 /core | |
parent | 1594371c8c0124af2469bd70b9b917bfd845ae19 (diff) | |
download | nextcloud-server-cfba90a78dbb011ff268ec3053f15ca764939c78.tar.gz nextcloud-server-cfba90a78dbb011ff268ec3053f15ca764939c78.zip |
Fix system tags proppatch with booleans
Backbone webdav adapter now converts booleans and ints to strings.
Fixed system tags to use "true" / "false" strings for booleans instead
of 1 / 0.
Diffstat (limited to 'core')
-rw-r--r-- | core/js/oc-backbone-webdav.js | 9 | ||||
-rw-r--r-- | core/js/systemtags/systemtagmodel.js | 4 | ||||
-rw-r--r-- | core/js/tests/specs/oc-backbone-webdavSpec.js | 50 |
3 files changed, 53 insertions, 10 deletions
diff --git a/core/js/oc-backbone-webdav.js b/core/js/oc-backbone-webdav.js index 24a2bb50193..7c32116f011 100644 --- a/core/js/oc-backbone-webdav.js +++ b/core/js/oc-backbone-webdav.js @@ -127,11 +127,16 @@ var key; for (key in attrs) { var changedProp = davProperties[key]; + var value = attrs[key]; if (!changedProp) { console.warn('No matching DAV property for property "' + key); - continue; + changedProp = key; } - props[changedProp] = attrs[key]; + if (_.isBoolean(value) || _.isNumber(value)) { + // convert to string + value = '' + value; + } + props[changedProp] = value; } return props; } diff --git a/core/js/systemtags/systemtagmodel.js b/core/js/systemtags/systemtagmodel.js index 62bf3a70084..b41fbdde61e 100644 --- a/core/js/systemtags/systemtagmodel.js +++ b/core/js/systemtags/systemtagmodel.js @@ -37,8 +37,8 @@ return { id: data.id, name: data.name, - userVisible: data.userVisible === true || data.userVisible === '1', - userAssignable: data.userAssignable === true || data.userAssignable === '1' + userVisible: data.userVisible === true || data.userVisible === 'true', + userAssignable: data.userAssignable === true || data.userAssignable === 'true' }; } }); diff --git a/core/js/tests/specs/oc-backbone-webdavSpec.js b/core/js/tests/specs/oc-backbone-webdavSpec.js index 8fe0b9e8297..97281e982ce 100644 --- a/core/js/tests/specs/oc-backbone-webdavSpec.js +++ b/core/js/tests/specs/oc-backbone-webdavSpec.js @@ -51,6 +51,17 @@ describe('Backbone Webdav extension', function() { davProperties: { 'firstName': '{http://owncloud.org/ns}first-name', 'lastName': '{http://owncloud.org/ns}last-name', + 'age': '{http://owncloud.org/ns}age', + 'married': '{http://owncloud.org/ns}married' + }, + parse: function(data) { + return { + id: data.id, + firstName: data.firstName, + lastName: data.lastName, + age: parseInt(data.age, 10), + married: data.married === 'true' || data.married === true + }; } }); TestCollection = OC.Backbone.Collection.extend({ @@ -111,7 +122,9 @@ describe('Backbone Webdav extension', function() { expect(davClientPropFindStub.getCall(0).args[1]) .toEqual([ '{http://owncloud.org/ns}first-name', - '{http://owncloud.org/ns}last-name' + '{http://owncloud.org/ns}last-name', + '{http://owncloud.org/ns}age', + '{http://owncloud.org/ns}married' ]); expect(davClientPropFindStub.getCall(0).args[2]) .toEqual(1); @@ -212,9 +225,20 @@ describe('Backbone Webdav extension', function() { davProperties: { 'firstName': '{http://owncloud.org/ns}first-name', 'lastName': '{http://owncloud.org/ns}last-name', + 'age': '{http://owncloud.org/ns}age', // int + 'married': '{http://owncloud.org/ns}married', // bool }, url: function() { return 'http://example.com/owncloud/remote.php/test/' + this.id; + }, + parse: function(data) { + return { + id: data.id, + firstName: data.firstName, + lastName: data.lastName, + age: parseInt(data.age, 10), + married: data.married === 'true' || data.married === true + }; } }); }); @@ -223,11 +247,15 @@ describe('Backbone Webdav extension', function() { var model = new TestModel({ id: '123', firstName: 'Hello', - lastName: 'World' + lastName: 'World', + age: 32, + married: false }); model.save({ - firstName: 'Hey' + firstName: 'Hey', + age: 33, + married: true }); expect(davClientPropPatchStub.calledOnce).toEqual(true); @@ -235,7 +263,9 @@ describe('Backbone Webdav extension', function() { .toEqual('http://example.com/owncloud/remote.php/test/123'); expect(davClientPropPatchStub.getCall(0).args[1]) .toEqual({ - '{http://owncloud.org/ns}first-name': 'Hey' + '{http://owncloud.org/ns}first-name': 'Hey', + '{http://owncloud.org/ns}age': '33', + '{http://owncloud.org/ns}married': 'true' }); expect(davClientPropPatchStub.getCall(0).args[2]['X-Requested-With']) .toEqual('XMLHttpRequest'); @@ -247,6 +277,8 @@ describe('Backbone Webdav extension', function() { expect(model.id).toEqual('123'); expect(model.get('firstName')).toEqual('Hey'); + expect(model.get('age')).toEqual(33); + expect(model.get('married')).toEqual(true); }); it('uses PROPFIND to fetch single model', function() { @@ -262,7 +294,9 @@ describe('Backbone Webdav extension', function() { expect(davClientPropFindStub.getCall(0).args[1]) .toEqual([ '{http://owncloud.org/ns}first-name', - '{http://owncloud.org/ns}last-name' + '{http://owncloud.org/ns}last-name', + '{http://owncloud.org/ns}age', + '{http://owncloud.org/ns}married' ]); expect(davClientPropFindStub.getCall(0).args[2]) .toEqual(0); @@ -277,7 +311,9 @@ describe('Backbone Webdav extension', function() { status: 'HTTP/1.1 200 OK', properties: { '{http://owncloud.org/ns}first-name': 'Hello', - '{http://owncloud.org/ns}last-name': 'World' + '{http://owncloud.org/ns}last-name': 'World', + '{http://owncloud.org/ns}age': '35', + '{http://owncloud.org/ns}married': 'true' } }] } @@ -286,6 +322,8 @@ describe('Backbone Webdav extension', function() { expect(model.id).toEqual('123'); expect(model.get('firstName')).toEqual('Hello'); expect(model.get('lastName')).toEqual('World'); + expect(model.get('age')).toEqual(35); + expect(model.get('married')).toEqual(true); }); it('makes a DELETE request to destroy model', function() { var model = new TestModel({ |