mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-27 04:39:37 +00:00
4b8580917e
- some pref. cleanup (21e17660e7) - add some font names and aliases (cb38962246) - remove unused dom.max_child_script_run_time (d214b353d4) - align strange layout.css.scroll-snap.enabled overwrite (f2562a5cc1) - reshuffle some preferences, remove unused (41f586186b) - more reshuffle and cleanup of preferences (0208aa32a3) - Bug 1168891 Part 1 - Refine two functions related to caret positioning. r=mats (86d718d60e) - Bug 1168891 Part 2 - Allow one caret to be dragged across the other caret. r=mats (9276eb7728) - part of Bug 1252802 - Web page scrolls when dragging caret in editable, r=snorp (31dade8b77) - Bug 1235508 - Re-implement fast Phone number selection on long-press, r=TYLin (59b6371d17) - Bug 1249201 Part 1 - Add "scroll" reason to CaretStateChangedEvent. r=smaug (b92ff6cbfc) - Bug 1249201 Part 2 - Show carets continuously when panning or zooming. r=mats,sebastian (ca5c51c479) - Bug 1245246: Add null check for mDocViewerPrint in nsPrintEngine::FirePrintingErrorEvent. r=roc (e9d5b49a3f) - Bug 1025267 - Make some -moz- prefixed pseudo-classes chrome-only. r=bz (238f7a85d4) - Bug 1259889 Part 1 - Add @supports -moz-bool-pref for internal-only style sheets. r=heycam (d716a7b884) - Bug 1237633 - Part 1: Percentages are not allowed in a <source-size-value>. r=jdm (52ccffbf86) - Bug 1081362 - Change nsStyleBasicShape pointer to an nsRefPtr, to avoid leak in unexpected case. r=dholbert (2a5cb8ffdd) - Bug 1264317 - Make the basic shape clip-path clipping use nsCSSValue::Array instead of nsCSSValueList. r=dholbert (7aaf39f2d7) - Bug 1247150 - Consistently use StyleSheetHandle::RefPtr* for outparams in nsLayoutStylesheetCache. r=dholbert (ddc85f29f8) - Bug 1251848: Check StyleSheetHandles for being null-flavored before derefing them, in assertions within nsLayoutStylesheetCache::InvalidateSheet. r=bholley (edb3924075) - Bug 1245260 - Add crashtest; r=hiro (6347e37750) - Bug 460209 - Add crashtest. (97b4786de2) - Bug 474377 - Add crashtest. (516b4e8164) - Bug 1264396 - Don't allow animation of 'display' property; r=heycam (6e94bcb26a) - missing bit of 759568 - Part 1 (fc954f075b) - part of Bug 1037483 replace microdata with microformats (4ff01e11d6) - Bug 1245334 - Make PromiseMessage.jsm ids more meaningful. r=baku (913ac1b9a5) - Bug 1094201 - Implement an Integration.jsm module for low-overhead registration of overrides. r=mak (9982624b90) - Bug 1167663 - Mark nsCSSKeyframeStyleDeclaration/nsCSSPageStyleDeclaration::mRule as MOZ_NON_OWNING_REF. r=dbaron (6d4e9751a1) - Bug 1244992 - Avoid double-counting in various refcounted types related to nsCSSValue. r=heycam. (c830949dd9) - Bug 1262646 - Change the outparams passed to nsStyleUtil::AppendEscapedCSSString from nsString to nsAutoString. r=dholbert (2b0caadf9d) - Bug 1247336 - De-dupe changes in ActiveLayerTracker before treating property as animated. r=roc (c44ed5aee6) - space fix (5e79d245ea) - Bug 1266288 - Track changes to all margin properties for scroll-linked effects. r=mstange (fed6994e4d) - Bug 1259641 - Do not force reflow for all tabs when size mode changed. r=smaug (70847cc6d2) - Bug 1261265 - Fix nsStyleContext::MoveTo flag assertions to allow mismatch on parents if bit is set on child. r=dholbert (3e6b08372e) - Bug 1264837 Part 43 - Remove SVGFEUnstyledLeafFrameBase. r=dholbert (bb55feda77) - Remove mention of old SVG text pref in comment; no bug. (DONTBUILD) (3a618aca18) - Bug 752638, part 1 - Move SVGTextFrame::SetupContextPaint to nsSVGUtils. r=heycam (c125c2903f) - Bug 1258843 - Don't build SVG display items if their visibility is hidden. r=dholbert (150c3b0059) - Bug 1258650. Properly use aExtraMasksTransform when combining masks. r=Bas,a=kwierso (ba5ea1928b) - Bug 1263789 - Stop nsSVGMaskFrameNEON.h from polluting the global namespace. r=dholbert (e2c8544d35) - Bug 1162418 - Try to find a suitable non-zero dimension to use when containing block's inline-size depends on an SVG element which is specified as a percentage of its container. r=jwatt (3eab79c8a4) - Bug 1250143. Account for border/padding on outer <svg> elements in GeometryUtils. r=mats (f307820b75) - Bug 1243623. Don't skip unregistering a table part if we have a split table. r=mats (35bb0821c1) - Bug 1203417. Propagate error result from PaintTableFrame. r=seth (866e47b3e4) - Bug 1209780. Propagate the use of MOZ_MUST_USE DrawResult in nsTablePainter. r=seth (851618d06c) - var-const (29d5e9f859) - Bug 1209780. Propagate the use of MOZ_MUST_USE DrawResult in nsTreeBodyFrame::PaintText. r=seth (1ce563ea18) - Bug 1203626 - remove the unused argument from nsTreeBodyFrame::GetTwistyRect. r=mattwoodrow (03293f52b5) - Bug 1218041, part 1: Give nsTreeBodyFrame::PaintImage a fallback codepath for painting SVG images with no explicit height or width. r=seth (b6fd3a39f7) - Bug 1218041, part 2: add reftests for <treecell> SVG-image rendering. (no review) (90231e0bfa) - Bug 1224736: When image size lookup fails in nsTreeBodyFrame::PaintImage, only fall back to use the full destRect if we've got a VectorImage. r=tn (dd7d7667ca) - Bug 1156108 - Make nsTreeColumns::mFirstColumn an nsRefPtr; r=roc (f6888480bc) - Bug 1255069 - use UniquePtr for storage in nsTreeContentView; r=dholbert (598256735f) - Bug 1181560 - ensure previous menus get closed when opening new ones, r=Enn (2c88f3452a) - Bug 1192655 - Make menubar not react to events when it is not visible. r=enn (2bbcbc81a2) - Bug 1197913 - Keep the last hovered item highlighted after moving the cursor outside the <select> drop-down list on Windows. r=neil (abd3240473) - Bug 1228029 - Fix the usage of gtest assertion macros in TestJobScheduler.cpp. r=kats (0fcc9aa6fe) - Bug 1244234 - Simplify joining jobs with the gfx job scheduler. r=jrmuizel (f4b6bbf418) - Bug 1239288 - Add a shutdown test to the gfx job scheduler. r=jrmuizel (fd2432d108) - Bug 1239288 - Fix a race in the win32 job scheduler's shutdown. r=jrmuizel (4e509b4bf3) - Bug 1241161 - make Matrix4x4::ProjectTo2D normalize out perpective where possible. r=mattwoodrow (5a68e396a3) - bits of Bug 1135138 - Remove UNICODE from DEFINES (1eb51a0a79) - Bug 1249640: Part 4 Android to use new blocking. r=snorp (855e5c0dda) - Bug 1234875 - Remove alwaysAcceptSessionCookies pref. r=mak (8bed323449) - Bug 1247912 - convert left side expression to int64_t when assigning to mCookiesLifetimeSec in order to avoid overflow. r=jdm (0cedb68c83) - code and comment style (9215d74a8f) - code and comment style (1d4cda31af) - Bug 1219928 - Skip misspelled words in style blocks. r=enndeakin. (91dd0bcedf) - Bug 1236968 - autodial telemetry r=mayhemer (3844b9c19e) - Bug 1254310 - Add a hidden pref to temporarily disable Safe Browsing on given hostnames. r=gcp (4955fc88f8) - Bug 772528 - Remove nsFileInputStream::Seek() from nsPartialFileInputStream::Init(). r=baku (15db900fb5) - Bug 1150921 - Add telemetry for response codes to SafeBrowsing requests. r=francois f=bsmedberg (215d50e4ad) - Bug 1164518 - Better logging of completions. r=gcp (95b4fe3731) - Bug 1172688 - Add telemetry for when gethash calls timeout. r=francois, r=bsmedberg (b94a2b38a7) - Bug 1266184 - Implement nsIMIMEInputStream.data getter. r=mcmanus (8c9159c030) - Bug 1239955 - Let DNSService rely on IOService::Offline, r=bagder (336f161d21) - Bug 1260407 - added logging for proxy/pac to aid debugging, r=mcmanus (a179275ca6) - Bug 1259089 - Set TCP socket to non-blocking in sts again, just to be sure. r=mcmanus (bf0656bf07) - Bug 1256473 - Cast values to avoid C4838 on VS2015; r=mayhemer (d4b138dba8) - Bug 1260764 - Creation of PollableEvent needs a lock r=dragana a=kwierso (01c9d5e477) - Bug 652186 - Implement URL Standard's backslash replacement r=mcmanus (6485fa7e8c) - Bug 1042347 - %2e entered in URL bar not normalized leading to denormalized request r=mcmanus (3fc1ff92cd) - Bug 377052 - nsBaseURLParser::ParseURL doesn't handle spaces embedded in the scheme properly r=mcmanus (1f54055b9d) - fix editor format (444d6a62c4) - Bug 1154124 - Prevent recursion when calling HTTP cache entry's callbacks. r=michal (7bdfbf603d) - Bug 1247644 - Don't do any I/O on doomed and unused HTTP cache entries, r=michal (7668d29a36)
239 lines
7.3 KiB
JavaScript
239 lines
7.3 KiB
JavaScript
/* Any copyright is dedicated to the Public Domain.
|
|
* http://creativecommons.org/publicdomain/zero/1.0/ */
|
|
|
|
/*
|
|
* Tests the Integration.jsm module.
|
|
*/
|
|
|
|
"use strict";
|
|
|
|
const { classes: Cc, interfaces: Ci, utils: Cu, results: Cr } = Components;
|
|
|
|
Cu.import("resource://gre/modules/Integration.jsm", this);
|
|
Cu.import("resource://gre/modules/Services.jsm", this);
|
|
Cu.import("resource://gre/modules/Task.jsm", this);
|
|
|
|
const TestIntegration = {
|
|
value: "value",
|
|
|
|
get valueFromThis() {
|
|
return this.value;
|
|
},
|
|
|
|
get property() {
|
|
return this._property;
|
|
},
|
|
|
|
set property(value) {
|
|
this._property = value;
|
|
},
|
|
|
|
method(argument) {
|
|
this.methodArgument = argument;
|
|
return "method" + argument;
|
|
},
|
|
|
|
asyncMethod: Task.async(function* (argument) {
|
|
this.asyncMethodArgument = argument;
|
|
return "asyncMethod" + argument;
|
|
}),
|
|
};
|
|
|
|
let overrideFn = base => ({
|
|
value: "overridden-value",
|
|
|
|
get property() {
|
|
return "overridden-" + base.__lookupGetter__("property").call(this);
|
|
},
|
|
|
|
set property(value) {
|
|
base.__lookupSetter__("property").call(this, "overridden-" + value);
|
|
},
|
|
|
|
method() {
|
|
return "overridden-" + base.method.apply(this, arguments);
|
|
},
|
|
|
|
asyncMethod: Task.async(function* () {
|
|
return "overridden-" + (yield base.asyncMethod.apply(this, arguments));
|
|
}),
|
|
});
|
|
|
|
let superOverrideFn = base => ({
|
|
__proto__: base,
|
|
|
|
value: "overridden-value",
|
|
|
|
get property() {
|
|
return "overridden-" + super.property;
|
|
},
|
|
|
|
set property(value) {
|
|
super.property = "overridden-" + value;
|
|
},
|
|
|
|
method() {
|
|
return "overridden-" + super.method(...arguments);
|
|
},
|
|
|
|
asyncMethod: Task.async(function* () {
|
|
// We cannot use the "super" keyword in methods defined using "Task.async".
|
|
return "overridden-" + (yield base.asyncMethod.apply(this, arguments));
|
|
}),
|
|
});
|
|
|
|
/**
|
|
* Fails the test if the results of method invocations on the combined object
|
|
* don't match the expected results based on how many overrides are registered.
|
|
*
|
|
* @param combined
|
|
* The combined object based on the TestIntegration root.
|
|
* @param overridesCount
|
|
* Zero if the root object is not overridden, or a higher value to test
|
|
* the presence of one or more integration overrides.
|
|
*/
|
|
function* assertCombinedResults(combined, overridesCount) {
|
|
let expectedValue = overridesCount > 0 ? "overridden-value" : "value";
|
|
let prefix = "overridden-".repeat(overridesCount);
|
|
|
|
Assert.equal(combined.value, expectedValue);
|
|
Assert.equal(combined.valueFromThis, expectedValue);
|
|
|
|
combined.property = "property";
|
|
Assert.equal(combined.property, prefix.repeat(2) + "property");
|
|
|
|
combined.methodArgument = "";
|
|
Assert.equal(combined.method("-argument"), prefix + "method-argument");
|
|
Assert.equal(combined.methodArgument, "-argument");
|
|
|
|
combined.asyncMethodArgument = "";
|
|
Assert.equal(yield combined.asyncMethod("-argument"),
|
|
prefix + "asyncMethod-argument");
|
|
Assert.equal(combined.asyncMethodArgument, "-argument");
|
|
}
|
|
|
|
/**
|
|
* Fails the test if the results of method invocations on the combined object
|
|
* for the "testModule" integration point don't match the expected results based
|
|
* on how many overrides are registered.
|
|
*
|
|
* @param overridesCount
|
|
* Zero if the root object is not overridden, or a higher value to test
|
|
* the presence of one or more integration overrides.
|
|
*/
|
|
function* assertCurrentCombinedResults(overridesCount) {
|
|
let combined = Integration.testModule.getCombined(TestIntegration);
|
|
yield assertCombinedResults(combined, overridesCount);
|
|
}
|
|
|
|
/**
|
|
* Checks the initial state with no integration override functions registered.
|
|
*/
|
|
add_task(function* test_base() {
|
|
yield assertCurrentCombinedResults(0);
|
|
});
|
|
|
|
/**
|
|
* Registers and unregisters an integration override function.
|
|
*/
|
|
add_task(function* test_override() {
|
|
Integration.testModule.register(overrideFn);
|
|
yield assertCurrentCombinedResults(1);
|
|
|
|
// Registering the same function more than once has no effect.
|
|
Integration.testModule.register(overrideFn);
|
|
yield assertCurrentCombinedResults(1);
|
|
|
|
Integration.testModule.unregister(overrideFn);
|
|
yield assertCurrentCombinedResults(0);
|
|
});
|
|
|
|
/**
|
|
* Registers and unregisters more than one integration override function, of
|
|
* which one uses the prototype and the "super" keyword to access the base.
|
|
*/
|
|
add_task(function* test_override_super_multiple() {
|
|
Integration.testModule.register(overrideFn);
|
|
Integration.testModule.register(superOverrideFn);
|
|
yield assertCurrentCombinedResults(2);
|
|
|
|
Integration.testModule.unregister(overrideFn);
|
|
yield assertCurrentCombinedResults(1);
|
|
|
|
Integration.testModule.unregister(superOverrideFn);
|
|
yield assertCurrentCombinedResults(0);
|
|
});
|
|
|
|
/**
|
|
* Registers an integration override function that throws an exception, and
|
|
* ensures that this does not block other functions from being registered.
|
|
*/
|
|
add_task(function* test_override_error() {
|
|
let errorOverrideFn = base => { throw "Expected error." };
|
|
|
|
Integration.testModule.register(errorOverrideFn);
|
|
Integration.testModule.register(overrideFn);
|
|
yield assertCurrentCombinedResults(1);
|
|
|
|
Integration.testModule.unregister(errorOverrideFn);
|
|
Integration.testModule.unregister(overrideFn);
|
|
yield assertCurrentCombinedResults(0);
|
|
});
|
|
|
|
/**
|
|
* Checks that state saved using the "this" reference is preserved as a shallow
|
|
* copy when registering new integration override functions.
|
|
*/
|
|
add_task(function* test_state_preserved() {
|
|
let valueObject = { toString: () => "toString" };
|
|
|
|
let combined = Integration.testModule.getCombined(TestIntegration);
|
|
combined.property = valueObject;
|
|
Assert.ok(combined.property === valueObject);
|
|
|
|
Integration.testModule.register(overrideFn);
|
|
combined = Integration.testModule.getCombined(TestIntegration);
|
|
Assert.equal(combined.property, "overridden-toString");
|
|
|
|
Integration.testModule.unregister(overrideFn);
|
|
combined = Integration.testModule.getCombined(TestIntegration);
|
|
Assert.ok(combined.property === valueObject);
|
|
});
|
|
|
|
/**
|
|
* Checks that the combined integration objects cannot be used with XPCOM.
|
|
*
|
|
* This is limited by the fact that interfaces with the "[function]" annotation,
|
|
* for example nsIObserver, do not call the QueryInterface implementation.
|
|
*/
|
|
add_task(function* test_xpcom_throws() {
|
|
let combined = Integration.testModule.getCombined(TestIntegration);
|
|
|
|
// This calls QueryInterface because it looks for nsISupportsWeakReference.
|
|
Assert.throws(() => Services.obs.addObserver(combined, "test-topic", true),
|
|
"NS_NOINTERFACE");
|
|
});
|
|
|
|
/**
|
|
* Checks that getters defined by defineModuleGetter are able to retrieve the
|
|
* latest version of the combined integration object.
|
|
*/
|
|
add_task(function* test_defineModuleGetter() {
|
|
let objectForGetters = {};
|
|
|
|
// Test with and without the optional "symbol" parameter.
|
|
Integration.testModule.defineModuleGetter(objectForGetters,
|
|
"TestIntegration", "resource://testing-common/TestIntegration.jsm");
|
|
Integration.testModule.defineModuleGetter(objectForGetters,
|
|
"integration", "resource://testing-common/TestIntegration.jsm",
|
|
"TestIntegration");
|
|
|
|
Integration.testModule.register(overrideFn);
|
|
yield assertCombinedResults(objectForGetters.integration, 1);
|
|
yield assertCombinedResults(objectForGetters.TestIntegration, 1);
|
|
|
|
Integration.testModule.unregister(overrideFn);
|
|
yield assertCombinedResults(objectForGetters.integration, 0);
|
|
yield assertCombinedResults(objectForGetters.TestIntegration, 0);
|
|
});
|