midi-test
TypeScript icon, indicating that this package has built-in type declarations

1.3.0 • Public • Published

midi-test

npm npm build

Virtual MIDI ports for testing MIDI applications

See also: web-midi-test, test-midi-files

Install: npm install midi-test --save-dev

Manual rebuild (if needed): node-gyp rebuild

API

MIDI Source (Virtual MIDI-In)

var MT = require('midi-test');
var port = new MT.MidiSrc('VIRTUAL MIDI-In');
port.connect();
port.emit([0x90, 0x40, 0x7f]);
//...
port.disconnect();

MIDI Destination (Virtual MIDI-Out)

var MT = require('midi-test');
var port = new MT.MidiDst('VIRTUAL MIDI-Out');
port.receive = function(msg) { console.log('received:', msg); };
port.connect();
//...
port.disconnect();

TypeScript

import * as MT from 'midi-test'
//...

Developer notes

midi-test currently works in Linux and MacOS.
Windows version may appear some day in the future, but it is not in the immediate plans.

This package requires Node.js v20 or above, and the full stack of node-gyp build tools.
(for older versions of Node please use midi-test v1.2.9)
Linux build also requires the ALSA libraries: apt-get install libasound2-dev

Since the Linux version needs special permissions to access the computer's sound system,
it may not work properly in virtual Linux environments such as the one at Travis-CI or GitHub Actions.

To make your test work with Travis-CI or GitHub Actions, run it on MacOS.
in .travis.yml:

os:
  - osx
...

in .github/workflows/*.yml:

jobs:
  build-macos:
    runs-on: macos-latest
  ...

If you are getting a build error related to Python 3.12, you may want to add this build step (see the build.yml file):

- run: python -m pip install --upgrade packaging pip setuptools

Readme

Keywords

Package Sidebar

Install

npm i midi-test

Weekly Downloads

28

Version

1.3.0

License

MIT

Unpacked Size

38.8 kB

Total Files

19

Last publish

Collaborators

  • jazz-soft