npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

@toba/editor-test

v2.0.4

Published

Helpers for programatically building editor test documents

Downloads

19

Readme

npm package Code style Dependencies DevDependencies

This is a fork of prosemirror-test-builder with these trade-offs:

  • Converted to strict TypeScript

  • Formatted with Prettier

  • Unit test coverage reports

  • Fully compatible (interchangeable) with original ProseMirror modules

  • Distributed as both CommonJS and ESM modules with no bundling

    • Better tree shaking
    • package.json configuration facilitates automatic load of correct module types
  • No direct forum or community support

Original ProseMirror documentation

This is a module used to write tests for ProseMirror. ProseMirror is a well-behaved rich semantic content editor based on contentEditable, with support for collaborative editing and custom document schemas.

This module provides helpers for building ProseMirror documents for tests. It's main file exports a basic schema with list support, and a number of functions, whose name mostly follows the corresponding HTML tag, to create nodes and marks in this schema. The prosemirror-test-builder/dist/build module exports a function that you can use to create such helpers for your own schema.

Node builder functions optionally take an attribute object as their first argument, followed by zero or more child nodes, and return a node with those attributes and children. Children should be either strings (for text nodes), existing nodes, or the result of calling a mark builder. For leaf nodes, you may also pass the builder function itself, without calling it. Mark builder functions work similarly, but return an object representing a set of nodes rather than a single node.

These builders help specifying and retrieving positions in the documents that you created (to avoid needing to count tokens when writing tests). Inside of strings passed as child nodes, angle-brackets <name> syntax can be used to place a tag called name at that position. The angle-bracketed part will not appear in the result node, but is stored in the node's tag property, which is an object mapping tag names to position integers. A string which is only a tag or set of tags may appear everywhere, even in places where text nodes aren't allowed.

So if you've imported doc and p from this module, the expression doc(p("foo<a>")) will return a document containing a single paragraph, and its .tag.a will hold the number 4 (the position at the end of the paragraph).

In addition to defining a function for each mark and node name in the test schema, the module exports the following helpers:

schema: The test schema itself.

p: A builder for paragraph nodes.

pre: A builder for code block nodes.

h1: A builder for heading block nodes with the level attribute defaulting to 1.

h2: A builder for heading block nodes with the level attribute defaulting to 2.

h3: A builder for heading block nodes with the level attribute defaulting to 3.

li: A builder for list item nodes.

ol: A builder for ordered list nodes.

ul: A builder for bullet list nodes.

br: A builder for hard break nodes.

img: A builder for image nodes, with the src attribute defaulting to "img.png".

hr: A builder for horizontal rule nodes.

a: A builder for link marks.

The dist/build submodule exports a single function which can be called with a schema and an optional object of renamed/configured builders to create a object of builders for a custom schema. It will return an object with a schema property and one builder for each node and mark in the schema. The second argument can be used to add custom builders—if given, it should be an object mapping names to attribute objects, which may contain a nodeType or markType property to specify which node or mark the builder by this name should create.

License

This module is open source and distributed under an MIT license.

We aim to be an inclusive, welcoming community. To make that explicit, we have a code of conduct that applies to communication around the project.