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
|
/* 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/. */
var EXPORTED_SYMBOLS = ["TestFile"];
const Assert = {
ok(cond, text) {
// we don't have the test harness' utilities in this scope, so we need this
// little helper. In the failure case, the exception is propagated to the
// caller in the main run_test() function, and the test fails.
if (!cond)
throw "Failed check: " + text;
}
};
var TestFile = {
doTest: function(cb) {
// throw if anything goes wrong
// find the current directory path
var file = Cc["@mozilla.org/file/directory_service;1"]
.getService(Ci.nsIProperties)
.get("CurWorkD", Ci.nsIFile);
file.append("xpcshell.toml");
// should be able to construct a file
var f1, f2;
Promise.all([
File.createFromFileName(file.path).then(f => { f1 = f; }),
File.createFromNsIFile(file).then(f => { f2 = f; }),
])
.then(() => {
// do some tests
Assert.ok(f1 instanceof File, "Should be a DOM File");
Assert.ok(f2 instanceof File, "Should be a DOM File");
Assert.ok(f1.name == "xpcshell.toml", "Should be the right file");
Assert.ok(f2.name == "xpcshell.toml", "Should be the right file");
Assert.ok(f1.type == "", "Should be the right type");
Assert.ok(f2.type == "", "Should be the right type");
})
.then(() => {
var threw = false;
try {
// Needs a ctor argument
var f7 = new File();
} catch (e) {
threw = true;
}
Assert.ok(threw, "No ctor arguments should throw");
var threw = false;
try {
// Needs a valid ctor argument
var f7 = new File(Date(132131532));
} catch (e) {
threw = true;
}
Assert.ok(threw, "Passing a random object should fail");
// Directories fail
var dir = Cc["@mozilla.org/file/directory_service;1"]
.getService(Ci.nsIProperties)
.get("CurWorkD", Ci.nsIFile);
return File.createFromNsIFile(dir)
})
.then(() => {
Assert.ok(false, "Can't create a File object for a directory");
}, () => {
Assert.ok(true, "Can't create a File object for a directory");
})
.then(() => {
cb(true);
});
},
};
|