<testsuites name="Mocha Tests" time="8.469" tests="12" failures="0">
  <testsuite name="Root Suite" timestamp="2025-12-18T18:42:09" tests="0" time="0.000" failures="0">
  </testsuite>
  <testsuite name="realtime/liveobjects" timestamp="2025-12-18T18:42:09" tests="0" file="/home/runner/work/ably-js/ably-js/test/realtime/liveobjects.test.js" time="0.000" failures="0">
  </testsuite>
  <testsuite name="Sync events" timestamp="2025-12-18T18:42:11" tests="12" file="/home/runner/work/ably-js/ably-js/test/realtime/liveobjects.test.js" time="6.502" failures="0">
    <testcase name="realtime/liveobjects Sync events The first ATTACHED should always provoke a SYNCING even when HAS_OBJECTS is false, so that the SYNCED is preceded by SYNCING" time="0.179" classname="The first ATTACHED should always provoke a SYNCING even when HAS_OBJECTS is false, so that the SYNCED is preceded by SYNCING">
    </testcase>
    <testcase name="realtime/liveobjects Sync events ATTACHED with HAS_OBJECTS false once SYNCED emits SYNCING and then SYNCED" time="0.129" classname="ATTACHED with HAS_OBJECTS false once SYNCED emits SYNCING and then SYNCED">
    </testcase>
    <testcase name="realtime/liveobjects Sync events If we&apos;re in SYNCING awaiting an OBJECT_SYNC but then instead get an ATTACHED with HAS_OBJECTS false, we should emit a SYNCED" time="0.151" classname="If we&apos;re in SYNCING awaiting an OBJECT_SYNC but then instead get an ATTACHED with HAS_OBJECTS false, we should emit a SYNCED">
    </testcase>
    <testcase name="realtime/liveobjects Sync events An initial ATTACHED with HAS_OBJECTS true provokes a SYNCING" time="0.196" classname="An initial ATTACHED with HAS_OBJECTS true provokes a SYNCING">
    </testcase>
    <testcase name="realtime/liveobjects Sync events ATTACHED with HAS_OBJECTS true when SYNCED should provoke another SYNCING, because we&apos;re waiting to receive the updated objects in an OBJECT_SYNC" time="0.150" classname="ATTACHED with HAS_OBJECTS true when SYNCED should provoke another SYNCING, because we&apos;re waiting to receive the updated objects in an OBJECT_SYNC">
    </testcase>
    <testcase name="realtime/liveobjects Sync events If we&apos;re in SYNCING awaiting an OBJECT_SYNC but then instead get another ATTACHED with HAS_OBJECTS true, we should remain SYNCING (i.e. not emit another event)" time="0.209" classname="If we&apos;re in SYNCING awaiting an OBJECT_SYNC but then instead get another ATTACHED with HAS_OBJECTS true, we should remain SYNCING (i.e. not emit another event)">
    </testcase>
    <testcase name="realtime/liveobjects Sync events A complete multi-message OBJECT_SYNC sequence after ATTACHED emits SYNCING and then SYNCED" time="0.257" classname="A complete multi-message OBJECT_SYNC sequence after ATTACHED emits SYNCING and then SYNCED">
    </testcase>
    <testcase name="realtime/liveobjects Sync events A complete single-message OBJECT_SYNC after ATTACHED emits SYNCING and then SYNCED" time="0.141" classname="A complete single-message OBJECT_SYNC after ATTACHED emits SYNCING and then SYNCED">
    </testcase>
    <testcase name="realtime/liveobjects Sync events SYNCED is not emitted midway through a multi-message OBJECT_SYNC sequence" time="0.072" classname="SYNCED is not emitted midway through a multi-message OBJECT_SYNC sequence">
    </testcase>
    <testcase name="realtime/liveobjects Sync events A complete multi-message OBJECT_SYNC sequence when already SYNCED emits SYNCING and then SYNCED" time="0.046" classname="A complete multi-message OBJECT_SYNC sequence when already SYNCED emits SYNCING and then SYNCED">
    </testcase>
    <testcase name="realtime/liveobjects Sync events A complete single-message OBJECT_SYNC when already SYNCED emits SYNCING and then SYNCED" time="0.200" classname="A complete single-message OBJECT_SYNC when already SYNCED emits SYNCING and then SYNCED">
    </testcase>
    <testcase name="realtime/liveobjects Sync events A new OBJECT_SYNC sequence in the middle of a sync sequence does not provoke another SYNCING" time="0.043" classname="A new OBJECT_SYNC sequence in the middle of a sync sequence does not provoke another SYNCING">
    </testcase>
  </testsuite>
</testsuites>