/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * This file is part of the LibreOffice project. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/.
*/
class OOO_DLLPUBLIC_TEST XmlTestTools
{ public: /// Return xmlDocPtr representation of the XML stream read from pStream. static xmlDocUniquePtr parseXmlStream(SvStream* pStream);
// Caller must call xmlXPathFreeObject:
xmlXPathObjectPtr getXPathNode(const xmlDocUniquePtr& pXmlDoc, constchar* pXPath); /** * Same as the assertXPath(), but don't assert: return the string instead.
*/
OUString getXPath(const xmlDocUniquePtr& pXmlDoc, constchar* pXPath, constchar* pAttribute);
OUString getXPath(const xmlDocUniquePtr& pXmlDoc, const OString& sXPath, constchar* pAttribute)
{ return getXPath(pXmlDoc, sXPath.getStr(), pAttribute);
} /** * Same as the assertXPathContent(), but don't assert: return the string instead.
*/
OUString getXPathContent(const xmlDocUniquePtr& pXmlDoc, constchar* pXPath);
OUString getXPathContent(const xmlDocUniquePtr& pXmlDoc, const OString& sXPath)
{ return getXPathContent(pXmlDoc, sXPath.getStr());
} /** * Get the position of the child named rName of the parent node specified by pXPath. * Useful for checking relative order of elements.
*/ int getXPathPosition(const xmlDocUniquePtr& pXmlDoc, constchar* pXPath, constchar* pChildName); /** * Get the number of the nodes returned by the pXPath.
*/ int countXPathNodes(const xmlDocUniquePtr& pXmlDoc, constchar* pXPath); int countXPathNodes(const xmlDocUniquePtr& pXmlDoc, const OString& sXPath)
{ return countXPathNodes(pXmlDoc, sXPath.getStr());
} /** * Assert that pXPath exists, returns exactly one node, and the pXPath's attribute's value * equals to the rExpected value.
*/ void assertXPath(const xmlDocUniquePtr& pXmlDoc, constchar* pXPath, constchar* pAttribute,
std::u16string_view rExpectedValue); void assertXPath(const xmlDocUniquePtr& pXmlDoc, const OString& sXPath, constchar* pAttribute,
std::u16string_view rExpectedValue)
{
assertXPath(pXmlDoc, sXPath.getStr(), pAttribute, rExpectedValue);
} void assertXPathAttrs(const xmlDocUniquePtr& pXmlDoc, constchar* pXPath, const std::vector<std::pair<constchar*, std::u16string_view>>& aPairVector); void assertXPathAttrs(const xmlDocUniquePtr& pXmlDoc, const OString& sXPath, const std::vector<std::pair<constchar*, std::u16string_view>>& aPairVector)
{
assertXPathAttrs(pXmlDoc, sXPath.getStr(), aPairVector);
}
/** * Given a double for the rExpected value, assert that pXPath exists, returns exactly one node, * and the pXPath's attribute's value matches the rExpected value within tolerance provided * by delta. This is used to account for HiDPI scaling.
*/ void assertXPathDoubleValue(const xmlDocUniquePtr& pXmlDoc, constchar* pXPath, constchar* pAttribute, double expectedValue, double delta); /** * Assert that pXPath exists, and returns exactly nNumberOfNodes nodes (1 by default). * Also useful for checking that we do _not_ export some node (nNumberOfNodes == 0).
*/ void assertXPath(const xmlDocUniquePtr& pXmlDoc, constchar* pXPath, int nNumberOfNodes = 1); void assertXPath(const xmlDocUniquePtr& pXmlDoc, const OString& sXPath, int nNumberOfNodes = 1)
{
assertXPath(pXmlDoc, sXPath.getStr(), nNumberOfNodes);
} /** * Assert that pXPath exists, and its content equals rContent.
*/ void assertXPathContent(const xmlDocUniquePtr& pXmlDoc, constchar* pXPath, std::u16string_view rContent); void assertXPathContent(const xmlDocUniquePtr& pXmlDoc, const OString& sXPath,
std::u16string_view rContent)
{
assertXPathContent(pXmlDoc, sXPath.getStr(), rContent);
} /** * Assert that pXPath exists and it has an rNSPrefix=rNSHref namespace definition.
*/ void assertXPathNSDef(const xmlDocUniquePtr& pXmlDoc, constchar* pXPath, std::string_view rNSPrefix,
std::string_view rNSHref); /** * Assert that pXPath exists, and has exactly nNumberOfChildNodes child nodes. * Useful for checking that we do have a no child nodes to a specific node (nNumberOfChildNodes == 0).
*/ void assertXPathChildren(const xmlDocUniquePtr& pXmlDoc, constchar* pXPath, int nNumberOfChildNodes); void assertXPathChildren(const xmlDocUniquePtr& pXmlDoc, const OString& sXPath, int nNumberOfChildNodes)
{
assertXPathChildren(pXmlDoc, sXPath.getStr(), nNumberOfChildNodes);
} /** * Assert that pXPath exists, has exactly 1 result set nodes and does *not* have an attribute named pAttribute.
*/ void assertXPathNoAttribute(const xmlDocUniquePtr& pXmlDoc, constchar* pXPath, constchar* pAttribute); void assertXPathNoAttribute(const xmlDocUniquePtr& pXmlDoc, const OString& sXPath, constchar* pAttribute)
{
assertXPathNoAttribute(pXmlDoc, sXPath.getStr(), pAttribute);
} /** * Same as the assertXPathNoAttribute(), but don't assert: return the bool instead.
*/ bool hasXPathAttribute(const xmlDocUniquePtr& pXmlDoc, constchar* pXPath, constchar* pAttribute); // Assert that the node name of the single node returned by an XPath is as specified, // e.g. to check order of elements, where getXPathPosition is unapplicable void assertXPathNodeName(const xmlDocUniquePtr& pXmlDoc, constchar* pXPath, std::string_view rExpectedName);
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.