mirror of
https://github.com/NativeScript/NativeScript.git
synced 2025-08-16 20:11:24 +08:00
XMLHttpRequest separated from http module
This commit is contained in:
@ -182,6 +182,7 @@
|
|||||||
<TypeScriptCompile Include="apps\tests\frame-tests.ts" />
|
<TypeScriptCompile Include="apps\tests\frame-tests.ts" />
|
||||||
<TypeScriptCompile Include="apps\tests\gestures-tests.ts" />
|
<TypeScriptCompile Include="apps\tests\gestures-tests.ts" />
|
||||||
<TypeScriptCompile Include="apps\tests\fetch-tests.ts" />
|
<TypeScriptCompile Include="apps\tests\fetch-tests.ts" />
|
||||||
|
<TypeScriptCompile Include="apps\tests\xhr-tests.ts" />
|
||||||
<TypeScriptCompile Include="apps\tests\layouts\dock-layout-tests.ts" />
|
<TypeScriptCompile Include="apps\tests\layouts\dock-layout-tests.ts" />
|
||||||
<TypeScriptCompile Include="apps\tests\pages\app.ts" />
|
<TypeScriptCompile Include="apps\tests\pages\app.ts" />
|
||||||
<TypeScriptCompile Include="apps\tests\pages\file-load-test.ts" />
|
<TypeScriptCompile Include="apps\tests\pages\file-load-test.ts" />
|
||||||
@ -1032,6 +1033,7 @@
|
|||||||
</TypeScriptCompile>
|
</TypeScriptCompile>
|
||||||
<TypeScriptCompile Include="apps\xml-demo\app.ts" />
|
<TypeScriptCompile Include="apps\xml-demo\app.ts" />
|
||||||
<TypeScriptCompile Include="apps\xml-demo\mainPage.ts" />
|
<TypeScriptCompile Include="apps\xml-demo\mainPage.ts" />
|
||||||
|
<TypeScriptCompile Include="xhr\xhr.ts" />
|
||||||
<TypeScriptCompile Include="xml\xml.d.ts" />
|
<TypeScriptCompile Include="xml\xml.d.ts" />
|
||||||
<TypeScriptCompile Include="data\observable-array\observable-array.d.ts" />
|
<TypeScriptCompile Include="data\observable-array\observable-array.d.ts" />
|
||||||
<TypeScriptCompile Include="apps\tests\observable-array-tests.ts" />
|
<TypeScriptCompile Include="apps\tests\observable-array-tests.ts" />
|
||||||
@ -1688,6 +1690,10 @@
|
|||||||
<Content Include="apps\list-view-demo\package.json">
|
<Content Include="apps\list-view-demo\package.json">
|
||||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
||||||
</Content>
|
</Content>
|
||||||
|
<Content Include="xhr\package.json">
|
||||||
|
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
||||||
|
</Content>
|
||||||
|
<Content Include="xhr\Readme.md" />
|
||||||
<None Include="js-libs\esprima\LICENSE.BSD" />
|
<None Include="js-libs\esprima\LICENSE.BSD" />
|
||||||
<Content Include="source-control.md" />
|
<Content Include="source-control.md" />
|
||||||
<Content Include="ui\segmented-bar\package.json">
|
<Content Include="ui\segmented-bar\package.json">
|
||||||
|
@ -110,7 +110,7 @@ export var test_getImage = function (done) {
|
|||||||
// <snippet module="http" title="http">
|
// <snippet module="http" title="http">
|
||||||
// ### Get Image from URL
|
// ### Get Image from URL
|
||||||
// ``` JavaScript
|
// ``` JavaScript
|
||||||
http.getImage("http://www.google.com/images/errors/logo_sm_2.png").then(function (r) {
|
http.getImage("https://httpbin.org/image/png").then(function (r) {
|
||||||
//// Argument (r) is Image!
|
//// Argument (r) is Image!
|
||||||
// <hide>
|
// <hide>
|
||||||
result = r;
|
result = r;
|
||||||
@ -309,7 +309,7 @@ export var test_request_responseContentToJSONShouldReturnJSON = function (done)
|
|||||||
export var test_request_responseContentToImageShouldReturnCorrectImage = function (done) {
|
export var test_request_responseContentToImageShouldReturnCorrectImage = function (done) {
|
||||||
var result;
|
var result;
|
||||||
|
|
||||||
http.request({ url: "http://www.google.com/images/errors/logo_sm_2.png", method: "GET" }).then(function (response) {
|
http.request({ url: "https://httpbin.org/image/png", method: "GET" }).then(function (response) {
|
||||||
response.content.toImage().then((source) => {
|
response.content.toImage().then((source) => {
|
||||||
result = source;
|
result = source;
|
||||||
try {
|
try {
|
||||||
@ -452,180 +452,4 @@ function doRequest(url: string, done: Function) {
|
|||||||
}, function (e) {
|
}, function (e) {
|
||||||
done(e);
|
done(e);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
export var test_XMLHttpRequest_isDefined = function () {
|
|
||||||
TKUnit.assert(types.isDefined(global["XMLHttpRequest"]), "XMLHttpRequest should be defined!");
|
|
||||||
};
|
|
||||||
|
|
||||||
var xhr = new XMLHttpRequest();
|
|
||||||
|
|
||||||
export var test_XMLHttpRequest_open_isDefined = function () {
|
|
||||||
TKUnit.assert(types.isFunction(xhr.open), "XMLHttpRequest.open should be defined!");
|
|
||||||
};
|
|
||||||
|
|
||||||
export var test_XMLHttpRequest_send_isDefined = function () {
|
|
||||||
TKUnit.assert(types.isFunction(xhr.send), "XMLHttpRequest.send should be defined!");
|
|
||||||
};
|
|
||||||
|
|
||||||
export var test_XMLHttpRequest_setRequestHeader_isDefined = function () {
|
|
||||||
TKUnit.assert(types.isFunction(xhr.setRequestHeader), "XMLHttpRequest.setRequestHeader should be defined!");
|
|
||||||
};
|
|
||||||
|
|
||||||
export var test_XMLHttpRequest_getAllResponseHeaders_isDefined = function () {
|
|
||||||
TKUnit.assert(types.isFunction(xhr.getAllResponseHeaders), "XMLHttpRequest.getAllResponseHeaders should be defined!");
|
|
||||||
};
|
|
||||||
|
|
||||||
export var test_XMLHttpRequest_getResponseHeader_isDefined = function () {
|
|
||||||
TKUnit.assert(types.isFunction(xhr.getResponseHeader), "XMLHttpRequest.getResponseHeader should be defined!");
|
|
||||||
};
|
|
||||||
|
|
||||||
export var test_XMLHttpRequest_overrideMimeType_isDefined = function () {
|
|
||||||
TKUnit.assert(types.isFunction(xhr.overrideMimeType), "XMLHttpRequest.overrideMimeType should be defined!");
|
|
||||||
};
|
|
||||||
|
|
||||||
export var test_XMLHttpRequest_readyState_isDefined = function () {
|
|
||||||
TKUnit.assert(types.isDefined(xhr.readyState), "XMLHttpRequest.readyState should be defined!");
|
|
||||||
};
|
|
||||||
|
|
||||||
export var test_XMLHttpRequest_responseText_isDefined = function () {
|
|
||||||
TKUnit.assert(types.isDefined(xhr.responseText), "XMLHttpRequest.responseText should be defined!");
|
|
||||||
};
|
|
||||||
|
|
||||||
export var test_XMLHttpRequest_readyStateShouldChange = function (done) {
|
|
||||||
var count = 0;
|
|
||||||
xhr = new XMLHttpRequest();
|
|
||||||
|
|
||||||
TKUnit.assert(xhr.readyState === 0, "xhr.readyState should be UNSENT!");
|
|
||||||
|
|
||||||
xhr.onreadystatechange = function () {
|
|
||||||
try {
|
|
||||||
|
|
||||||
if (count === 0) {
|
|
||||||
TKUnit.assert(xhr.readyState === 1, "xhr.readyState should be OPEN!");
|
|
||||||
} else if (count === 1) {
|
|
||||||
TKUnit.assert(xhr.readyState === 2, "xhr.readyState should be HEADERS_RECEIVED!");
|
|
||||||
} else if (count === 2) {
|
|
||||||
TKUnit.assert(xhr.readyState === 3, "xhr.readyState should be LOADING!");
|
|
||||||
} else if (count === 3) {
|
|
||||||
TKUnit.assert(xhr.readyState === 4, "xhr.readyState should be DONE!");
|
|
||||||
}
|
|
||||||
|
|
||||||
count++;
|
|
||||||
|
|
||||||
done(null);
|
|
||||||
}
|
|
||||||
catch (err) {
|
|
||||||
done(err);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
xhr.open("GET", "https://httpbin.org/get");
|
|
||||||
xhr.send();
|
|
||||||
};
|
|
||||||
|
|
||||||
export var test_XMLHttpRequest_headersSentAndReceivedProperly = function (done) {
|
|
||||||
xhr = new XMLHttpRequest();
|
|
||||||
xhr.open("GET", "https://httpbin.org/get");
|
|
||||||
xhr.setRequestHeader("Content-Type", "application/json");
|
|
||||||
xhr.onreadystatechange = function () {
|
|
||||||
if (xhr.readyState > 1) {
|
|
||||||
try {
|
|
||||||
TKUnit.assert(xhr.getResponseHeader("Content-Type") === "application/json", "Headers not sent/received properly!");
|
|
||||||
done(null);
|
|
||||||
}
|
|
||||||
catch (err) {
|
|
||||||
done(err);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
xhr.send();
|
|
||||||
};
|
|
||||||
|
|
||||||
export var test_XMLHttpRequest_contentSentAndReceivedProperly = function (done) {
|
|
||||||
xhr = new XMLHttpRequest();
|
|
||||||
xhr.open("POST", "https://httpbin.org/post");
|
|
||||||
xhr.setRequestHeader("Content-Type", "application/json");
|
|
||||||
xhr.onreadystatechange = function () {
|
|
||||||
if (xhr.readyState > 3) {
|
|
||||||
var result = JSON.parse(xhr.responseText);
|
|
||||||
try {
|
|
||||||
TKUnit.assert(result["json"]["MyVariableOne"] === "ValueOne" && result["json"]["MyVariableTwo"] === "ValueTwo", "Content not sent/received properly!");
|
|
||||||
done(null);
|
|
||||||
}
|
|
||||||
catch (err) {
|
|
||||||
done(err);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
xhr.send(JSON.stringify({ MyVariableOne: "ValueOne", MyVariableTwo: "ValueTwo" }));
|
|
||||||
};
|
|
||||||
|
|
||||||
export var test_XMLHttpRequest_abortShouldCancelonreadystatechange = function (done) {
|
|
||||||
var flag = false;
|
|
||||||
|
|
||||||
xhr = new XMLHttpRequest();
|
|
||||||
xhr.open("POST", "https://httpbin.org/post");
|
|
||||||
xhr.setRequestHeader("Content-Type", "application/json");
|
|
||||||
xhr.onreadystatechange = function () {
|
|
||||||
flag = true;
|
|
||||||
};
|
|
||||||
xhr.send(JSON.stringify({ MyVariableOne: "ValueOne", MyVariableTwo: "ValueTwo" }));
|
|
||||||
xhr.abort();
|
|
||||||
|
|
||||||
TKUnit.assert(flag === false, "Content not sent/received properly!");
|
|
||||||
done(null);
|
|
||||||
};
|
|
||||||
|
|
||||||
export var test_XMLHttpRequest_requestShouldBePossibleAfterAbort = function (done) {
|
|
||||||
xhr = new XMLHttpRequest();
|
|
||||||
xhr.open("POST", "https://httpbin.org/post");
|
|
||||||
xhr.setRequestHeader("Content-Type", "application/json");
|
|
||||||
xhr.onreadystatechange = function () {
|
|
||||||
if (xhr.readyState > 3) {
|
|
||||||
var result = JSON.parse(xhr.responseText);
|
|
||||||
try {
|
|
||||||
TKUnit.assert(result["json"]["MyVariableOne"] === "ValueOne" && result["json"]["MyVariableTwo"] === "ValueTwo", "Content not sent/received properly!");
|
|
||||||
done(null);
|
|
||||||
}
|
|
||||||
catch (err) {
|
|
||||||
done(err);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
xhr.send(JSON.stringify({ MyVariableOne: "ValueOne", MyVariableTwo: "ValueTwo" }));
|
|
||||||
xhr.abort();
|
|
||||||
|
|
||||||
xhr.send(JSON.stringify({ MyVariableOne: "ValueOne", MyVariableTwo: "ValueTwo" }));
|
|
||||||
};
|
|
||||||
|
|
||||||
export function test_raises_onload_Event(done) {
|
|
||||||
let xhr = new XMLHttpRequest();
|
|
||||||
xhr.onload = () => {
|
|
||||||
done(null);
|
|
||||||
}
|
|
||||||
xhr.open("GET", "https://httpbin.org/get");
|
|
||||||
xhr.send();
|
|
||||||
}
|
|
||||||
|
|
||||||
export function test_raises_onerror_Event(done) {
|
|
||||||
let xhr = new XMLHttpRequest();
|
|
||||||
xhr.onerror = () => {
|
|
||||||
done(null);
|
|
||||||
}
|
|
||||||
xhr.open("GET", "https://no-such-domain-httpbin.org");
|
|
||||||
xhr.send();
|
|
||||||
}
|
|
||||||
|
|
||||||
export function test_responseType(done) {
|
|
||||||
let xhr = new XMLHttpRequest();
|
|
||||||
xhr.responseType = "";
|
|
||||||
xhr.responseType = "text";
|
|
||||||
|
|
||||||
TKUnit.assertThrows(
|
|
||||||
() => xhr.responseType = "json",
|
|
||||||
"Didn't raise on unsupported type.",
|
|
||||||
"Response type of 'json' not supported."
|
|
||||||
);
|
|
||||||
done(null);
|
|
||||||
}
|
|
@ -36,6 +36,7 @@ allTests["STYLE-PROPERTIES"] = require("./ui/style/style-properties-tests");
|
|||||||
allTests["SCROLL-VIEW"] = require("./ui/scroll-view/scroll-view-tests");
|
allTests["SCROLL-VIEW"] = require("./ui/scroll-view/scroll-view-tests");
|
||||||
allTests["FILE SYSTEM"] = require("./file-system-tests");
|
allTests["FILE SYSTEM"] = require("./file-system-tests");
|
||||||
allTests["HTTP"] = require("./http-tests");
|
allTests["HTTP"] = require("./http-tests");
|
||||||
|
allTests["XHR"] = require("./xhr-tests");
|
||||||
allTests["FETCH"] = require("./fetch-tests");
|
allTests["FETCH"] = require("./fetch-tests");
|
||||||
allTests["APPLICATION SETTINGS"] = require("./application-settings-tests");
|
allTests["APPLICATION SETTINGS"] = require("./application-settings-tests");
|
||||||
allTests["IMAGE SOURCE"] = require("./image-source-tests");
|
allTests["IMAGE SOURCE"] = require("./image-source-tests");
|
||||||
|
183
apps/tests/xhr-tests.ts
Normal file
183
apps/tests/xhr-tests.ts
Normal file
@ -0,0 +1,183 @@
|
|||||||
|
/* tslint:disable:no-unused-variable */
|
||||||
|
import TKUnit = require("./TKUnit");
|
||||||
|
import types = require("utils/types");
|
||||||
|
|
||||||
|
export var test_XMLHttpRequest_isDefined = function () {
|
||||||
|
TKUnit.assert(types.isDefined(global["XMLHttpRequest"]), "XMLHttpRequest should be defined!");
|
||||||
|
};
|
||||||
|
|
||||||
|
var xhr = new XMLHttpRequest();
|
||||||
|
|
||||||
|
export var test_XMLHttpRequest_open_isDefined = function () {
|
||||||
|
TKUnit.assert(types.isFunction(xhr.open), "XMLHttpRequest.open should be defined!");
|
||||||
|
};
|
||||||
|
|
||||||
|
export var test_XMLHttpRequest_send_isDefined = function () {
|
||||||
|
TKUnit.assert(types.isFunction(xhr.send), "XMLHttpRequest.send should be defined!");
|
||||||
|
};
|
||||||
|
|
||||||
|
export var test_XMLHttpRequest_setRequestHeader_isDefined = function () {
|
||||||
|
TKUnit.assert(types.isFunction(xhr.setRequestHeader), "XMLHttpRequest.setRequestHeader should be defined!");
|
||||||
|
};
|
||||||
|
|
||||||
|
export var test_XMLHttpRequest_getAllResponseHeaders_isDefined = function () {
|
||||||
|
TKUnit.assert(types.isFunction(xhr.getAllResponseHeaders), "XMLHttpRequest.getAllResponseHeaders should be defined!");
|
||||||
|
};
|
||||||
|
|
||||||
|
export var test_XMLHttpRequest_getResponseHeader_isDefined = function () {
|
||||||
|
TKUnit.assert(types.isFunction(xhr.getResponseHeader), "XMLHttpRequest.getResponseHeader should be defined!");
|
||||||
|
};
|
||||||
|
|
||||||
|
export var test_XMLHttpRequest_overrideMimeType_isDefined = function () {
|
||||||
|
TKUnit.assert(types.isFunction(xhr.overrideMimeType), "XMLHttpRequest.overrideMimeType should be defined!");
|
||||||
|
};
|
||||||
|
|
||||||
|
export var test_XMLHttpRequest_readyState_isDefined = function () {
|
||||||
|
TKUnit.assert(types.isNumber(xhr.readyState), "XMLHttpRequest.readyState should be defined!");
|
||||||
|
};
|
||||||
|
|
||||||
|
export var test_XMLHttpRequest_responseText_isDefined = function () {
|
||||||
|
TKUnit.assert(types.isString(xhr.responseText), "XMLHttpRequest.responseText should be defined!");
|
||||||
|
};
|
||||||
|
|
||||||
|
export var test_XMLHttpRequest_responseType_isDefined = function () {
|
||||||
|
TKUnit.assert(types.isString(xhr.responseType), "XMLHttpRequest.responseType should be defined!");
|
||||||
|
};
|
||||||
|
|
||||||
|
export var test_XMLHttpRequest_readyStateShouldChange = function (done) {
|
||||||
|
var count = 0;
|
||||||
|
xhr = new XMLHttpRequest();
|
||||||
|
|
||||||
|
TKUnit.assert(xhr.readyState === 0, "xhr.readyState should be UNSENT!");
|
||||||
|
|
||||||
|
xhr.onreadystatechange = function () {
|
||||||
|
try {
|
||||||
|
|
||||||
|
if (count === 0) {
|
||||||
|
TKUnit.assert(xhr.readyState === 1, "xhr.readyState should be OPEN!");
|
||||||
|
} else if (count === 1) {
|
||||||
|
TKUnit.assert(xhr.readyState === 2, "xhr.readyState should be HEADERS_RECEIVED!");
|
||||||
|
} else if (count === 2) {
|
||||||
|
TKUnit.assert(xhr.readyState === 3, "xhr.readyState should be LOADING!");
|
||||||
|
} else if (count === 3) {
|
||||||
|
TKUnit.assert(xhr.readyState === 4, "xhr.readyState should be DONE!");
|
||||||
|
}
|
||||||
|
|
||||||
|
count++;
|
||||||
|
|
||||||
|
done(null);
|
||||||
|
}
|
||||||
|
catch (err) {
|
||||||
|
done(err);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
xhr.open("GET", "https://httpbin.org/get");
|
||||||
|
xhr.send();
|
||||||
|
};
|
||||||
|
|
||||||
|
export var test_XMLHttpRequest_headersSentAndReceivedProperly = function (done) {
|
||||||
|
xhr = new XMLHttpRequest();
|
||||||
|
xhr.open("GET", "https://httpbin.org/get");
|
||||||
|
xhr.setRequestHeader("Content-Type", "application/json");
|
||||||
|
xhr.onreadystatechange = function () {
|
||||||
|
if (xhr.readyState > 1) {
|
||||||
|
try {
|
||||||
|
TKUnit.assert(xhr.getResponseHeader("Content-Type") === "application/json", "Headers not sent/received properly!");
|
||||||
|
done(null);
|
||||||
|
}
|
||||||
|
catch (err) {
|
||||||
|
done(err);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
xhr.send();
|
||||||
|
};
|
||||||
|
|
||||||
|
export var test_XMLHttpRequest_contentSentAndReceivedProperly = function (done) {
|
||||||
|
xhr = new XMLHttpRequest();
|
||||||
|
xhr.open("POST", "https://httpbin.org/post");
|
||||||
|
xhr.setRequestHeader("Content-Type", "application/json");
|
||||||
|
xhr.onreadystatechange = function () {
|
||||||
|
if (xhr.readyState > 3) {
|
||||||
|
var result = JSON.parse(xhr.responseText);
|
||||||
|
try {
|
||||||
|
TKUnit.assert(result["json"]["MyVariableOne"] === "ValueOne" && result["json"]["MyVariableTwo"] === "ValueTwo", "Content not sent/received properly!");
|
||||||
|
done(null);
|
||||||
|
}
|
||||||
|
catch (err) {
|
||||||
|
done(err);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
xhr.send(JSON.stringify({ MyVariableOne: "ValueOne", MyVariableTwo: "ValueTwo" }));
|
||||||
|
};
|
||||||
|
|
||||||
|
export var test_XMLHttpRequest_abortShouldCancelonreadystatechange = function (done) {
|
||||||
|
var flag = false;
|
||||||
|
|
||||||
|
xhr = new XMLHttpRequest();
|
||||||
|
xhr.open("POST", "https://httpbin.org/post");
|
||||||
|
xhr.setRequestHeader("Content-Type", "application/json");
|
||||||
|
xhr.onreadystatechange = function () {
|
||||||
|
flag = true;
|
||||||
|
};
|
||||||
|
xhr.send(JSON.stringify({ MyVariableOne: "ValueOne", MyVariableTwo: "ValueTwo" }));
|
||||||
|
xhr.abort();
|
||||||
|
|
||||||
|
TKUnit.assert(flag === false, "Content not sent/received properly!");
|
||||||
|
done(null);
|
||||||
|
};
|
||||||
|
|
||||||
|
export var test_XMLHttpRequest_requestShouldBePossibleAfterAbort = function (done) {
|
||||||
|
xhr = new XMLHttpRequest();
|
||||||
|
xhr.open("POST", "https://httpbin.org/post");
|
||||||
|
xhr.setRequestHeader("Content-Type", "application/json");
|
||||||
|
xhr.onreadystatechange = function () {
|
||||||
|
if (xhr.readyState > 3) {
|
||||||
|
var result = JSON.parse(xhr.responseText);
|
||||||
|
try {
|
||||||
|
TKUnit.assert(result["json"]["MyVariableOne"] === "ValueOne" && result["json"]["MyVariableTwo"] === "ValueTwo", "Content not sent/received properly!");
|
||||||
|
done(null);
|
||||||
|
}
|
||||||
|
catch (err) {
|
||||||
|
done(err);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
xhr.send(JSON.stringify({ MyVariableOne: "ValueOne", MyVariableTwo: "ValueTwo" }));
|
||||||
|
xhr.abort();
|
||||||
|
|
||||||
|
xhr.send(JSON.stringify({ MyVariableOne: "ValueOne", MyVariableTwo: "ValueTwo" }));
|
||||||
|
};
|
||||||
|
|
||||||
|
export function test_raises_onload_Event(done) {
|
||||||
|
let xhr = new XMLHttpRequest();
|
||||||
|
xhr.onload = () => {
|
||||||
|
done(null);
|
||||||
|
}
|
||||||
|
xhr.open("GET", "https://httpbin.org/get");
|
||||||
|
xhr.send();
|
||||||
|
}
|
||||||
|
|
||||||
|
export function test_raises_onerror_Event(done) {
|
||||||
|
let xhr = new XMLHttpRequest();
|
||||||
|
xhr.onerror = () => {
|
||||||
|
done(null);
|
||||||
|
}
|
||||||
|
xhr.open("GET", "https://no-such-domain-httpbin.org");
|
||||||
|
xhr.send();
|
||||||
|
}
|
||||||
|
|
||||||
|
export function test_responseType(done) {
|
||||||
|
let xhr = new XMLHttpRequest();
|
||||||
|
xhr.responseType = "";
|
||||||
|
xhr.responseType = "text";
|
||||||
|
|
||||||
|
TKUnit.assertThrows(
|
||||||
|
() => xhr.responseType = "json",
|
||||||
|
"Didn't raise on unsupported type.",
|
||||||
|
"Response type of 'json' not supported."
|
||||||
|
);
|
||||||
|
done(null);
|
||||||
|
}
|
@ -1,7 +1,7 @@
|
|||||||
import types = require("utils/types");
|
import types = require("utils/types");
|
||||||
import timer = require("timer");
|
import timer = require("timer");
|
||||||
import consoleModule = require("console");
|
import consoleModule = require("console");
|
||||||
import http = require("http");
|
import xhr = require("xhr/xhr");
|
||||||
import dialogs = require("ui/dialogs");
|
import dialogs = require("ui/dialogs");
|
||||||
|
|
||||||
global.setTimeout = timer.setTimeout;
|
global.setTimeout = timer.setTimeout;
|
||||||
@ -14,7 +14,7 @@ if (types.isUndefined(global.NSObject)) {
|
|||||||
global.console = new consoleModule.Console();
|
global.console = new consoleModule.Console();
|
||||||
}
|
}
|
||||||
|
|
||||||
global.XMLHttpRequest = (<any>http).XMLHttpRequest;
|
global.XMLHttpRequest = xhr.XMLHttpRequest;
|
||||||
global.alert = dialogs.alert;
|
global.alert = dialogs.alert;
|
||||||
|
|
||||||
export function Deprecated(target: Object, key?: string | symbol, descriptor?: any) {
|
export function Deprecated(target: Object, key?: string | symbol, descriptor?: any) {
|
||||||
|
236
http/http.ts
236
http/http.ts
@ -1,10 +1,6 @@
|
|||||||
import image = require("image-source");
|
import image = require("image-source");
|
||||||
|
|
||||||
import definition = require("http");
|
|
||||||
import httpRequest = require("http/http-request");
|
import httpRequest = require("http/http-request");
|
||||||
|
|
||||||
import types = require("utils/types");
|
|
||||||
|
|
||||||
// merge the exports of the request file with the exports of this file
|
// merge the exports of the request file with the exports of this file
|
||||||
declare var exports;
|
declare var exports;
|
||||||
require("utils/module-merge").merge(httpRequest, exports);
|
require("utils/module-merge").merge(httpRequest, exports);
|
||||||
@ -27,233 +23,7 @@ export function getImage(arg: any): Promise<image.ImageSource> {
|
|||||||
return new Promise<image.ImageSource>((resolve, reject) => {
|
return new Promise<image.ImageSource>((resolve, reject) => {
|
||||||
httpRequest.request(typeof arg === "string" ? { url: arg, method: "GET" } : arg)
|
httpRequest.request(typeof arg === "string" ? { url: arg, method: "GET" } : arg)
|
||||||
.then(r => {
|
.then(r => {
|
||||||
r.content.toImage().then(source => resolve(source));
|
r.content.toImage().then(source => resolve(source));
|
||||||
}, e => reject(e));
|
}, e => reject(e));
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
export class XMLHttpRequest {
|
|
||||||
public UNSENT = 0;
|
|
||||||
public OPENED = 1;
|
|
||||||
public HEADERS_RECEIVED = 2;
|
|
||||||
public LOADING = 3;
|
|
||||||
public DONE = 4;
|
|
||||||
|
|
||||||
public onload: () => void;
|
|
||||||
public onerror: () => void;
|
|
||||||
|
|
||||||
private _options: definition.HttpRequestOptions;
|
|
||||||
private _readyState: number;
|
|
||||||
private _status: number;
|
|
||||||
private _response: any;
|
|
||||||
private _responseText: string = "";
|
|
||||||
private _headers: any;
|
|
||||||
private _errorFlag: boolean;
|
|
||||||
private _responseType: string;
|
|
||||||
|
|
||||||
public onreadystatechange: Function;
|
|
||||||
|
|
||||||
constructor() {
|
|
||||||
this._readyState = this.UNSENT;
|
|
||||||
}
|
|
||||||
|
|
||||||
public open(method: string, url: string, async?: boolean, user?: string, password?: string) {
|
|
||||||
if (types.isString(method) && types.isString(url)) {
|
|
||||||
this._options = { url: url, method: method };
|
|
||||||
this._options.headers = {};
|
|
||||||
|
|
||||||
if (types.isString(user)) {
|
|
||||||
this._options.headers["user"] = user;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (types.isString(password)) {
|
|
||||||
this._options.headers["password"] = password;
|
|
||||||
}
|
|
||||||
|
|
||||||
this._setReadyState(this.OPENED);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public abort() {
|
|
||||||
this._errorFlag = true;
|
|
||||||
|
|
||||||
this._response = null;
|
|
||||||
this._responseText = null;
|
|
||||||
this._headers = null;
|
|
||||||
this._status = null;
|
|
||||||
|
|
||||||
if (this._readyState === this.UNSENT || this._readyState === this.OPENED || this._readyState === this.DONE) {
|
|
||||||
this._readyState = this.UNSENT;
|
|
||||||
} else {
|
|
||||||
this._setReadyState(this.DONE);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public send(data?: string) {
|
|
||||||
this._errorFlag = false;
|
|
||||||
this._response = null;
|
|
||||||
this._responseText = null;
|
|
||||||
this._headers = null;
|
|
||||||
this._status = null;
|
|
||||||
|
|
||||||
if (types.isDefined(this._options)) {
|
|
||||||
if (types.isString(data)) {
|
|
||||||
this._options.content = data;
|
|
||||||
}
|
|
||||||
|
|
||||||
httpRequest.request(this._options).then(r=> {
|
|
||||||
if (!this._errorFlag) {
|
|
||||||
this._status = r.statusCode;
|
|
||||||
this._response = r.content.raw;
|
|
||||||
|
|
||||||
this._headers = r.headers;
|
|
||||||
this._setReadyState(this.HEADERS_RECEIVED);
|
|
||||||
|
|
||||||
this._setReadyState(this.LOADING);
|
|
||||||
|
|
||||||
this._responseText = r.content.toString();
|
|
||||||
this._setReadyState(this.DONE);
|
|
||||||
}
|
|
||||||
|
|
||||||
}).catch(e => {
|
|
||||||
this._errorFlag = true;
|
|
||||||
this._setReadyState(this.DONE);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public setRequestHeader(header: string, value: string) {
|
|
||||||
if (types.isDefined(this._options) && types.isString(header) && types.isString(value)) {
|
|
||||||
this._options.headers[header] = value;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public getAllResponseHeaders(): string {
|
|
||||||
if (this._readyState < 2 || this._errorFlag) {
|
|
||||||
return "";
|
|
||||||
}
|
|
||||||
|
|
||||||
var result = "";
|
|
||||||
|
|
||||||
for (var i in this._headers) {
|
|
||||||
// Cookie headers are excluded
|
|
||||||
if (i !== "set-cookie" && i !== "set-cookie2") {
|
|
||||||
result += i + ": " + this._headers[i] + "\r\n";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return result.substr(0, result.length - 2);
|
|
||||||
}
|
|
||||||
|
|
||||||
public getResponseHeader(header: string): string {
|
|
||||||
if (types.isString(header) && this._readyState > 1
|
|
||||||
&& this._headers
|
|
||||||
&& this._headers[header]
|
|
||||||
&& !this._errorFlag
|
|
||||||
) {
|
|
||||||
return this._headers[header];
|
|
||||||
}
|
|
||||||
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
public overrideMimeType(mime: string) {
|
|
||||||
//
|
|
||||||
}
|
|
||||||
|
|
||||||
get readyState(): number {
|
|
||||||
return this._readyState;
|
|
||||||
}
|
|
||||||
|
|
||||||
public get responseType(): string {
|
|
||||||
return this._responseType;
|
|
||||||
}
|
|
||||||
|
|
||||||
public set responseType(value: string) {
|
|
||||||
if (value === "" || value === "text") {
|
|
||||||
this._responseType = value;
|
|
||||||
} else {
|
|
||||||
throw new Error(`Response type of '${value}' not supported.`);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private _setReadyState(value: number) {
|
|
||||||
if (this._readyState !== value) {
|
|
||||||
this._readyState = value;
|
|
||||||
|
|
||||||
if (types.isFunction(this.onreadystatechange)) {
|
|
||||||
this.onreadystatechange();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (this._readyState === this.DONE) {
|
|
||||||
if (this._errorFlag && types.isFunction(this.onerror)) {
|
|
||||||
this.onerror();
|
|
||||||
}
|
|
||||||
if (!this._errorFlag && types.isFunction(this.onload)) {
|
|
||||||
this.onload();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
get responseText(): string {
|
|
||||||
return this._responseText;
|
|
||||||
}
|
|
||||||
|
|
||||||
get response(): any {
|
|
||||||
return this._response;
|
|
||||||
}
|
|
||||||
|
|
||||||
get status(): number {
|
|
||||||
return this._status;
|
|
||||||
}
|
|
||||||
|
|
||||||
get statusText(): string {
|
|
||||||
if (this._readyState === this.UNSENT || this._readyState === this.OPENED || this._errorFlag) {
|
|
||||||
return "";
|
|
||||||
}
|
|
||||||
return this._status + " " + statuses[this._status];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
var statuses = {
|
|
||||||
100: "Continue",
|
|
||||||
101: "Switching Protocols",
|
|
||||||
200: "OK",
|
|
||||||
201: "Created",
|
|
||||||
202: "Accepted",
|
|
||||||
203: "Non - Authoritative Information",
|
|
||||||
204: "No Content",
|
|
||||||
205: "Reset Content",
|
|
||||||
206: "Partial Content",
|
|
||||||
300: "Multiple Choices",
|
|
||||||
301: "Moved Permanently",
|
|
||||||
302: "Found",
|
|
||||||
303: "See Other",
|
|
||||||
304: "Not Modified",
|
|
||||||
305: "Use Proxy",
|
|
||||||
307: "Temporary Redirect",
|
|
||||||
400: "Bad Request",
|
|
||||||
401: "Unauthorized",
|
|
||||||
402: "Payment Required",
|
|
||||||
403: "Forbidden",
|
|
||||||
404: "Not Found",
|
|
||||||
405: "Method Not Allowed",
|
|
||||||
406: "Not Acceptable",
|
|
||||||
407: "Proxy Authentication Required",
|
|
||||||
408: "Request Timeout",
|
|
||||||
409: "Conflict",
|
|
||||||
410: "Gone",
|
|
||||||
411: "Length Required",
|
|
||||||
412: "Precondition Failed",
|
|
||||||
413: "Request Entity Too Large",
|
|
||||||
414: "Request - URI Too Long",
|
|
||||||
415: "Unsupported Media Type",
|
|
||||||
416: "Requested Range Not Satisfiable",
|
|
||||||
417: "Expectation Failed",
|
|
||||||
500: "Internal Server Error",
|
|
||||||
501: "Not Implemented",
|
|
||||||
502: "Bad Gateway",
|
|
||||||
503: "Service Unavailable",
|
|
||||||
504: "Gateway Timeout",
|
|
||||||
505: "HTTP Version Not Supported"
|
|
||||||
};
|
|
1
xhr/Readme.md
Normal file
1
xhr/Readme.md
Normal file
@ -0,0 +1 @@
|
|||||||
|
XMLHttpRequest Level 2: https://xhr.spec.whatwg.org/
|
2
xhr/package.json
Normal file
2
xhr/package.json
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
{ "name" : "xhr",
|
||||||
|
"main" : "xhr.js" }
|
228
xhr/xhr.ts
Normal file
228
xhr/xhr.ts
Normal file
@ -0,0 +1,228 @@
|
|||||||
|
import http = require("http");
|
||||||
|
import types = require("utils/types");
|
||||||
|
|
||||||
|
export class XMLHttpRequest {
|
||||||
|
public UNSENT = 0;
|
||||||
|
public OPENED = 1;
|
||||||
|
public HEADERS_RECEIVED = 2;
|
||||||
|
public LOADING = 3;
|
||||||
|
public DONE = 4;
|
||||||
|
|
||||||
|
public onload: () => void;
|
||||||
|
public onerror: () => void;
|
||||||
|
|
||||||
|
private _options: http.HttpRequestOptions;
|
||||||
|
private _readyState: number;
|
||||||
|
private _status: number;
|
||||||
|
private _response: any;
|
||||||
|
private _responseText: string = "";
|
||||||
|
private _headers: any;
|
||||||
|
private _errorFlag: boolean;
|
||||||
|
private _responseType: string = "";
|
||||||
|
|
||||||
|
public onreadystatechange: Function;
|
||||||
|
|
||||||
|
constructor() {
|
||||||
|
this._readyState = this.UNSENT;
|
||||||
|
}
|
||||||
|
|
||||||
|
public open(method: string, url: string, async?: boolean, user?: string, password?: string) {
|
||||||
|
if (types.isString(method) && types.isString(url)) {
|
||||||
|
this._options = { url: url, method: method };
|
||||||
|
this._options.headers = {};
|
||||||
|
|
||||||
|
if (types.isString(user)) {
|
||||||
|
this._options.headers["user"] = user;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (types.isString(password)) {
|
||||||
|
this._options.headers["password"] = password;
|
||||||
|
}
|
||||||
|
|
||||||
|
this._setReadyState(this.OPENED);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public abort() {
|
||||||
|
this._errorFlag = true;
|
||||||
|
|
||||||
|
this._response = null;
|
||||||
|
this._responseText = null;
|
||||||
|
this._headers = null;
|
||||||
|
this._status = null;
|
||||||
|
|
||||||
|
if (this._readyState === this.UNSENT || this._readyState === this.OPENED || this._readyState === this.DONE) {
|
||||||
|
this._readyState = this.UNSENT;
|
||||||
|
} else {
|
||||||
|
this._setReadyState(this.DONE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public send(data?: string) {
|
||||||
|
this._errorFlag = false;
|
||||||
|
this._response = null;
|
||||||
|
this._responseText = null;
|
||||||
|
this._headers = null;
|
||||||
|
this._status = null;
|
||||||
|
|
||||||
|
if (types.isDefined(this._options)) {
|
||||||
|
if (types.isString(data)) {
|
||||||
|
this._options.content = data;
|
||||||
|
}
|
||||||
|
|
||||||
|
http.request(this._options).then(r=> {
|
||||||
|
if (!this._errorFlag) {
|
||||||
|
this._status = r.statusCode;
|
||||||
|
this._response = r.content.raw;
|
||||||
|
|
||||||
|
this._headers = r.headers;
|
||||||
|
this._setReadyState(this.HEADERS_RECEIVED);
|
||||||
|
|
||||||
|
this._setReadyState(this.LOADING);
|
||||||
|
|
||||||
|
this._responseText = r.content.toString();
|
||||||
|
this._setReadyState(this.DONE);
|
||||||
|
}
|
||||||
|
|
||||||
|
}).catch(e => {
|
||||||
|
this._errorFlag = true;
|
||||||
|
this._setReadyState(this.DONE);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public setRequestHeader(header: string, value: string) {
|
||||||
|
if (types.isDefined(this._options) && types.isString(header) && types.isString(value)) {
|
||||||
|
this._options.headers[header] = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public getAllResponseHeaders(): string {
|
||||||
|
if (this._readyState < 2 || this._errorFlag) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
var result = "";
|
||||||
|
|
||||||
|
for (var i in this._headers) {
|
||||||
|
// Cookie headers are excluded
|
||||||
|
if (i !== "set-cookie" && i !== "set-cookie2") {
|
||||||
|
result += i + ": " + this._headers[i] + "\r\n";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return result.substr(0, result.length - 2);
|
||||||
|
}
|
||||||
|
|
||||||
|
public getResponseHeader(header: string): string {
|
||||||
|
if (types.isString(header) && this._readyState > 1
|
||||||
|
&& this._headers
|
||||||
|
&& this._headers[header]
|
||||||
|
&& !this._errorFlag
|
||||||
|
) {
|
||||||
|
return this._headers[header];
|
||||||
|
}
|
||||||
|
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public overrideMimeType(mime: string) {
|
||||||
|
//
|
||||||
|
}
|
||||||
|
|
||||||
|
get readyState(): number {
|
||||||
|
return this._readyState;
|
||||||
|
}
|
||||||
|
|
||||||
|
public get responseType(): string {
|
||||||
|
return this._responseType;
|
||||||
|
}
|
||||||
|
|
||||||
|
public set responseType(value: string) {
|
||||||
|
if (value === "" || value === "text") {
|
||||||
|
this._responseType = value;
|
||||||
|
} else {
|
||||||
|
throw new Error(`Response type of '${value}' not supported.`);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private _setReadyState(value: number) {
|
||||||
|
if (this._readyState !== value) {
|
||||||
|
this._readyState = value;
|
||||||
|
|
||||||
|
if (types.isFunction(this.onreadystatechange)) {
|
||||||
|
this.onreadystatechange();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this._readyState === this.DONE) {
|
||||||
|
if (this._errorFlag && types.isFunction(this.onerror)) {
|
||||||
|
this.onerror();
|
||||||
|
}
|
||||||
|
if (!this._errorFlag && types.isFunction(this.onload)) {
|
||||||
|
this.onload();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
get responseText(): string {
|
||||||
|
return this._responseText;
|
||||||
|
}
|
||||||
|
|
||||||
|
get response(): any {
|
||||||
|
return this._response;
|
||||||
|
}
|
||||||
|
|
||||||
|
get status(): number {
|
||||||
|
return this._status;
|
||||||
|
}
|
||||||
|
|
||||||
|
get statusText(): string {
|
||||||
|
if (this._readyState === this.UNSENT || this._readyState === this.OPENED || this._errorFlag) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
return this._status + " " + statuses[this._status];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var statuses = {
|
||||||
|
100: "Continue",
|
||||||
|
101: "Switching Protocols",
|
||||||
|
200: "OK",
|
||||||
|
201: "Created",
|
||||||
|
202: "Accepted",
|
||||||
|
203: "Non - Authoritative Information",
|
||||||
|
204: "No Content",
|
||||||
|
205: "Reset Content",
|
||||||
|
206: "Partial Content",
|
||||||
|
300: "Multiple Choices",
|
||||||
|
301: "Moved Permanently",
|
||||||
|
302: "Found",
|
||||||
|
303: "See Other",
|
||||||
|
304: "Not Modified",
|
||||||
|
305: "Use Proxy",
|
||||||
|
307: "Temporary Redirect",
|
||||||
|
400: "Bad Request",
|
||||||
|
401: "Unauthorized",
|
||||||
|
402: "Payment Required",
|
||||||
|
403: "Forbidden",
|
||||||
|
404: "Not Found",
|
||||||
|
405: "Method Not Allowed",
|
||||||
|
406: "Not Acceptable",
|
||||||
|
407: "Proxy Authentication Required",
|
||||||
|
408: "Request Timeout",
|
||||||
|
409: "Conflict",
|
||||||
|
410: "Gone",
|
||||||
|
411: "Length Required",
|
||||||
|
412: "Precondition Failed",
|
||||||
|
413: "Request Entity Too Large",
|
||||||
|
414: "Request - URI Too Long",
|
||||||
|
415: "Unsupported Media Type",
|
||||||
|
416: "Requested Range Not Satisfiable",
|
||||||
|
417: "Expectation Failed",
|
||||||
|
500: "Internal Server Error",
|
||||||
|
501: "Not Implemented",
|
||||||
|
502: "Bad Gateway",
|
||||||
|
503: "Service Unavailable",
|
||||||
|
504: "Gateway Timeout",
|
||||||
|
505: "HTTP Version Not Supported"
|
||||||
|
};
|
Reference in New Issue
Block a user