@sapui5/sap.fe.test 1.112.0 → 1.114.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +1 -1
- package/src/sap/fe/test/.library +1 -1
- package/src/sap/fe/test/JestTemplatingHelper.js +62 -7
- package/src/sap/fe/test/JestTemplatingHelper.ts +62 -10
- package/src/sap/fe/test/api/FormAPI.js +5 -12
- package/src/sap/fe/test/api/HeaderAssertions.js +18 -0
- package/src/sap/fe/test/api/TableAssertions.js +1 -4
- package/src/sap/fe/test/builder/MdcTableBuilder.js +2 -2
- package/src/sap/fe/test/internal/ConsoleErrorChecker.js +2 -4
- package/src/sap/fe/test/internal/ConsoleErrorChecker.ts +1 -2
- package/src/sap/fe/test/library-preload.js +90 -29
- package/src/sap/fe/test/library-preload.js.map +1 -1
- package/src/sap/fe/test/library.js +1 -1
- package/src/sap/fe/test/manifest.json +1 -1
|
@@ -16,9 +16,7 @@ sap.ui.define([], function () {
|
|
|
16
16
|
/**
|
|
17
17
|
* List of error message patterns that are always accepted.
|
|
18
18
|
*/
|
|
19
|
-
const GLOBALLY_ACCEPTED_ERRORS = ["failed to load JavaScript resource: sap/esh/search/ui/i18n.js"
|
|
20
|
-
// shell
|
|
21
|
-
"Custom attributes are not exist" // accept console error temporarily - remove as soon as unified shell ticket is resolved
|
|
19
|
+
const GLOBALLY_ACCEPTED_ERRORS = ["failed to load JavaScript resource: sap/esh/search/ui/i18n.js" // shell
|
|
22
20
|
].map(wrapPatterns);
|
|
23
21
|
let ConsoleErrorChecker = /*#__PURE__*/function () {
|
|
24
22
|
function ConsoleErrorChecker(window) {
|
|
@@ -193,4 +191,4 @@ sap.ui.define([], function () {
|
|
|
193
191
|
}();
|
|
194
192
|
return ConsoleErrorChecker.getInstance(window);
|
|
195
193
|
}, false);
|
|
196
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["wrapPatterns","pattern","RegExp","message","match","includes","GLOBALLY_ACCEPTED_ERRORS","map","ConsoleErrorChecker","window","matchers","messages","observer","MutationObserver","mutations","opaFrame","reduce","iFrame","mutation","node","Array","from","addedNodes","Element","element","querySelector","HTMLIFrameElement","contentWindow","prepareWindow","QUnit","moduleStart","observe","document","body","childList","moduleDone","disconnect","testStart","reset","log","handleFailedMessages","karma","__karma__","search","URLSearchParams","location","urlParam","get","isStrict","config","ui5","strictconsoleerrors","failedMessages","length","assert","pushResult","result","source","actual","expected","setAcceptedErrorPatterns","patterns","concat","checkAndLog","type","data","messageText","isAllowed","some","matcher","push","wrappedData","d","console","patchConsoleMethod","method","fnOriginal","apply","condition","first","unshift","error","onPromiseRejection","event","reason","stack","onError","filename","addEventListener","bind","passive","getInstance","sapFEConsoleErrorChecker"],"sourceRoot":".","sources":["ConsoleErrorChecker.ts"],"sourcesContent":["import type { BrowserConsoleLogOptions } from \"karma\";\n\ntype MessageMatcherFunction = (message: string) => boolean;\ntype Karma = {\n\tlog: (level: BrowserConsoleLogOptions[\"level\"], ...data: any[]) => void;\n\tconfig: {\n\t\tui5?: {\n\t\t\tconfig: {\n\t\t\t\tstrictconsoleerrors?: boolean; // Karma options are all lowercase at runtime!\n\t\t\t};\n\t\t};\n\t};\n};\n\nfunction wrapPatterns(pattern: RegExp | string): MessageMatcherFunction {\n\tif (pattern instanceof RegExp) {\n\t\treturn (message) => message.match(pattern) !== null;\n\t} else {\n\t\treturn (message) => message.includes(pattern);\n\t}\n}\n\n/**\n * List of error message patterns that are always accepted.\n */\nconst GLOBALLY_ACCEPTED_ERRORS = [\n\t\"failed to load JavaScript resource: sap/esh/search/ui/i18n.js\", // shell\n\t\"Custom attributes are not exist\" // accept console error temporarily - remove as soon as unified shell ticket is resolved\n].map(wrapPatterns);\n\nclass ConsoleErrorChecker {\n\tprivate matchers: MessageMatcherFunction[] = [];\n\n\tprivate messages: string[] = [];\n\n\tprivate readonly karma: Karma | undefined;\n\n\tprivate readonly isStrict: boolean;\n\n\tprivate readonly observer = new MutationObserver((mutations) => {\n\t\tconst opaFrame = mutations.reduce((iFrame: HTMLIFrameElement | null, mutation: MutationRecord) => {\n\t\t\tif (iFrame !== null) {\n\t\t\t\treturn iFrame;\n\t\t\t}\n\n\t\t\tfor (const node of Array.from(mutation.addedNodes)) {\n\t\t\t\tif (node instanceof Element) {\n\t\t\t\t\tconst element = node.querySelector(\"#OpaFrame\");\n\t\t\t\t\tif (element instanceof HTMLIFrameElement && element.contentWindow) {\n\t\t\t\t\t\treturn element;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn iFrame;\n\t\t}, null);\n\n\t\tif (opaFrame && opaFrame.contentWindow) {\n\t\t\tthis.prepareWindow(opaFrame.contentWindow);\n\t\t}\n\t});\n\n\tconstructor(window: Window & { __karma__?: Karma }) {\n\t\tQUnit.moduleStart(() => {\n\t\t\tthis.observer.observe(window.document.body, { childList: true });\n\t\t});\n\n\t\tQUnit.moduleDone(() => {\n\t\t\tthis.observer.disconnect();\n\t\t});\n\n\t\tQUnit.testStart(() => {\n\t\t\tthis.reset();\n\t\t});\n\n\t\tQUnit.log(() => {\n\t\t\tthis.handleFailedMessages();\n\t\t});\n\n\t\tthis.karma = window.__karma__;\n\n\t\t// either go for Karma config option \"ui5.config.strictConsoleErrors\" or use URL query parameter \"strict\"\n\t\tconst search = new URLSearchParams(window.location.search);\n\t\tconst urlParam = search.get(\"strictConsoleErrors\");\n\t\tif (urlParam !== null) {\n\t\t\tthis.isStrict = urlParam === \"true\";\n\t\t} else {\n\t\t\tthis.isStrict = this.karma?.config.ui5?.config.strictconsoleerrors ?? false;\n\t\t}\n\n\t\tthis.reset();\n\t}\n\n\tprivate handleFailedMessages() {\n\t\tconst failedMessages = this.messages;\n\t\tthis.messages = [];\n\n\t\tif (failedMessages.length > 0) {\n\t\t\tQUnit.assert.pushResult({\n\t\t\t\tresult: false,\n\t\t\t\tsource: \"FE Console Log Check\",\n\t\t\t\tmessage: `There were ${failedMessages.length} unexpected console errors`,\n\t\t\t\tactual: failedMessages,\n\t\t\t\texpected: []\n\t\t\t});\n\t\t}\n\t}\n\n\tprivate reset() {\n\t\tthis.messages = [];\n\n\t\t// this sets the default to apply if no allowed patterns are set via setAcceptedErrorPatterns().\n\t\tif (this.isStrict) {\n\t\t\tthis.matchers = GLOBALLY_ACCEPTED_ERRORS;\n\t\t} else {\n\t\t\tthis.matchers = [() => true];\n\t\t}\n\t}\n\n\tsetAcceptedErrorPatterns(patterns?: (RegExp | string)[]) {\n\t\tif (!patterns || patterns.length === 0) {\n\t\t\tthis.matchers = GLOBALLY_ACCEPTED_ERRORS;\n\t\t} else {\n\t\t\tthis.matchers = patterns.map(wrapPatterns).concat(GLOBALLY_ACCEPTED_ERRORS);\n\t\t}\n\t}\n\n\tprivate checkAndLog(type: BrowserConsoleLogOptions[\"level\"], ...data: any[]) {\n\t\t// only check the error messages\n\t\tif (type === \"error\") {\n\t\t\tconst messageText = data[0];\n\t\t\tconst isAllowed = this.matchers.some((matcher) => matcher(messageText));\n\t\t\tif (!isAllowed) {\n\t\t\t\tthis.messages.push(messageText);\n\t\t\t}\n\t\t}\n\n\t\tif (this.karma) {\n\t\t\t// wrap the data to facilitate parsing in the backend\n\t\t\tconst wrappedData = data.map((d) => [d]);\n\t\t\tthis.karma.log(type, wrappedData);\n\t\t}\n\t}\n\n\tprivate prepareWindow(window: Window) {\n\t\tconst console: Console = (window as any).console;\n\n\t\t// capture console.log(), console.debug(), etc.\n\t\tconst patchConsoleMethod = (method: \"log\" | \"info\" | \"warn\" | \"error\" | \"debug\") => {\n\t\t\tconst fnOriginal = console[method];\n\t\t\tconsole[method] = (...data: any[]): void => {\n\t\t\t\tthis.checkAndLog(method, ...data);\n\t\t\t\treturn fnOriginal.apply(console, data);\n\t\t\t};\n\t\t};\n\n\t\tpatchConsoleMethod(\"log\");\n\t\tpatchConsoleMethod(\"debug\");\n\t\tpatchConsoleMethod(\"info\");\n\t\tpatchConsoleMethod(\"warn\");\n\t\tpatchConsoleMethod(\"error\");\n\n\t\t// capture console.assert()\n\t\t// see https://console.spec.whatwg.org/#assert\n\t\tconsole.assert = function (condition = false, ...data: any[]) {\n\t\t\tif (condition) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tconst message = \"Assertion failed\";\n\t\t\tif (data.length === 0) {\n\t\t\t\tdata.push(message);\n\t\t\t} else {\n\t\t\t\tlet first = data[0];\n\t\t\t\tif (typeof first !== \"string\") {\n\t\t\t\t\tdata.unshift(message);\n\t\t\t\t} else {\n\t\t\t\t\tfirst = `${message}: ${first}`;\n\t\t\t\t\tdata[0] = first;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tconsole.error(...data);\n\t\t};\n\n\t\t// capture errors\n\t\tfunction onPromiseRejection(this: ConsoleErrorChecker, event: PromiseRejectionEvent) {\n\t\t\tconst message = `UNHANDLED PROMISE REJECTION: ${event.reason}`;\n\t\t\tthis.checkAndLog(\"error\", message, event.reason?.stack);\n\t\t}\n\n\t\tfunction onError(this: ConsoleErrorChecker, event: ErrorEvent) {\n\t\t\tconst message = event.message;\n\t\t\tthis.checkAndLog(\"error\", message, event.filename);\n\t\t}\n\n\t\twindow.addEventListener(\"error\", onError.bind(this), { passive: true });\n\t\twindow.addEventListener(\"unhandledrejection\", onPromiseRejection.bind(this), { passive: true });\n\t}\n\n\tstatic getInstance(window: Window & { sapFEConsoleErrorChecker?: ConsoleErrorChecker }): ConsoleErrorChecker {\n\t\t// the global instance is needed to support multiple tests in a row (in Karma)\n\t\tif (!window.sapFEConsoleErrorChecker) {\n\t\t\twindow.sapFEConsoleErrorChecker = new ConsoleErrorChecker(window);\n\t\t}\n\t\treturn window.sapFEConsoleErrorChecker;\n\t}\n}\n\nexport default ConsoleErrorChecker.getInstance(window);\n"],"mappings":"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"}
|
|
194
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["wrapPatterns","pattern","RegExp","message","match","includes","GLOBALLY_ACCEPTED_ERRORS","map","ConsoleErrorChecker","window","matchers","messages","observer","MutationObserver","mutations","opaFrame","reduce","iFrame","mutation","node","Array","from","addedNodes","Element","element","querySelector","HTMLIFrameElement","contentWindow","prepareWindow","QUnit","moduleStart","observe","document","body","childList","moduleDone","disconnect","testStart","reset","log","handleFailedMessages","karma","__karma__","search","URLSearchParams","location","urlParam","get","isStrict","config","ui5","strictconsoleerrors","failedMessages","length","assert","pushResult","result","source","actual","expected","setAcceptedErrorPatterns","patterns","concat","checkAndLog","type","data","messageText","isAllowed","some","matcher","push","wrappedData","d","console","patchConsoleMethod","method","fnOriginal","apply","condition","first","unshift","error","onPromiseRejection","event","reason","stack","onError","filename","addEventListener","bind","passive","getInstance","sapFEConsoleErrorChecker"],"sourceRoot":".","sources":["ConsoleErrorChecker.ts"],"sourcesContent":["import type { BrowserConsoleLogOptions } from \"karma\";\n\ntype MessageMatcherFunction = (message: string) => boolean;\ntype Karma = {\n\tlog: (level: BrowserConsoleLogOptions[\"level\"], ...data: any[]) => void;\n\tconfig: {\n\t\tui5?: {\n\t\t\tconfig: {\n\t\t\t\tstrictconsoleerrors?: boolean; // Karma options are all lowercase at runtime!\n\t\t\t};\n\t\t};\n\t};\n};\n\nfunction wrapPatterns(pattern: RegExp | string): MessageMatcherFunction {\n\tif (pattern instanceof RegExp) {\n\t\treturn (message) => message.match(pattern) !== null;\n\t} else {\n\t\treturn (message) => message.includes(pattern);\n\t}\n}\n\n/**\n * List of error message patterns that are always accepted.\n */\nconst GLOBALLY_ACCEPTED_ERRORS = [\n\t\"failed to load JavaScript resource: sap/esh/search/ui/i18n.js\" // shell\n].map(wrapPatterns);\n\nclass ConsoleErrorChecker {\n\tprivate matchers: MessageMatcherFunction[] = [];\n\n\tprivate messages: string[] = [];\n\n\tprivate readonly karma: Karma | undefined;\n\n\tprivate readonly isStrict: boolean;\n\n\tprivate readonly observer = new MutationObserver((mutations) => {\n\t\tconst opaFrame = mutations.reduce((iFrame: HTMLIFrameElement | null, mutation: MutationRecord) => {\n\t\t\tif (iFrame !== null) {\n\t\t\t\treturn iFrame;\n\t\t\t}\n\n\t\t\tfor (const node of Array.from(mutation.addedNodes)) {\n\t\t\t\tif (node instanceof Element) {\n\t\t\t\t\tconst element = node.querySelector(\"#OpaFrame\");\n\t\t\t\t\tif (element instanceof HTMLIFrameElement && element.contentWindow) {\n\t\t\t\t\t\treturn element;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn iFrame;\n\t\t}, null);\n\n\t\tif (opaFrame && opaFrame.contentWindow) {\n\t\t\tthis.prepareWindow(opaFrame.contentWindow);\n\t\t}\n\t});\n\n\tconstructor(window: Window & { __karma__?: Karma }) {\n\t\tQUnit.moduleStart(() => {\n\t\t\tthis.observer.observe(window.document.body, { childList: true });\n\t\t});\n\n\t\tQUnit.moduleDone(() => {\n\t\t\tthis.observer.disconnect();\n\t\t});\n\n\t\tQUnit.testStart(() => {\n\t\t\tthis.reset();\n\t\t});\n\n\t\tQUnit.log(() => {\n\t\t\tthis.handleFailedMessages();\n\t\t});\n\n\t\tthis.karma = window.__karma__;\n\n\t\t// either go for Karma config option \"ui5.config.strictConsoleErrors\" or use URL query parameter \"strict\"\n\t\tconst search = new URLSearchParams(window.location.search);\n\t\tconst urlParam = search.get(\"strictConsoleErrors\");\n\t\tif (urlParam !== null) {\n\t\t\tthis.isStrict = urlParam === \"true\";\n\t\t} else {\n\t\t\tthis.isStrict = this.karma?.config.ui5?.config.strictconsoleerrors ?? false;\n\t\t}\n\n\t\tthis.reset();\n\t}\n\n\tprivate handleFailedMessages() {\n\t\tconst failedMessages = this.messages;\n\t\tthis.messages = [];\n\n\t\tif (failedMessages.length > 0) {\n\t\t\tQUnit.assert.pushResult({\n\t\t\t\tresult: false,\n\t\t\t\tsource: \"FE Console Log Check\",\n\t\t\t\tmessage: `There were ${failedMessages.length} unexpected console errors`,\n\t\t\t\tactual: failedMessages,\n\t\t\t\texpected: []\n\t\t\t});\n\t\t}\n\t}\n\n\tprivate reset() {\n\t\tthis.messages = [];\n\n\t\t// this sets the default to apply if no allowed patterns are set via setAcceptedErrorPatterns().\n\t\tif (this.isStrict) {\n\t\t\tthis.matchers = GLOBALLY_ACCEPTED_ERRORS;\n\t\t} else {\n\t\t\tthis.matchers = [() => true];\n\t\t}\n\t}\n\n\tsetAcceptedErrorPatterns(patterns?: (RegExp | string)[]) {\n\t\tif (!patterns || patterns.length === 0) {\n\t\t\tthis.matchers = GLOBALLY_ACCEPTED_ERRORS;\n\t\t} else {\n\t\t\tthis.matchers = patterns.map(wrapPatterns).concat(GLOBALLY_ACCEPTED_ERRORS);\n\t\t}\n\t}\n\n\tprivate checkAndLog(type: BrowserConsoleLogOptions[\"level\"], ...data: any[]) {\n\t\t// only check the error messages\n\t\tif (type === \"error\") {\n\t\t\tconst messageText = data[0];\n\t\t\tconst isAllowed = this.matchers.some((matcher) => matcher(messageText));\n\t\t\tif (!isAllowed) {\n\t\t\t\tthis.messages.push(messageText);\n\t\t\t}\n\t\t}\n\n\t\tif (this.karma) {\n\t\t\t// wrap the data to facilitate parsing in the backend\n\t\t\tconst wrappedData = data.map((d) => [d]);\n\t\t\tthis.karma.log(type, wrappedData);\n\t\t}\n\t}\n\n\tprivate prepareWindow(window: Window) {\n\t\tconst console: Console = (window as any).console;\n\n\t\t// capture console.log(), console.debug(), etc.\n\t\tconst patchConsoleMethod = (method: \"log\" | \"info\" | \"warn\" | \"error\" | \"debug\") => {\n\t\t\tconst fnOriginal = console[method];\n\t\t\tconsole[method] = (...data: any[]): void => {\n\t\t\t\tthis.checkAndLog(method, ...data);\n\t\t\t\treturn fnOriginal.apply(console, data);\n\t\t\t};\n\t\t};\n\n\t\tpatchConsoleMethod(\"log\");\n\t\tpatchConsoleMethod(\"debug\");\n\t\tpatchConsoleMethod(\"info\");\n\t\tpatchConsoleMethod(\"warn\");\n\t\tpatchConsoleMethod(\"error\");\n\n\t\t// capture console.assert()\n\t\t// see https://console.spec.whatwg.org/#assert\n\t\tconsole.assert = function (condition = false, ...data: any[]) {\n\t\t\tif (condition) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tconst message = \"Assertion failed\";\n\t\t\tif (data.length === 0) {\n\t\t\t\tdata.push(message);\n\t\t\t} else {\n\t\t\t\tlet first = data[0];\n\t\t\t\tif (typeof first !== \"string\") {\n\t\t\t\t\tdata.unshift(message);\n\t\t\t\t} else {\n\t\t\t\t\tfirst = `${message}: ${first}`;\n\t\t\t\t\tdata[0] = first;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tconsole.error(...data);\n\t\t};\n\n\t\t// capture errors\n\t\tfunction onPromiseRejection(this: ConsoleErrorChecker, event: PromiseRejectionEvent) {\n\t\t\tconst message = `UNHANDLED PROMISE REJECTION: ${event.reason}`;\n\t\t\tthis.checkAndLog(\"error\", message, event.reason?.stack);\n\t\t}\n\n\t\tfunction onError(this: ConsoleErrorChecker, event: ErrorEvent) {\n\t\t\tconst message = event.message;\n\t\t\tthis.checkAndLog(\"error\", message, event.filename);\n\t\t}\n\n\t\twindow.addEventListener(\"error\", onError.bind(this), { passive: true });\n\t\twindow.addEventListener(\"unhandledrejection\", onPromiseRejection.bind(this), { passive: true });\n\t}\n\n\tstatic getInstance(window: Window & { sapFEConsoleErrorChecker?: ConsoleErrorChecker }): ConsoleErrorChecker {\n\t\t// the global instance is needed to support multiple tests in a row (in Karma)\n\t\tif (!window.sapFEConsoleErrorChecker) {\n\t\t\twindow.sapFEConsoleErrorChecker = new ConsoleErrorChecker(window);\n\t\t}\n\t\treturn window.sapFEConsoleErrorChecker;\n\t}\n}\n\nexport default ConsoleErrorChecker.getInstance(window);\n"],"mappings":"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"}
|
|
@@ -24,8 +24,7 @@ function wrapPatterns(pattern: RegExp | string): MessageMatcherFunction {
|
|
|
24
24
|
* List of error message patterns that are always accepted.
|
|
25
25
|
*/
|
|
26
26
|
const GLOBALLY_ACCEPTED_ERRORS = [
|
|
27
|
-
"failed to load JavaScript resource: sap/esh/search/ui/i18n.js"
|
|
28
|
-
"Custom attributes are not exist" // accept console error temporarily - remove as soon as unified shell ticket is resolved
|
|
27
|
+
"failed to load JavaScript resource: sap/esh/search/ui/i18n.js" // shell
|
|
29
28
|
].map(wrapPatterns);
|
|
30
29
|
|
|
31
30
|
class ConsoleErrorChecker {
|
|
@@ -1904,6 +1904,38 @@ sap.ui.predefine("sap/fe/test/JestTemplatingHelper", ["@sap/cds-compiler", "fs",
|
|
|
1904
1904
|
},
|
|
1905
1905
|
pass: nodes && nodes.length === 0
|
|
1906
1906
|
};
|
|
1907
|
+
},
|
|
1908
|
+
/**
|
|
1909
|
+
* Checks for errors in `xml` created during templating of an XML string or
|
|
1910
|
+
* an XML node.
|
|
1911
|
+
*
|
|
1912
|
+
* This function checkes for the xml errors created by the
|
|
1913
|
+
* function [BuildingBlockTemplateProcessor.createErrorXML]{@link sap.fe.core.buildingBlocks.BuildingBlockTemplateProcessor#createErrorXML}.
|
|
1914
|
+
*
|
|
1915
|
+
* @param xml XML String or XML Node to be tested for errors
|
|
1916
|
+
* @returns Jest Matcher result object
|
|
1917
|
+
*/
|
|
1918
|
+
toHaveTemplatingErrors(xml) {
|
|
1919
|
+
const xmlText = typeof xml === "string" ? xml : serializeXML(xml);
|
|
1920
|
+
const base64Entries = xmlText.match(/BBF\.base64Decode\('([^']*)'\)/gm) || [];
|
|
1921
|
+
const errorMessages = base64Entries.map(message => {
|
|
1922
|
+
if (message && message.length > 0) {
|
|
1923
|
+
var _message$match, _message$match$;
|
|
1924
|
+
return atob(((_message$match = message.match(/('[^']*)/)) === null || _message$match === void 0 ? void 0 : (_message$match$ = _message$match[0]) === null || _message$match$ === void 0 ? void 0 : _message$match$.slice(1)) || "");
|
|
1925
|
+
}
|
|
1926
|
+
return "";
|
|
1927
|
+
});
|
|
1928
|
+
if (errorMessages.length <= 0) {
|
|
1929
|
+
return {
|
|
1930
|
+
message: () => `XML Templating without errors`,
|
|
1931
|
+
pass: false
|
|
1932
|
+
};
|
|
1933
|
+
} else {
|
|
1934
|
+
return {
|
|
1935
|
+
message: () => errorMessages.join("\n"),
|
|
1936
|
+
pass: true
|
|
1937
|
+
};
|
|
1938
|
+
}
|
|
1907
1939
|
}
|
|
1908
1940
|
});
|
|
1909
1941
|
_exports.runXPathQuery = runXPathQuery;
|
|
@@ -1920,10 +1952,24 @@ sap.ui.predefine("sap/fe/test/JestTemplatingHelper", ["@sap/cds-compiler", "fs",
|
|
|
1920
1952
|
const selector = `string(${_getTemplatedSelector(xmlDom, controlSelector)}/@${attributeName})`;
|
|
1921
1953
|
return runXPathQuery(selector, xmlDom);
|
|
1922
1954
|
};
|
|
1955
|
+
|
|
1956
|
+
/**
|
|
1957
|
+
* Serialize the parts or the complete given XML DOM to string.
|
|
1958
|
+
*
|
|
1959
|
+
* @param xmlDom DOM node that is to be serialized.
|
|
1960
|
+
* @param selector Optional selector of sub nodes
|
|
1961
|
+
* @returns XML string
|
|
1962
|
+
*/
|
|
1923
1963
|
_exports.getControlAttribute = getControlAttribute;
|
|
1924
|
-
const serializeXML = function (xmlDom) {
|
|
1964
|
+
const serializeXML = function (xmlDom, selector) {
|
|
1925
1965
|
const serializer = new window.XMLSerializer();
|
|
1926
|
-
|
|
1966
|
+
let xmlString;
|
|
1967
|
+
if (selector) {
|
|
1968
|
+
const nodes = runXPathQuery(selector, xmlDom);
|
|
1969
|
+
xmlString = nodes.map(node => serializer.serializeToString(node)).join("\n");
|
|
1970
|
+
} else {
|
|
1971
|
+
xmlString = serializer.serializeToString(xmlDom);
|
|
1972
|
+
}
|
|
1927
1973
|
return formatXML(xmlString);
|
|
1928
1974
|
};
|
|
1929
1975
|
_exports.serializeXML = serializeXML;
|
|
@@ -1941,16 +1987,23 @@ sap.ui.predefine("sap/fe/test/JestTemplatingHelper", ["@sap/cds-compiler", "fs",
|
|
|
1941
1987
|
* @param cdsUrl The path to the file containing the CDS definition. This file must declare the namespace
|
|
1942
1988
|
* sap.fe.test and a service JestService
|
|
1943
1989
|
* @param options Options for creating the EDMX output
|
|
1944
|
-
* @param edmxFileName Allows you to override the name of the compiled EDMX metadata file
|
|
1945
1990
|
* @returns The path of the generated EDMX
|
|
1946
1991
|
*/
|
|
1947
1992
|
_exports.formatXML = formatXML;
|
|
1948
1993
|
const compileCDS = function (cdsUrl) {
|
|
1949
1994
|
let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
|
|
1950
|
-
let edmxFileName = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : path.basename(cdsUrl).replace(".cds", ".xml");
|
|
1951
1995
|
const cdsString = fs.readFileSync(cdsUrl, "utf-8");
|
|
1952
1996
|
const edmxContent = cds2edmx(cdsString, "sap.fe.test.JestService", options);
|
|
1953
1997
|
const dir = path.resolve(cdsUrl, "..", "gen");
|
|
1998
|
+
|
|
1999
|
+
// If the caller provided CDS compiler options: Include them in the filename. This prevents unpredictable results if the same CDS source
|
|
2000
|
+
// file is used simultaneously with a different set of options (e.g. in a test running in parallel)
|
|
2001
|
+
const allOptions = Object.entries(options);
|
|
2002
|
+
allOptions.sort((a, b) => b[0].localeCompare(a[0]));
|
|
2003
|
+
const edmxFileName = allOptions.reduce((filename, _ref) => {
|
|
2004
|
+
let [optionKey, optionValue] = _ref;
|
|
2005
|
+
return `${filename}#${optionKey}=${optionValue.toString()}#`;
|
|
2006
|
+
}, path.basename(cdsUrl).replace(".cds", "")) + ".xml";
|
|
1954
2007
|
const edmxFilePath = path.resolve(dir, edmxFileName);
|
|
1955
2008
|
fs.mkdirSync(dir, {
|
|
1956
2009
|
recursive: true
|
|
@@ -1983,7 +2036,7 @@ sap.ui.predefine("sap/fe/test/JestTemplatingHelper", ["@sap/cds-compiler", "fs",
|
|
|
1983
2036
|
const edmxOptions = {
|
|
1984
2037
|
odataForeignKeys: true,
|
|
1985
2038
|
odataFormat: "structured",
|
|
1986
|
-
odataContainment:
|
|
2039
|
+
odataContainment: true,
|
|
1987
2040
|
...options,
|
|
1988
2041
|
service: service
|
|
1989
2042
|
};
|
|
@@ -2183,7 +2236,9 @@ sap.ui.predefine("sap/fe/test/JestTemplatingHelper", ["@sap/cds-compiler", "fs",
|
|
|
2183
2236
|
_exports.getTemplatingResult = getTemplatingResult;
|
|
2184
2237
|
const getTemplatedXML = async function (xmlInput, sMetadataUrl, mBindingContexts, mModels, flexChanges, fakeSideEffectService) {
|
|
2185
2238
|
const templatedXML = await getTemplatingResult(xmlInput, sMetadataUrl, mBindingContexts, mModels, flexChanges, fakeSideEffectService);
|
|
2186
|
-
|
|
2239
|
+
const serialiedXML = serializeXML(templatedXML);
|
|
2240
|
+
expect(serialiedXML).not.toHaveTemplatingErrors();
|
|
2241
|
+
return serialiedXML;
|
|
2187
2242
|
};
|
|
2188
2243
|
|
|
2189
2244
|
/**
|
|
@@ -10341,18 +10396,11 @@ sap.ui.predefine(
|
|
|
10341
10396
|
if (vFieldIdentifier.fieldGroup) {
|
|
10342
10397
|
oBuilder.has(OpaBuilder.Matchers.children(this._getBuilderForFieldGroup(vFieldIdentifier)));
|
|
10343
10398
|
}
|
|
10344
|
-
|
|
10345
|
-
|
|
10346
|
-
|
|
10347
|
-
|
|
10348
|
-
|
|
10349
|
-
} else {
|
|
10350
|
-
return oBuilder
|
|
10351
|
-
.has(OpaBuilder.Matchers.children(this._getBuilderForFormElement(vFieldIdentifier)))
|
|
10352
|
-
.has(FEBuilder.Matchers.singleElement())
|
|
10353
|
-
.has(OpaBuilder.Matchers.children(this.createFieldMatcher(vFieldIdentifier)))
|
|
10354
|
-
.has(FEBuilder.Matchers.singleElement());
|
|
10355
|
-
}
|
|
10399
|
+
return oBuilder
|
|
10400
|
+
.has(OpaBuilder.Matchers.children(this._getBuilderForFormElement(vFieldIdentifier)))
|
|
10401
|
+
.has(FEBuilder.Matchers.singleElement())
|
|
10402
|
+
.has(OpaBuilder.Matchers.children(this.createFieldMatcher(vFieldIdentifier)))
|
|
10403
|
+
.has(FEBuilder.Matchers.singleElement());
|
|
10356
10404
|
};
|
|
10357
10405
|
|
|
10358
10406
|
FormAPI.prototype._getBuilderForFormElement = function (vFieldIdentifier) {
|
|
@@ -11346,6 +11394,24 @@ sap.ui.predefine(
|
|
|
11346
11394
|
return this.iCheckAction({ service: "StandardAction", action: "Edit", unbound: true }, mState);
|
|
11347
11395
|
};
|
|
11348
11396
|
|
|
11397
|
+
/**
|
|
11398
|
+
* Checks if a specific header action is in focus.
|
|
11399
|
+
*
|
|
11400
|
+
* @param {string | sap.fe.test.api.ActionIdentifier} vActionIdentifier The identifier of the action
|
|
11401
|
+
* @returns {object} The result of the {@link sap.ui.test.Opa5#waitFor} function, to be used for chained statements
|
|
11402
|
+
* @ui5-restricted
|
|
11403
|
+
*/
|
|
11404
|
+
HeaderAssertions.prototype.iCheckActionHasFocus = function (vActionIdentifier) {
|
|
11405
|
+
var oFEBuilder = FEBuilder.create(this.getOpaInstance());
|
|
11406
|
+
return this.prepareResult(
|
|
11407
|
+
oFEBuilder
|
|
11408
|
+
.hasId(this.createActionMatcher(vActionIdentifier))
|
|
11409
|
+
.hasState({ focused: true })
|
|
11410
|
+
.description(Utils.formatMessage("Checking focus on header action '{0}'", vActionIdentifier))
|
|
11411
|
+
.execute()
|
|
11412
|
+
);
|
|
11413
|
+
};
|
|
11414
|
+
|
|
11349
11415
|
/**
|
|
11350
11416
|
* Checks the <code>Delete</code> action in the header toolbar.
|
|
11351
11417
|
*
|
|
@@ -14264,12 +14330,9 @@ sap.ui.predefine(
|
|
|
14264
14330
|
*/
|
|
14265
14331
|
TableAssertions.prototype.iCheckQuickFilter = function (mState) {
|
|
14266
14332
|
var oTableBuilder = this.getBuilder();
|
|
14267
|
-
var vAggregationMatcher = FEBuilder.Matchers.deepAggregationMatcher("quickFilter/selector", [
|
|
14268
|
-
[FEBuilder.Matchers.states(mState)]
|
|
14269
|
-
]);
|
|
14270
14333
|
return this.prepareResult(
|
|
14271
14334
|
oTableBuilder
|
|
14272
|
-
.
|
|
14335
|
+
.hasAggregation("quickFilter", [FEBuilder.Matchers.states(mState)])
|
|
14273
14336
|
.description(
|
|
14274
14337
|
Utils.formatMessage(
|
|
14275
14338
|
"Checking that table '{0}' has a QuickFilter Control with state='{1}'",
|
|
@@ -16716,7 +16779,7 @@ sap.ui.predefine(
|
|
|
16716
16779
|
return this.has(function (oTable) {
|
|
16717
16780
|
var oQuickFilter = oTable.getQuickFilter();
|
|
16718
16781
|
if (oQuickFilter) {
|
|
16719
|
-
var aItems = oQuickFilter.
|
|
16782
|
+
var aItems = oQuickFilter.getItems();
|
|
16720
16783
|
if (Utils.isOfType(aItems, Array)) {
|
|
16721
16784
|
return aItems.length === iNumberOfItems;
|
|
16722
16785
|
}
|
|
@@ -16728,7 +16791,7 @@ sap.ui.predefine(
|
|
|
16728
16791
|
|
|
16729
16792
|
TableBuilder.prototype.doSelectQuickFilter = function (oItemMatcher) {
|
|
16730
16793
|
return this.has(function (oTable) {
|
|
16731
|
-
return oTable.getQuickFilter()
|
|
16794
|
+
return oTable.getQuickFilter();
|
|
16732
16795
|
})
|
|
16733
16796
|
.doConditional(FEBuilder.Matchers.state("controlType", "sap.m.Select"), OpaBuilder.Actions.press())
|
|
16734
16797
|
.success(
|
|
@@ -17708,9 +17771,7 @@ sap.ui.predefine("sap/fe/test/internal/ConsoleErrorChecker", [], function () {
|
|
|
17708
17771
|
/**
|
|
17709
17772
|
* List of error message patterns that are always accepted.
|
|
17710
17773
|
*/
|
|
17711
|
-
const GLOBALLY_ACCEPTED_ERRORS = ["failed to load JavaScript resource: sap/esh/search/ui/i18n.js"
|
|
17712
|
-
// shell
|
|
17713
|
-
"Custom attributes are not exist" // accept console error temporarily - remove as soon as unified shell ticket is resolved
|
|
17774
|
+
const GLOBALLY_ACCEPTED_ERRORS = ["failed to load JavaScript resource: sap/esh/search/ui/i18n.js" // shell
|
|
17714
17775
|
].map(wrapPatterns);
|
|
17715
17776
|
let ConsoleErrorChecker = /*#__PURE__*/function () {
|
|
17716
17777
|
function ConsoleErrorChecker(window) {
|
|
@@ -18069,12 +18130,12 @@ sap.ui.predefine("sap/fe/test/library", ["sap/ui/core/Core", "sap/ui/core/librar
|
|
|
18069
18130
|
controls: [],
|
|
18070
18131
|
elements: [],
|
|
18071
18132
|
// eslint-disable-next-line no-template-curly-in-string
|
|
18072
|
-
version: "1.
|
|
18133
|
+
version: "1.114.0",
|
|
18073
18134
|
noLibraryCSS: true
|
|
18074
18135
|
});
|
|
18075
18136
|
return thisLib;
|
|
18076
18137
|
}, false);
|
|
18077
18138
|
sap.ui.require.preload({
|
|
18078
|
-
"sap/fe/test/manifest.json":'{"_version":"1.21.0","sap.app":{"id":"sap.fe.test","type":"library","embeds":[],"applicationVersion":{"version":"1.
|
|
18139
|
+
"sap/fe/test/manifest.json":'{"_version":"1.21.0","sap.app":{"id":"sap.fe.test","type":"library","embeds":[],"applicationVersion":{"version":"1.114.0"},"title":"UI5 library: sap.fe.test","description":"UI5 library: sap.fe.test","resources":"resources.json","offline":true},"sap.ui":{"technology":"UI5","supportedThemes":[]},"sap.ui5":{"dependencies":{"libs":{"sap.ui.core":{}}},"library":{"i18n":false,"content":{"controls":[],"elements":[],"types":[],"interfaces":[]}}}}'
|
|
18079
18140
|
});
|
|
18080
18141
|
//# sourceMappingURL=library-preload.js.map
|