<?xml version="1.0" encoding="utf-8"?>
<t:test xmlns:t="http://xproc.org/ns/testsuite/3.0"
        xml:base="message-011.xml"
        name="message-011.xml"
        expected="pass">
   <t:info>
      <t:title>message-011</t:title>
      <t:revision-history>
         <t:revision>
            <t:date>2025-08-24</t:date>
            <t:author>
               <t:name>Norm Tovey-Walsh</t:name>
            </t:author>
            <t:description xmlns="http://www.w3.org/1999/xhtml">
               <p>Created test.</p>
            </t:description>
         </t:revision>
      </t:revision-history>
   </t:info>
   <t:description xmlns="http://www.w3.org/1999/xhtml">
      <p>Tests that message on p:viewport works.</p>
   </t:description>
   <t:pipeline>
      <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:identity>
            <p:with-input>
               <doc/>
            </p:with-input>
         </p:identity>
         <p:viewport match="/*" name="dep" message="Element is {node-name(/*)}">
            <p:identity/>
         </p:viewport>
         <cx:pipeline-messages p:depends="dep" level="info"/>
      </p:declare-step>
   </t:pipeline>
   <t:schematron>
      <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='INFO' and contains(@message, 'Element is doc')]">No message output.</s:assert>
            </s:rule>
         </s:pattern>
      </s:schema>
   </t:schematron>
   <t:result name="message-011.xml">
      <cx:messages xmlns:cx="http://xmlcalabash.com/ns/extensions">
         <cx:message date="2026-05-10T09:14:38+00:00"
                     level="INFO"
                     message="Element is doc"/>
      </cx:messages>
   </t:result>
</t:test>
