p-message-006

Tests that p:message outputs a sequence.

Test is expected to pass.

The 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"
                xmlns:t="http://xproc.org/ns/testsuite/3.0"
                xmlns:xs="http://www.w3.org/2001/XMLSchema" version="3.0">
   <p:import href="https://xmlcalabash.com/ext/library/pipeline-messages.xpl"/>
   <p:output port="result"/>
   <p:message name="message" test="true">
      <p:with-option name="select"
                     select="(1,2,3,'Spanish Inquisition',5)"/>
      <p:with-input>
         <doc/>
      </p:with-input>
   </p:message>
   <cx:pipeline-messages p:depends="message"
                         level="info" message-attribute="false"/>
</p:declare-step>

Result

<cx:messages xmlns:cx="http://xmlcalabash.com/ns/extensions"
             xmlns:t="http://xproc.org/ns/testsuite/3.0">
   <cx:message date="2025-12-14T15:59:52+00:00"
               level="INFO">1</cx:message>
   <cx:message date="2025-12-14T15:59:52+00:00"
               level="INFO">2</cx:message>
   <cx:message date="2025-12-14T15:59:52+00:00"
               level="INFO">3</cx:message>
   <cx:message date="2025-12-14T15:59:52+00:00"
               level="INFO">Spanish Inquisition</cx:message>
   <cx:message date="2025-12-14T15:59:52+00:00"
               level="INFO">5</cx:message>
</cx:messages>

Schematron checks

<s:schema xmlns:s="http://purl.oclc.org/dsdl/schematron"
          xmlns:t="http://xproc.org/ns/testsuite/3.0" 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[1][@level='INFO' and .= '1']">
                    >Incorrect first item.</s:assert>
         <s:assert test="cx:message[2][@level='INFO' and .= '2']">
                    >Incorrect second item.</s:assert>
         <s:assert test="cx:message[3][@level='INFO' and .= '3']">
                    >Incorrect third item.</s:assert>
         <s:assert test="cx:message[4][@level='INFO' and .= 'Spanish Inquisition']">
                    >Incorrect fourth item.</s:assert>
         <s:assert test="cx:message[5][@level='INFO' and .= '5']">
                    >Incorrect fifth item.</s:assert>
      </s:rule>
   </s:pattern>
</s:schema>

Revision history

06 Dec 2025, Norm Tovey-Walsh
Created test.