1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
|
/* -*- indent-tabs-mode: nil; js-indent-level: 2 -*- */
/* vim:set ts=2 sw=2 sts=2 et: */
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
function assert_date_eq(a, b) {
if (typeof a != "number") {
a = PlacesUtils.toPRTime(a);
}
if (typeof b != "number") {
b = PlacesUtils.toPRTime(b);
}
Assert.equal(a, b, "The dates should match");
}
/**
* Test that inserting a new bookmark will set lastModified to the same
* values as dateAdded.
*/
add_task(async function test_bookmarkLastModified() {
let bookmark = await PlacesUtils.bookmarks.insert({
parentGuid: PlacesUtils.bookmarks.menuGuid,
url: "http://www.mozilla.org/",
title: "itemTitle",
});
let guid = bookmark.guid;
// Check the bookmark from the database.
bookmark = await PlacesUtils.bookmarks.fetch(guid);
let dateAdded = PlacesUtils.toPRTime(bookmark.dateAdded);
assert_date_eq(dateAdded, bookmark.lastModified);
// Change lastModified, then change dateAdded. LastModified should be set
// to the new dateAdded.
// This could randomly fail on virtual machines due to timing issues, so
// we manually increase the time value. See bug 500640 for details.
await PlacesUtils.bookmarks.update({
guid,
lastModified: PlacesUtils.toDate(dateAdded + 1000),
});
bookmark = await PlacesUtils.bookmarks.fetch(guid);
assert_date_eq(bookmark.lastModified, dateAdded + 1000);
Assert.ok(
bookmark.dateAdded < bookmark.lastModified,
"Date added should be earlier than last modified."
);
await PlacesUtils.bookmarks.update({
guid,
dateAdded: PlacesUtils.toDate(dateAdded + 2000),
});
bookmark = await PlacesUtils.bookmarks.fetch(guid);
assert_date_eq(bookmark.dateAdded, dateAdded + 2000);
assert_date_eq(bookmark.dateAdded, bookmark.lastModified);
// If dateAdded is set to older than lastModified, then we shouldn't
// update lastModified to keep sync happy.
let origLastModified = bookmark.lastModified;
await PlacesUtils.bookmarks.update({
guid,
dateAdded: PlacesUtils.toDate(dateAdded - 10000),
});
bookmark = await PlacesUtils.bookmarks.fetch(guid);
assert_date_eq(bookmark.dateAdded, dateAdded - 10000);
assert_date_eq(bookmark.lastModified, origLastModified);
await PlacesUtils.bookmarks.remove(guid);
});
|