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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
|
/* 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/. */
// Encoded test URI to work on all platforms/independent of file encoding
const kTestURI = "http://\u65e5\u672c\u8a93.jp/";
const kExpectedURI = "http://xn--wgv71a309e.jp/";
const kOutputFile = "result.txt";
// Try several times in case the box we're running on is slow.
const kMaxCheckExistAttempts = 30; // seconds
var gCheckExistsAttempts = 0;
const tempDir = do_get_tempdir();
function checkFile() {
// This is where we expect the output
var tempFile = tempDir.clone();
tempFile.append(kOutputFile);
if (!tempFile.exists()) {
if (gCheckExistsAttempts >= kMaxCheckExistAttempts) {
do_throw(
"Expected File " +
tempFile.path +
" does not exist after " +
kMaxCheckExistAttempts +
" seconds"
);
} else {
++gCheckExistsAttempts;
// Wait a bit longer then try again
do_timeout(1000, checkFile);
return;
}
}
// Now read it
var fstream = Cc["@mozilla.org/network/file-input-stream;1"].createInstance(
Ci.nsIFileInputStream
);
var sstream = Cc["@mozilla.org/scriptableinputstream;1"].createInstance(
Ci.nsIScriptableInputStream
);
fstream.init(tempFile, -1, 0, 0);
sstream.init(fstream);
// Read the first line only as that's the one we expect WriteArguments
// to be writing the argument to.
var data = sstream.read(4096);
sstream.close();
fstream.close();
// Now remove the old file
tempFile.remove(false);
// This currently fails on Mac with an argument like -psn_0_nnnnnn
// This seems to be to do with how the executable is called, but I couldn't
// find a way around it.
// Additionally the lack of OS detection in xpcshell tests sucks, so we'll
// have to check for the argument mac gives us.
if (data.substring(0, 7) != "-psn_0_") {
Assert.equal(data, kExpectedURI);
}
do_test_finished();
}
function run_test() {
if (mozinfo.os == "mac") {
dump("INFO | test_punycodeURIs.js | Skipping test on mac, bug 599475");
return;
}
// set up the uri to test with
var ioService = Services.io;
// set up the local handler object
var localHandler = Cc[
"@mozilla.org/uriloader/local-handler-app;1"
].createInstance(Ci.nsILocalHandlerApp);
localHandler.name = "Test Local Handler App";
// WriteArgument will just dump its arguments to a file for us.
var processDir = do_get_cwd();
var exe = processDir.clone();
exe.append("WriteArgument");
if (!exe.exists()) {
// Maybe we are on windows
exe.leafName = "WriteArgument.exe";
if (!exe.exists()) {
do_throw("Could not locate the WriteArgument tests executable\n");
}
}
var outFile = tempDir.clone();
outFile.append(kOutputFile);
// Set an environment variable for WriteArgument to pick up
// The Write Argument file needs to know where its libraries are, so
// just force the path variable
// For mac
var greDir = Services.dirsvc.get("GreD", Ci.nsIFile);
Services.env.set("DYLD_LIBRARY_PATH", greDir.path);
// For Linux
Services.env.set("LD_LIBRARY_PATH", greDir.path);
// XXX: handle windows
// Now tell it where we want the file.
Services.env.set("WRITE_ARGUMENT_FILE", outFile.path);
var uri = ioService.newURI(kTestURI);
// Just check we've got these matching, if we haven't there's a problem
// with ascii spec or our test case.
Assert.equal(uri.asciiSpec, kExpectedURI);
localHandler.executable = exe;
localHandler.launchWithURI(uri);
do_test_pending();
do_timeout(1000, checkFile);
}
|