Socket
Socket
Sign inDemoInstall

@ovotech/avro-mock-generator

Package Overview
Dependencies
Maintainers
354
Versions
15
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@ovotech/avro-mock-generator

Generate mock messages from an avro schema


Version published
Maintainers
354
Created
Source

Avro Mock Generator

Create mock messages from Avro schemas.

Usage

Call the generator with the schema:

import generateMsg from '@ovotech/avro-mock-generator'

const schema = {
  type: 'record',
  fields: [{ name: 'nbChickens', type: 'int' }],
}
console.log(generateData(schema));

// { nbChickens: 25672672 }

All fields will contain randomly generated data that respects their type.

Options

An options object can optionnaly be provide as the second argument.

Supported Options:

  • generators: An key/value object of generator functions.
    • key: the type (or logicalType)
    • value: should be a generator function (type, context) => value where - type: the content of the type field in the schema, either a string for simple type, or the type configuration for complex types - context: an object with contextual data, including the generators It is possible to override the default generators, and add support for extra types/logicalTypes by providing
  • pickUnion: Array of strings to drive which member of union type to choose. Can be the short name of fully namespaced names. When this option is not provided, the first element in the union will be chosen

Reproducible generation

Use the Seeded factory to create a version of the generator that will use deterministic randomness.

The factory will return a function with the same signature as the default generator.

Supported Avro features

Based on the Avro 1.9.0 specification.

  • All primitive types
  • All logical types
    • including custom logicalTypes using the options parameter. If a logicalType is missing a generator, data will be generated matching the underlying type.
  • All complex types
    • Note that for enum types, the first element of the array will always be chosen.
  • Type Alias

Partial support for namespaces. Only union types are namespaced, unconditionally.

Contributing

All contributions are welcome, just fork the repository then create a PR. Once merged we will release a new version.

Releasing

Simply create a new release on master, with the tag being the new version (eg: 1.0.0).

Keywords

FAQs

Package last updated on 28 Oct 2022

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc