Merge lp:~renatofilho/ubuntu-calendar-app/keep-event-size into lp:ubuntu-calendar-app
- keep-event-size
- Merge into trunk
Status: | Merged |
---|---|
Approved by: | Arthur Mello |
Approved revision: | 787 |
Merged at revision: | 809 |
Proposed branch: | lp:~renatofilho/ubuntu-calendar-app/keep-event-size |
Merge into: | lp:ubuntu-calendar-app |
Diff against target: |
408 lines (+217/-51) 4 files modified
NewEvent.qml (+43/-46) dateExt.js (+4/-4) tests/unittests/CMakeLists.txt (+1/-1) tests/unittests/tst_new_event.qml (+169/-0) |
To merge this branch: | bzr merge lp:~renatofilho/ubuntu-calendar-app/keep-event-size |
Related bugs: |
Reviewer | Review Type | Date Requested | Status |
---|---|---|---|
Arthur Mello (community) | Approve | ||
Jenkins Bot | continuous-integration | Approve | |
Review via email: mp+289288@code.launchpad.net |
Commit message
Make sure that event keep the same size when changing the start date.
Description of the change
Jenkins Bot (ubuntu-core-apps-jenkins-bot) wrote : | # |
- 783. By Renato Araujo Oliveira Filho
-
Trunk merged.
- 784. By Renato Araujo Oliveira Filho
-
Update NewEvent to handle null end time.
- 785. By Renato Araujo Oliveira Filho
-
created unit test for new event page.
Jenkins Bot (ubuntu-core-apps-jenkins-bot) wrote : | # |
PASSED: Continuous integration, rev:785
https:/
Executed test runs:
None: https:/
Click here to trigger a rebuild:
https:/
Arthur Mello (artmello) wrote : | # |
in line comment
- 786. By Renato Araujo Oliveira Filho
-
Typo fixed.
Jenkins Bot (ubuntu-core-apps-jenkins-bot) wrote : | # |
PASSED: Continuous integration, rev:786
https:/
Executed test runs:
None: https:/
Click here to trigger a rebuild:
https:/
- 787. By Renato Araujo Oliveira Filho
-
Trunk merged.
Jenkins Bot (ubuntu-core-apps-jenkins-bot) wrote : | # |
PASSED: Continuous integration, rev:787
https:/
Executed test runs:
None: https:/
Click here to trigger a rebuild:
https:/
Preview Diff
1 | === modified file 'NewEvent.qml' | |||
2 | --- NewEvent.qml 2016-03-23 18:53:48 +0000 | |||
3 | +++ NewEvent.qml 2016-03-28 21:19:15 +0000 | |||
4 | @@ -25,6 +25,7 @@ | |||
5 | 25 | import Ubuntu.Components.Pickers 1.0 | 25 | import Ubuntu.Components.Pickers 1.0 |
6 | 26 | import QtOrganizer 5.0 | 26 | import QtOrganizer 5.0 |
7 | 27 | import "Defines.js" as Defines | 27 | import "Defines.js" as Defines |
8 | 28 | import "dateExt.js" as DateExt | ||
9 | 28 | 29 | ||
10 | 29 | Page { | 30 | Page { |
11 | 30 | id: root | 31 | id: root |
12 | @@ -35,18 +36,22 @@ | |||
13 | 35 | 36 | ||
14 | 36 | property var date; | 37 | property var date; |
15 | 37 | property alias allDay: allDayEventCheckbox.checked | 38 | property alias allDay: allDayEventCheckbox.checked |
16 | 39 | property int eventSize: -1 | ||
17 | 38 | 40 | ||
18 | 39 | property var event:null; | 41 | property var event:null; |
19 | 40 | property var rule :null; | 42 | property var rule :null; |
20 | 41 | property var model:null; | 43 | property var model:null; |
21 | 42 | 44 | ||
24 | 43 | property var startDate; | 45 | property alias startDate: startDateTimeInput.dateTime |
25 | 44 | property var endDate; | 46 | property alias endDate: endDateTimeInput.dateTime |
26 | 45 | property alias reminderValue: eventReminder.reminderValue | 47 | property alias reminderValue: eventReminder.reminderValue |
27 | 46 | 48 | ||
28 | 47 | property alias scrollY: flickable.contentY | 49 | property alias scrollY: flickable.contentY |
29 | 48 | property bool isEdit: false | 50 | property bool isEdit: false |
30 | 49 | 51 | ||
31 | 52 | readonly property int millisecsInADay: 86400000 | ||
32 | 53 | readonly property int millisecsInAnHour: 3600000 | ||
33 | 54 | |||
34 | 50 | signal eventAdded(var event); | 55 | signal eventAdded(var event); |
35 | 51 | signal eventDeleted(var event); | 56 | signal eventDeleted(var event); |
36 | 52 | signal canceled() | 57 | signal canceled() |
37 | @@ -78,8 +83,6 @@ | |||
38 | 78 | } | 83 | } |
39 | 79 | 84 | ||
40 | 80 | function updateEventDate(date, allDay) { | 85 | function updateEventDate(date, allDay) { |
41 | 81 | root.startDate = undefined | ||
42 | 82 | root.endDate = undefined | ||
43 | 83 | setDate(date) | 86 | setDate(date) |
44 | 84 | root.allDay = allDay | 87 | root.allDay = allDay |
45 | 85 | } | 88 | } |
46 | @@ -94,18 +97,9 @@ | |||
47 | 94 | date.setHours(newDate.getHours(), newDate.getMinutes()); | 97 | date.setHours(newDate.getHours(), newDate.getMinutes()); |
48 | 95 | } | 98 | } |
49 | 96 | 99 | ||
62 | 97 | // If startDate is setted by argument we have to not change it | 100 | startDate = new Date(root.roundDate(date)) |
63 | 98 | //Set the nearest current time. | 101 | var enDateValue = new Date(root.roundDate(date)) |
64 | 99 | if (typeof(startDate) === 'undefined') | 102 | endDate = enDateValue.addMinutes(60) |
53 | 100 | startDate = new Date(root.roundDate(date)) | ||
54 | 101 | |||
55 | 102 | // If endDate is setted by argument we have to not change it | ||
56 | 103 | if (typeof(endDate) === 'undefined') { | ||
57 | 104 | endDate = new Date(root.roundDate(date)) | ||
58 | 105 | endDate.setMinutes(endDate.getMinutes() + 30) | ||
59 | 106 | endTimeInput.text = Qt.formatDateTime(endDate, Qt.locale().timeFormat(Locale.ShortFormat)); | ||
60 | 107 | } | ||
61 | 108 | |||
65 | 109 | } | 103 | } |
66 | 110 | 104 | ||
67 | 111 | function selectCalendar(collectionId) { | 105 | function selectCalendar(collectionId) { |
68 | @@ -140,9 +134,19 @@ | |||
69 | 140 | titleEdit.text = e.displayLabel; | 134 | titleEdit.text = e.displayLabel; |
70 | 141 | } | 135 | } |
71 | 142 | 136 | ||
72 | 137 | allDayEventCheckbox.checked = e.allDay; | ||
73 | 138 | |||
74 | 139 | var eventEndDate = e.endDateTime | ||
75 | 140 | if (!eventEndDate || isNaN(eventEndDate.getTime())) | ||
76 | 141 | eventEndDate = new Date(startDate) | ||
77 | 142 | |||
78 | 143 | if (e.allDay) { | 143 | if (e.allDay) { |
79 | 144 | allDayEventCheckbox.checked = true | 144 | allDayEventCheckbox.checked = true |
81 | 145 | endDate = new Date(e.endDateTime).addDays(-1); | 145 | endDate = new Date(eventEndDate).addDays(-1); |
82 | 146 | eventSize = DateExt.daysBetween(startDate, eventEndDate) * root.millisecsInADay | ||
83 | 147 | } else { | ||
84 | 148 | endDate = eventEndDate | ||
85 | 149 | eventSize = (eventEndDate.getTime() - startDate.getTime()) | ||
86 | 146 | } | 150 | } |
87 | 147 | 151 | ||
88 | 148 | if(e.location) { | 152 | if(e.location) { |
89 | @@ -153,7 +157,6 @@ | |||
90 | 153 | messageEdit.text = e.description; | 157 | messageEdit.text = e.description; |
91 | 154 | } | 158 | } |
92 | 155 | 159 | ||
93 | 156 | allDayEventCheckbox.checked = e.allDay; | ||
94 | 157 | var index = 0; | 160 | var index = 0; |
95 | 158 | 161 | ||
96 | 159 | if( e.itemType === Type.Event ) { | 162 | if( e.itemType === Type.Event ) { |
97 | @@ -309,33 +312,6 @@ | |||
98 | 309 | } | 312 | } |
99 | 310 | 313 | ||
100 | 311 | Keys.onEscapePressed: root.cancel() | 314 | Keys.onEscapePressed: root.cancel() |
101 | 312 | onStartDateChanged: { | ||
102 | 313 | if (!startDate) | ||
103 | 314 | return | ||
104 | 315 | |||
105 | 316 | startDateTimeInput.dateTime = startDate; | ||
106 | 317 | |||
107 | 318 | // set time forward to one hour | ||
108 | 319 | var time_forward = 3600000; | ||
109 | 320 | |||
110 | 321 | if (isEdit && event !== null) { | ||
111 | 322 | time_forward = event.endDateTime - event.startDateTime; | ||
112 | 323 | } | ||
113 | 324 | adjustEndDateToStartDate(time_forward); | ||
114 | 325 | } | ||
115 | 326 | |||
116 | 327 | onEndDateChanged: { | ||
117 | 328 | if (!root.endDate || isNaN(root.endDate.getTime())) { | ||
118 | 329 | if (root.startDate) { | ||
119 | 330 | endDateTimeInput.dateTime = root.startDate; | ||
120 | 331 | } | ||
121 | 332 | } else { | ||
122 | 333 | if (root.endDate) { | ||
123 | 334 | endDateTimeInput.dateTime = root.endDate; | ||
124 | 335 | } | ||
125 | 336 | } | ||
126 | 337 | } | ||
127 | 338 | |||
128 | 339 | header: PageHeader { | 315 | header: PageHeader { |
129 | 340 | id: pageHeader | 316 | id: pageHeader |
130 | 341 | 317 | ||
131 | @@ -442,6 +418,8 @@ | |||
132 | 442 | 418 | ||
133 | 443 | NewEventTimePicker{ | 419 | NewEventTimePicker{ |
134 | 444 | id: startDateTimeInput | 420 | id: startDateTimeInput |
135 | 421 | objectName: "startDateTimeInput" | ||
136 | 422 | |||
137 | 445 | header: i18n.tr("From") | 423 | header: i18n.tr("From") |
138 | 446 | showTimePicker: !allDayEventCheckbox.checked | 424 | showTimePicker: !allDayEventCheckbox.checked |
139 | 447 | anchors { | 425 | anchors { |
140 | @@ -450,11 +428,14 @@ | |||
141 | 450 | } | 428 | } |
142 | 451 | onDateTimeChanged: { | 429 | onDateTimeChanged: { |
143 | 452 | startDate = dateTime; | 430 | startDate = dateTime; |
144 | 431 | endDateTimeInput.dateTime = new Date(startDate.getTime() + root.eventSize) | ||
145 | 453 | } | 432 | } |
146 | 454 | } | 433 | } |
147 | 455 | 434 | ||
148 | 456 | NewEventTimePicker{ | 435 | NewEventTimePicker{ |
149 | 457 | id: endDateTimeInput | 436 | id: endDateTimeInput |
150 | 437 | objectName: "endDateTimeInput" | ||
151 | 438 | |||
152 | 458 | header: i18n.tr("To") | 439 | header: i18n.tr("To") |
153 | 459 | showTimePicker: !allDayEventCheckbox.checked | 440 | showTimePicker: !allDayEventCheckbox.checked |
154 | 460 | anchors { | 441 | anchors { |
155 | @@ -462,7 +443,17 @@ | |||
156 | 462 | right: parent.right | 443 | right: parent.right |
157 | 463 | } | 444 | } |
158 | 464 | onDateTimeChanged: { | 445 | onDateTimeChanged: { |
159 | 446 | if (dateTime.getTime() < startDate.getTime()) { | ||
160 | 447 | root.eventSize = root.allDay ? 0 : root.millisecsInAnHour | ||
161 | 448 | dateTime = new Date(startDate.getTime() + root.eventSize) | ||
162 | 449 | return | ||
163 | 450 | } | ||
164 | 451 | |||
165 | 465 | endDate = dateTime; | 452 | endDate = dateTime; |
166 | 453 | if (allDay) | ||
167 | 454 | root.eventSize = endDate.midnight().getTime() - startDate.midnight().getTime() | ||
168 | 455 | else | ||
169 | 456 | root.eventSize = endDate.getTime() - startDate.getTime() | ||
170 | 466 | } | 457 | } |
171 | 467 | } | 458 | } |
172 | 468 | 459 | ||
173 | @@ -479,6 +470,12 @@ | |||
174 | 479 | objectName: "allDayEventCheckbox" | 470 | objectName: "allDayEventCheckbox" |
175 | 480 | id: allDayEventCheckbox | 471 | id: allDayEventCheckbox |
176 | 481 | checked: false | 472 | checked: false |
177 | 473 | onCheckedChanged: { | ||
178 | 474 | if (checked) | ||
179 | 475 | root.eventSize = Math.max(endDate.midnight().getTime() - startDate.midnight().getTime(), 0) | ||
180 | 476 | else | ||
181 | 477 | root.eventSize = Math.max(endDate.getTime() - startDate.getTime(), root.millisecsInAnHour) | ||
182 | 478 | } | ||
183 | 482 | } | 479 | } |
184 | 483 | } | 480 | } |
185 | 484 | 481 | ||
186 | @@ -570,7 +567,7 @@ | |||
187 | 570 | } | 567 | } |
188 | 571 | 568 | ||
189 | 572 | containerHeight: itemHeight * 4 | 569 | containerHeight: itemHeight * 4 |
191 | 573 | model: root.model.getWritableAndSelectedCollections(); | 570 | model: root.model ? root.model.getWritableAndSelectedCollections() : [] |
192 | 574 | 571 | ||
193 | 575 | delegate: OptionSelectorDelegate{ | 572 | delegate: OptionSelectorDelegate{ |
194 | 576 | text: modelData.name | 573 | text: modelData.name |
195 | 577 | 574 | ||
196 | === modified file 'dateExt.js' | |||
197 | --- dateExt.js 2016-03-02 19:55:52 +0000 | |||
198 | +++ dateExt.js 2016-03-28 21:19:15 +0000 | |||
199 | @@ -60,19 +60,19 @@ | |||
200 | 60 | } | 60 | } |
201 | 61 | 61 | ||
202 | 62 | Date.prototype.addDays = function(days) { | 62 | Date.prototype.addDays = function(days) { |
203 | 63 | var date = new Date(this) | ||
204 | 63 | if (days === 0) | 64 | if (days === 0) |
206 | 64 | return this | 65 | return date |
207 | 65 | 66 | ||
208 | 66 | var date = new Date(this) | ||
209 | 67 | date.setDate(date.getDate() + days); | 67 | date.setDate(date.getDate() + days); |
210 | 68 | return date | 68 | return date |
211 | 69 | } | 69 | } |
212 | 70 | 70 | ||
213 | 71 | Date.prototype.addMinutes = function(minutes) { | 71 | Date.prototype.addMinutes = function(minutes) { |
214 | 72 | var date = new Date(this) | ||
215 | 72 | if (minutes === 0) | 73 | if (minutes === 0) |
217 | 73 | return this | 74 | return date |
218 | 74 | 75 | ||
219 | 75 | var date = new Date(this) | ||
220 | 76 | date.setMinutes(date.getMinutes() + minutes); | 76 | date.setMinutes(date.getMinutes() + minutes); |
221 | 77 | return date | 77 | return date |
222 | 78 | } | 78 | } |
223 | 79 | 79 | ||
224 | === modified file 'tests/unittests/CMakeLists.txt' | |||
225 | --- tests/unittests/CMakeLists.txt 2014-01-28 16:51:15 +0000 | |||
226 | +++ tests/unittests/CMakeLists.txt 2016-03-28 21:19:15 +0000 | |||
227 | @@ -3,6 +3,6 @@ | |||
228 | 3 | file(GLOB TESTS tst_*.qml) | 3 | file(GLOB TESTS tst_*.qml) |
229 | 4 | foreach(TEST ${TESTS}) | 4 | foreach(TEST ${TESTS}) |
230 | 5 | get_filename_component(NAME ${TEST} NAME_WE) | 5 | get_filename_component(NAME ${TEST} NAME_WE) |
232 | 6 | add_test(${NAME} ${QMLTESTRUNNER} -input ${TEST}) | 6 | add_test(${NAME} ${QMLTESTRUNNER} -import ${CMAKE_SOURCE_DIR} -input ${TEST}) |
233 | 7 | set_tests_properties(${NAME} PROPERTIES ENVIRONMENT "QT_QPA_PLATFORM=minimal") | 7 | set_tests_properties(${NAME} PROPERTIES ENVIRONMENT "QT_QPA_PLATFORM=minimal") |
234 | 8 | endforeach(TEST) | 8 | endforeach(TEST) |
235 | 9 | 9 | ||
236 | === added file 'tests/unittests/tst_new_event.qml' | |||
237 | --- tests/unittests/tst_new_event.qml 1970-01-01 00:00:00 +0000 | |||
238 | +++ tests/unittests/tst_new_event.qml 2016-03-28 21:19:15 +0000 | |||
239 | @@ -0,0 +1,169 @@ | |||
240 | 1 | import QtQuick 2.0 | ||
241 | 2 | import QtTest 1.0 | ||
242 | 3 | import QtOrganizer 5.0 | ||
243 | 4 | |||
244 | 5 | TestCase{ | ||
245 | 6 | id: root | ||
246 | 7 | name: "New Event tests" | ||
247 | 8 | |||
248 | 9 | property var newEventPage: null | ||
249 | 10 | |||
250 | 11 | Component { | ||
251 | 12 | id: eventComp | ||
252 | 13 | |||
253 | 14 | Event { | ||
254 | 15 | } | ||
255 | 16 | } | ||
256 | 17 | |||
257 | 18 | function create_event_from_data(data) | ||
258 | 19 | { | ||
259 | 20 | return eventComp.createObject(root, | ||
260 | 21 | {'allDay': data.allDay, | ||
261 | 22 | 'displayLabel': data.label, | ||
262 | 23 | 'startDateTime': data.startDate, | ||
263 | 24 | 'endDateTime': data.endDate}) | ||
264 | 25 | } | ||
265 | 26 | |||
266 | 27 | function create_new_event_page(event) | ||
267 | 28 | { | ||
268 | 29 | var component = Qt.createComponent(Qt.resolvedUrl("../../NewEvent.qml")) | ||
269 | 30 | if (component.status === Component.Ready) | ||
270 | 31 | return component.createObject(root, {"event": event}) | ||
271 | 32 | |||
272 | 33 | return null | ||
273 | 34 | } | ||
274 | 35 | |||
275 | 36 | function init() | ||
276 | 37 | { | ||
277 | 38 | |||
278 | 39 | } | ||
279 | 40 | |||
280 | 41 | function cleanup() | ||
281 | 42 | { | ||
282 | 43 | if (newEventPage) { | ||
283 | 44 | newEventPage.destroy() | ||
284 | 45 | newEventPage = null | ||
285 | 46 | } | ||
286 | 47 | } | ||
287 | 48 | |||
288 | 49 | function test_new_event_title() | ||
289 | 50 | { | ||
290 | 51 | newEventPage = create_new_event_page(null) | ||
291 | 52 | compare(newEventPage.header.title, "New Event") | ||
292 | 53 | } | ||
293 | 54 | |||
294 | 55 | function test_edit_event_details() | ||
295 | 56 | { | ||
296 | 57 | var startDate = new Date(2016, 3, 28, 14, 0,0 ) | ||
297 | 58 | var endDate = new Date(2016, 3, 28, 15, 0,0 ) | ||
298 | 59 | var eventData = {"label": 'test_event_details', | ||
299 | 60 | "allDay": false, | ||
300 | 61 | "startDate": startDate, | ||
301 | 62 | "endDate": endDate } | ||
302 | 63 | var event = create_event_from_data(eventData) | ||
303 | 64 | newEventPage = create_new_event_page(event) | ||
304 | 65 | |||
305 | 66 | compare(newEventPage.header.title, "Edit Event") | ||
306 | 67 | compare(newEventPage.startDate, startDate) | ||
307 | 68 | compare(newEventPage.endDate, endDate) | ||
308 | 69 | } | ||
309 | 70 | |||
310 | 71 | function test_change_start_date() | ||
311 | 72 | { | ||
312 | 73 | var startDate = new Date(2016, 3, 28, 14, 0,0 ) | ||
313 | 74 | var endDate = new Date(2016, 3, 28, 15, 0,0 ) | ||
314 | 75 | var eventData = {"label": 'test_event_details', | ||
315 | 76 | "allDay": false, | ||
316 | 77 | "startDate": startDate, | ||
317 | 78 | "endDate": endDate } | ||
318 | 79 | var event = create_event_from_data(eventData) | ||
319 | 80 | newEventPage = create_new_event_page(event) | ||
320 | 81 | |||
321 | 82 | compare(newEventPage.eventSize, 3600000) // 1h | ||
322 | 83 | |||
323 | 84 | //Move start date 1h foward | ||
324 | 85 | var startDatePicker = findChild(newEventPage, "startDateTimeInput") | ||
325 | 86 | startDatePicker.dateTime = new Date(2016, 3, 28, 15, 0,0 ) | ||
326 | 87 | compare(newEventPage.eventSize, 3600000) // 1h | ||
327 | 88 | compare(newEventPage.endDate, new Date(2016, 3, 28, 16, 0,0 )) | ||
328 | 89 | |||
329 | 90 | //Move start date 3h backward | ||
330 | 91 | startDatePicker.dateTime = new Date(2016, 3, 28, 12, 0,0 ) | ||
331 | 92 | compare(newEventPage.eventSize, 3600000) // 1h | ||
332 | 93 | compare(newEventPage.endDate, new Date(2016, 3, 28, 13, 0,0 )) | ||
333 | 94 | } | ||
334 | 95 | |||
335 | 96 | function test_change_end_date() | ||
336 | 97 | { | ||
337 | 98 | var startDate = new Date(2016, 3, 28, 14, 0,0 ) | ||
338 | 99 | var endDate = new Date(2016, 3, 28, 15, 0,0 ) | ||
339 | 100 | var eventData = {"label": 'test_event_details', | ||
340 | 101 | "allDay": false, | ||
341 | 102 | "startDate": startDate, | ||
342 | 103 | "endDate": endDate } | ||
343 | 104 | var event = create_event_from_data(eventData) | ||
344 | 105 | newEventPage = create_new_event_page(event) | ||
345 | 106 | |||
346 | 107 | // Move end date 30 min backward | ||
347 | 108 | var endDatePicker = findChild(newEventPage, "endDateTimeInput") | ||
348 | 109 | endDatePicker.dateTime = new Date(2016, 3, 28, 14, 30,0 ) | ||
349 | 110 | compare(newEventPage.eventSize, 1800000) // 30 min | ||
350 | 111 | |||
351 | 112 | // Move start date 1h foward | ||
352 | 113 | var startDatePicker = findChild(newEventPage, "startDateTimeInput") | ||
353 | 114 | startDatePicker.dateTime = new Date(2016, 3, 28, 15, 0,0 ) | ||
354 | 115 | compare(newEventPage.eventSize, 1800000) // 30 min | ||
355 | 116 | compare(newEventPage.endDate, new Date(2016, 3, 28, 15, 30,0 )) | ||
356 | 117 | } | ||
357 | 118 | |||
358 | 119 | function test_change_start_date_for_all_day() | ||
359 | 120 | { | ||
360 | 121 | var startDate = new Date(2016, 3, 28, 0, 0,0 ) | ||
361 | 122 | var endDate = new Date(2016, 3, 28, 0, 0,0 ) | ||
362 | 123 | var eventData = {"label": 'test_event_details', | ||
363 | 124 | "allDay": true, | ||
364 | 125 | "startDate": startDate, | ||
365 | 126 | "endDate": endDate } | ||
366 | 127 | var event = create_event_from_data(eventData) | ||
367 | 128 | newEventPage = create_new_event_page(event) | ||
368 | 129 | |||
369 | 130 | compare(newEventPage.eventSize, 0) // 1 day | ||
370 | 131 | |||
371 | 132 | // Move start date 1 day foward | ||
372 | 133 | var startDatePicker = findChild(newEventPage, "startDateTimeInput") | ||
373 | 134 | startDatePicker.dateTime = new Date(2016, 3, 29, 0, 0,0) | ||
374 | 135 | |||
375 | 136 | // end date should move 1 day | ||
376 | 137 | compare(newEventPage.endDate, new Date(2016, 3, 29, 0, 0,0 )) | ||
377 | 138 | |||
378 | 139 | // Move end date 1 day foward | ||
379 | 140 | var endDatePicker = findChild(newEventPage, "endDateTimeInput") | ||
380 | 141 | endDatePicker.dateTime = new Date(2016, 3, 30, 0, 0,0) | ||
381 | 142 | |||
382 | 143 | // start date should not change | ||
383 | 144 | compare(newEventPage.startDate, new Date(2016, 3, 29, 0, 0,0 )) | ||
384 | 145 | // event size should increase | ||
385 | 146 | compare(newEventPage.eventSize, 86400000) // 2 days | ||
386 | 147 | |||
387 | 148 | // Move start date 1 day foward | ||
388 | 149 | startDatePicker.dateTime = new Date(2016, 3, 30, 0, 0,0) | ||
389 | 150 | |||
390 | 151 | // end date should move 2 day | ||
391 | 152 | compare(newEventPage.endDate, new Date(2016, 3, 31, 0, 0,0 )) | ||
392 | 153 | } | ||
393 | 154 | |||
394 | 155 | function test_events_with_null_end_date() | ||
395 | 156 | { | ||
396 | 157 | var startDate = new Date(2016, 3, 28, 15, 0,0 ) | ||
397 | 158 | var eventData = {"label": 'test_event_details', | ||
398 | 159 | "allDay": false, | ||
399 | 160 | "startDate": startDate, | ||
400 | 161 | "endDate": null } | ||
401 | 162 | var event = create_event_from_data(eventData) | ||
402 | 163 | newEventPage = create_new_event_page(event) | ||
403 | 164 | |||
404 | 165 | compare(newEventPage.eventSize, 0) | ||
405 | 166 | compare(newEventPage.startDate, new Date(2016, 3, 28, 15, 0,0 )) | ||
406 | 167 | compare(newEventPage.endDate, new Date(2016, 3, 28, 15, 0,0 )) | ||
407 | 168 | } | ||
408 | 169 | } |
FAILED: Continuous integration, rev:782 /core-apps- jenkins. ubuntu. com/job/ calendar- app-ci/ 793/ /core-apps- jenkins. ubuntu. com/job/ generic- update- mp/794/ console
https:/
Executed test runs:
None: https:/
Click here to trigger a rebuild: /core-apps- jenkins. ubuntu. com/job/ calendar- app-ci/ 793/rebuild
https:/