From 47a10b6dba1f748f66ff5bd9e012c796acb83dd9 Mon Sep 17 00:00:00 2001 From: Mike Kaganski Date: Sat, 21 Sep 2024 18:41:17 +0500 Subject: tdf#163064: pic element is required here, after all In commit cf15306ccf49da290b391517e2c5dd22a4f1be45 (ERROR: Invalid content was found starting with element 'p:pic'., 2014-12-22), the pic element inside the oleObj element was only alloswed for the old revision of ECMA-736 export, because that was considered invalid by officeotron. However, as of ECMA-376-1:2016, this element is mandatory; CT_OleObject definition in Annex A has: and Annex L (Primer) has L.7.2.5 "Embeddings in a PresentationML Document" saying: The oleObj element shall have a pic child element that (optionally) contains the image data to be used in place of loading the actual object data. The omission of this in the export is the reason of tdf#163064. So here I filter out the error from the validation results, which is not ideal (I have no way to know if the found pic is really in the oleObj, or somewhere else), but a lesser evil, compared to required exclusion of all tests that export OLE objects. Change-Id: Ia73a49da7347e8ff22c626e211b55ba1e0625070 Reviewed-on: https://gerrit.libreoffice.org/c/core/+/173761 Reviewed-by: Mike Kaganski Tested-by: Jenkins Signed-off-by: Xisco Fauli Reviewed-on: https://gerrit.libreoffice.org/c/core/+/173809 --- test/source/bootstrapfixture.cxx | 58 ++++++++++++++++++++++++++++++++++++++-- 1 file changed, 56 insertions(+), 2 deletions(-) (limited to 'test') diff --git a/test/source/bootstrapfixture.cxx b/test/source/bootstrapfixture.cxx index 273109496012..876538db679d 100644 --- a/test/source/bootstrapfixture.cxx +++ b/test/source/bootstrapfixture.cxx @@ -140,6 +140,59 @@ OString loadFile(const OUString& rURL) return aContent; } +constexpr std::u16string_view grand_total = u"Grand total of errors in submitted package: "; + +OUString filterOut(const OUString& s, std::u16string_view excludedSubstr) +{ + OUString result = s; + for (;;) + { + sal_Int32 pos = result.indexOf(excludedSubstr); + if (pos < 0) + break; + sal_Int32 start = result.lastIndexOf('\n', pos); + if (!result.match("ERROR", start + 1)) + return s; // unexpected string format + sal_Int32 end = result.indexOf('\n', pos); + result = result.replaceAt(start, end - start, u""); + pos = result.lastIndexOf(grand_total); + if (pos < 0) + return s; // unexpected string format + start = end = pos + grand_total.size(); + while (end < result.getLength() && rtl::isAsciiDigit(result[end])) + ++end; + std::u16string_view aNumber = result.subView(start, end - start); + sal_Int32 nErrors = o3tl::toInt32(aNumber) - 1; + result = result.replaceAt(start, end - start, OUString::number(nErrors)); + } + return result; +} + +OUString filterValidationResults(const OUString& s) +{ + OUString result = s; + // In ECMA-376-1 Second Edition, 2008, there is the following restriction for oleObj: + // + // + // + // + // + // + // + // This makes simultaneous use of embed (or link) and pic impossible. This was obviously a + // mistake; and the following editions of standard fixed it: e.g., in ECMA-376-1:2016, that + // rule is + // + // + // + // + // + // + // + // But officeotron only knows the old version... + result = filterOut(result, u"Invalid content was found starting with element 'p:pic'. No child element is expected at this point."); + return result; +} } #endif @@ -215,15 +268,16 @@ void test::BootstrapFixture::validate(const OUString& rPath, test::ValidationFor if( eFormat == test::OOXML && !aContentOUString.isEmpty() ) { + aContentOUString = filterValidationResults(aContentOUString); // check for validation errors here - sal_Int32 nIndex = aContentOUString.lastIndexOf("Grand total of errors in submitted package: "); + sal_Int32 nIndex = aContentOUString.lastIndexOf(grand_total); if(nIndex == -1) { SAL_WARN("test", "no summary line"); } else { - sal_Int32 nStartOfNumber = nIndex + std::strlen("Grand total of errors in submitted package: "); + sal_Int32 nStartOfNumber = nIndex + grand_total.size(); std::u16string_view aNumber = aContentOUString.subView(nStartOfNumber); sal_Int32 nErrors = o3tl::toInt32(aNumber); OString aMsg = "validation error in OOXML export: Errors: " + OString::number(nErrors); -- cgit