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 πŸ™

Β© 2026 – Pkg Stats / Ryan Hefner

@variablesoftware/mock-kv

v0.4.1

Published

πŸŽ›οΈπŸ·οΈβœ¨ Mock KV Namespace for testing Cloudflare Workers

Downloads

85

Readme

@variablesoftware/mock-kv πŸŽ›οΈπŸ·οΈβœ¨

Test Suite NPM version License Coverage Bundle Size Downloads PRs Welcome

Mock Cloudflare KV Namespace for unit and integration testing

πŸŽ›οΈπŸ·οΈβœ¨ @variablesoftware/mock-kv provides an in-memory simulation of Cloudflare Workers KV. It is designed for testing key-value storage logic with expiration, metadata, and batch operations β€” without any external dependencies.


πŸ”§ Installation

yarn add --dev @variablesoftware/mock-kv

This package assumes a test environment with Vitest and support for ESM.


πŸš€ Usage

import { mockKVNamespace } from '@variablesoftware/mock-kv';

const kv = mockKVNamespace();
await kv.put('token-abc', 'value', { expirationTtl: 60 });

const result = await kv.get('token-abc');
console.log(result); // 'value'

🎯 Goals

  • βš™ Match Cloudflare KV behavior closely for testing
  • πŸ§ͺ Support test-safe mocking of put/get/delete/list flows
  • πŸ“¦ No external storage dependencies; uses only in-memory JS objects
  • πŸ“Ž Logging via @variablesoftware/logface is required for test and runtime logging, but does not rely on any external services

✨ Features

Includes matching behavior for edge cases like:

  • Key expiration mid-test

  • list() with prefix collisions and limits

  • Metadata preservation across put/get calls

  • In-memory mock of Cloudflare KVNamespace

  • Supports put, get, delete, list, and metadata options

  • TTL-aware: honors expirationTtl and expiration

  • Returns values as string, ArrayBuffer, or null just like real KV

  • Simulates listing behavior including prefix + limit

  • Supports metadata in put() and getWithMetadata()

  • Compatible with Vitest and any Cloudflare Worker test setup

  • Logs via @variablesoftware/logface

  • Optional .dump() method for inspecting KV state during tests


πŸ§ͺ Test Coverage

Tested using vitest run, with coverage for:

  • put() with TTL and metadata
  • get() and getWithMetadata() matching real behavior
  • delete() and list() consistency
  • Full .dump() snapshots for inspection and debugging

Run tests:

yarn test

🚧 Status

This package is under active development and not yet stable.

Once stable, it will be published as:

"@variablesoftware/mock-kv": "^0.5.0"

πŸ“„ License

MIT Β© Rob Friedman / Variable Software


Built with ❀️ by @variablesoftware
Thank you for downloading and using this project. Pull requests are warmly welcomed!


🌐 Inclusive & Accessible Design

  • Naming, logging, error messages, and tests avoid cultural or ableist bias
  • Avoids assumptions about input/output formats or encodings
  • Faithfully reflects user data β€” no coercion or silent transformations
  • Designed for clarity, predictability, and parity with underlying platforms (e.g., Cloudflare APIs)
  • Works well in diverse, multilingual, and inclusive developer environments