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 🙏

© 2024 – Pkg Stats / Ryan Hefner

state-waiter

v1.1.0

Published

Handle async states conveniently.

Downloads

32

Readme

State-Waiter

Handle async states conveniently.

  • Stores the state and make it easy for test cases to hook into transitions.
  • Makes it easy to write shutdown and kill methods. Just supply and implementation.

Installation

npm i state-waiter

Usage

end state

If the end state is defined, it is possible to use the method Waiter.onClose as a callback. The waiter will go into end state immediately, because that's wait the close event means.

shutdown and kill actions

  • Waiter implements wrappers for shutdown and kill to make it easier to explicitly transition to end state.
  • For sync shutdown and kill waiter goes into end state immediately. For async it goes into 'stopping' until the shutdown/kill implementation has finished.
  • Shutdown/kill can be called as many times in what ever order from the outside, the transition will be the same, and all calls will resolve when end state is reached.
  • Shutdown implementation should do a graceful shutdown. Shutdown implementation will only be called once. Shutdown will not be called if kill already has been called.
  • Kill implementation should do efficient shutdown (no grace). Kill implementation will be called each time kill is called.

Waiting for state changes or events

Has limitations, so only useful for testing, for now.

Injecting actions synchronous on state transition or emits events could break its assumptions. One would have to ensure actions have finished and the object is ready for the next tick. But it's worthwhile to have that extra constraint, because it's possible to inject actions at precise transitions or event, which makes white-box test possible. The test case essentially because deterministic.

Known issues

Related work

  • xstate gives a DSL to define finite-state machines and hooks into transitions. And tools for visualizing transition graphs.
  • jssm similar to xstate

API

Waiter: class<States, Events = never>(deps)

Class for representing a waiter.

Parameters:

  • deps: Configuration for the waiter.
    object: {
      startState: States;
      stoppingState?: States;
      endState?: States;
      onError: (error: unknown) => void;
    };

waiter.getState: () => States

Return: The current state.

More methods exists: See source code

License

MIT