trabajo-afectivo/public/assets/tests/model.js

240 lines
6.7 KiB
JavaScript

window.onload = function() {
// search
test( "model search tests", function() {
App.TicketPriority.refresh( [
{
id: 1,
name: '1 low',
note: 'some note 1',
active: true,
created_at: '2014-06-10T11:17:34.000Z',
},
{
id: 2,
name: '2 normal',
note: 'some note 2',
active: false,
created_at: '2014-06-10T10:17:33.000Z',
},
{
id: 3,
name: '3 high',
note: 'some note 3',
active: true,
created_at: '2014-06-10T10:17:44.000Z',
},
{
id: 4,
name: '4 very high',
note: 'some note 4',
active: true,
created_at: '2014-06-10T10:17:54.000Z',
},
] )
priorities = App.TicketPriority.search({sortBy:'created_at', order: 'ASC'})
equal('2 normal', priorities[0].name, 'check 1 entry')
equal('3 high', priorities[1].name, 'check 2 entry')
equal('4 very high', priorities[2].name, 'check 3 entry')
equal('1 low', priorities[3].name, 'check 4 entry')
equal(undefined, priorities[4], 'check 5 entry')
priorities = App.TicketPriority.search({sortBy:'created_at', order: 'DESC'})
equal('1 low', priorities[0].name, 'check 4 entry')
equal('4 very high', priorities[1].name, 'check 3 entry')
equal('3 high', priorities[2].name, 'check 2 entry')
equal('2 normal', priorities[3].name, 'check 1 entry')
equal(undefined, priorities[4], 'check 5 entry')
});
// model
test( "model loadAssets tests - 1", function() {
window.refreshCounter1 = 0
var callback1 = function(state, triggerType) {
window.refreshCounter1 = window.refreshCounter1 + 1
equal(state.id, 9999, 'id check')
if (window.refreshCounter1 == 1) {
equal('full', triggerType, 'trigger type check')
}
else {
equal('refresh', triggerType, 'trigger type check')
}
if ( window.refreshCounter1 == 1 ) {
App.Collection.loadAssets({
TicketState: {
9999: {
name: 'some some name', id: 9999, updated_at: "2014-11-07T23:43:08.000Z"
}
}
})
}
if ( window.refreshCounter1 == 2 ) {
App.Collection.loadAssets({
TicketState: {
9999: {
name: 'some some name', id: 9999, updated_at: "2014-11-07T23:43:08.000Z"
}
}
})
}
}
App.Collection.loadAssets({
TicketState: {
9999: {
name: 'some some name', id: 9999, updated_at: "2014-11-06T23:43:08.000Z"
}
}
})
// do not force, but bild on every change/loadAssets
App.TicketState.full(9999, callback1, false, true)
});
App.Delay.set( function() {
test( "model loadAssets tests - 1 / check refresh counter", function() {
equal(window.refreshCounter1, 2, 'check refresh counter')
});
},
1000
);
test( "model loadAssets tests - 2", function() {
window.refreshCounter2 = 0
var callback2 = function(state, triggerType) {
window.refreshCounter2 = window.refreshCounter2 + 1
equal(state.id, 10000, 'id check')
if (window.refreshCounter2 == 1) {
equal('full', triggerType, 'trigger type check')
}
else {
equal('refresh', triggerType, 'trigger type check')
}
if ( window.refreshCounter2 == 1 ) {
App.Collection.loadAssets({
TicketState: {
10000: {
name: 'some some name', id: 10000, updated_at: "2014-11-07T23:43:08.000Z"
}
}
})
}
if ( window.refreshCounter2 == 2 ) {
App.Collection.loadAssets({
TicketState: {
10000: {
name: 'some some name', id: 10000, updated_at: "2014-11-05T23:43:08.000Z"
}
}
})
}
}
App.Collection.loadAssets({
TicketState: {
10000: {
name: 'some some name', id: 10000, updated_at: "2014-11-06T23:43:08.000Z"
}
}
})
// do not force, but bild on every change/loadAssets
App.TicketState.full(10000, callback2, false, true)
});
App.Delay.set( function() {
test( "model loadAssets tests - 2 / check refresh counter", function() {
equal(window.refreshCounter2, 2, 'check refresh counter')
});
},
1200
);
test( "model loadAssets tests - 3", function() {
window.refreshCounter3 = 0
var callback3 = function(state, triggerType) {
window.refreshCounter3 = window.refreshCounter3 + 1
equal(state.id, 10001, 'id check')
if (window.refreshCounter3 == 1) {
equal('full', triggerType, 'trigger type check')
}
else {
equal('refresh', triggerType, 'trigger type check')
}
if ( window.refreshCounter3 == 1 ) {
App.Collection.loadAssets({
TicketState: {
10001: {
name: 'some some name', id: 10001, updated_at: "2014-11-07T23:43:08.000Z"
}
}
})
}
if ( window.refreshCounter3 == 2 ) {
App.Collection.loadAssets({
TicketState: {
10001: {
name: 'some some name', id: 10001, updated_at: "2014-11-08T23:43:08.000Z"
}
}
})
}
}
App.Collection.loadAssets({
TicketState: {
10001: {
name: 'some some name', id: 10001, updated_at: "2014-11-06T23:43:08.000Z"
}
}
})
// do not force, but bild on every change/loadAssets
App.TicketState.full(10001, callback3, false, true)
});
App.Delay.set( function() {
test( "model loadAssets tests - 3 / check refresh counter", function() {
equal(window.refreshCounter3, 3, 'check refresh counter')
});
},
1400
);
test("updateAttributes will change existing attributes and add new ones", function() {
App.Ticket.resetAttributes();
var attributesBefore = _.clone(App.Ticket.configure_attributes);
var updateAttribute = _.clone(attributesBefore[0]);
updateAttribute['new_option_1239393'] = 1;
App.Ticket.updateAttributes([
updateAttribute,
{
name: 'new_attribute_1010101',
display: 'New Attribute',
tag: 'input',
readonly: 1,
},
]);
var attributesAfterUpdate = _.clone(App.Ticket.configure_attributes);
equal(attributesAfterUpdate.length, attributesBefore.length + 1, 'new attributes list contains 1 more elements')
equal(attributesAfterUpdate[attributesAfterUpdate.length - 1]['name'], 'new_attribute_1010101', 'new attributes list contains the new element')
equal(attributesAfterUpdate[0]['new_option_1239393'], 1, 'first element of the new attributes got updated with the new option')
App.Ticket.resetAttributes();
var attributesAfterReset = _.clone(App.Ticket.configure_attributes);
equal(attributesAfterReset.length, attributesBefore.length, 'new attributes list has the same elements after reset')
equal(attributesAfterReset[0]['new_option_1239393'], undefined, 'first element of the new attributes has no attribute new_option_1239393')
});
}