Tests that the cache is used more than once.
Test compile-cache-002.xml is expected to pass.
<p:declare-step xmlns:cx="http://xmlcalabash.com/ns/extensions" xmlns:err="http://www.w3.org/ns/xproc-error" xmlns:p="http://www.w3.org/ns/xproc" xmlns:s="http://purl.oclc.org/dsdl/schematron" version="3.0">
<p:import href="https://xmlcalabash.com/ext/library/pipeline-messages.xpl"/>
<p:output port="result"/>
<p:xslt cx:cache-stylesheet="true">
<p:with-input port="source">
<doc>
<p>It doesn’t matter what goes here</p>
</doc>
</p:with-input>
<p:with-input port="stylesheet" href="../documents/identity.xsl"/>
</p:xslt>
<p:xslt cx:cache-stylesheet="true">
<p:with-input port="stylesheet" href="../documents/identity.xsl"/>
</p:xslt>
<p:xslt name="xslt" cx:cache-stylesheet="true">
<p:with-input port="stylesheet" href="../documents/identity.xsl"/>
</p:xslt>
<cx:pipeline-messages p:depends="xslt" level="debug"/>
</p:declare-step>
<s:schema xmlns:s="http://purl.oclc.org/dsdl/schematron" queryBinding="xslt2">
<s:ns prefix="cx" uri="http://xmlcalabash.com/ns/extensions"/>
<s:pattern>
<s:rule context="/">
<s:assert test="cx:messages">The document root is not correct.</s:assert>
</s:rule>
</s:pattern>
<s:pattern>
<s:rule context="/cx:messages">
<s:assert test="cx:message[@level='DEBUG' and matches(@message, 'Caching compiled.*documents/identity\.xsl')]">No caching message.</s:assert>
</s:rule>
<s:rule context="/cx:messages">
<s:assert test="cx:message[@level='DEBUG' and matches(@message, 'Using cached.*documents/identity\.xsl')] /following-sibling::cx:message[@level='DEBUG' and matches(@message, 'Using cached.*documents/identity\.xsl')]">No second using cached message.</s:assert>
</s:rule>
</s:pattern>
</s:schema>
Created test.