From 7488d5f2c9216ac87e47ac7019fbc18674e86e30 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Matthias=20O=C3=9Fwald?= <1410947+matz3@users.noreply.github.com> Date: Mon, 29 Jun 2020 14:16:17 +0200 Subject: [PATCH] [FIX] XMLTemplateAnalyzer: Handle empty XML view/fragment (#471) Fixes: https://github.com/SAP/ui5-builder/issues/281 --- lib/lbt/analyzer/XMLTemplateAnalyzer.js | 6 ++ test/lib/lbt/analyzer/XMLTemplateAnalyzer.js | 58 ++++++++------------ 2 files changed, 28 insertions(+), 36 deletions(-) diff --git a/lib/lbt/analyzer/XMLTemplateAnalyzer.js b/lib/lbt/analyzer/XMLTemplateAnalyzer.js index faa819b1f..5a3aa8e89 100644 --- a/lib/lbt/analyzer/XMLTemplateAnalyzer.js +++ b/lib/lbt/analyzer/XMLTemplateAnalyzer.js @@ -162,6 +162,12 @@ class XMLTemplateAnalyzer { return; } + if ( !result ) { + // Handle empty xml views/fragments + reject(new Error("Invalid empty XML document: " + info.name)); + return; + } + // console.log(result); // clear(); if ( isFragment ) { diff --git a/test/lib/lbt/analyzer/XMLTemplateAnalyzer.js b/test/lib/lbt/analyzer/XMLTemplateAnalyzer.js index 40069981b..1b8485a84 100644 --- a/test/lib/lbt/analyzer/XMLTemplateAnalyzer.js +++ b/test/lib/lbt/analyzer/XMLTemplateAnalyzer.js @@ -3,6 +3,10 @@ const XMLTemplateAnalyzer = require("../../../../lib/lbt/analyzer/XMLTemplateAna const ModuleInfo = require("../../../../lib/lbt/resources/ModuleInfo"); const sinon = require("sinon"); +const fakeMockPool = { + findResource: () => Promise.resolve() +}; + test("integration: Analysis of an xml view", async (t) => { const xml = ` @@ -13,15 +17,10 @@ test("integration: Analysis of an xml view", async (t) => { `; - const mockPool = {async findResource(name) { - return { - buffer: () => name.endsWith(".xml") ? JSON.stringify(xml): "test" - }; - }}; const moduleInfo = new ModuleInfo(); - const analyzer = new XMLTemplateAnalyzer(mockPool); + const analyzer = new XMLTemplateAnalyzer(fakeMockPool); await analyzer.analyzeView(xml, moduleInfo); t.deepEqual(moduleInfo.dependencies, [ @@ -39,15 +38,10 @@ test("integration: Analysis of an xml view with data binding in properties", asy controllerName="myController"> `; - const mockPool = {async findResource(name) { - return { - buffer: () => name.endsWith(".xml") ? JSON.stringify(xml): "test" - }; - }}; const moduleInfo = new ModuleInfo(); - const analyzer = new XMLTemplateAnalyzer(mockPool); + const analyzer = new XMLTemplateAnalyzer(fakeMockPool); await analyzer.analyzeView(xml, moduleInfo); t.deepEqual(moduleInfo.dependencies, [ @@ -70,15 +64,10 @@ test("integration: Analysis of an xml view with core:require", async (t) => {