test(plugin-tools): add some tests for the sanitizeMigrationName function

This commit is contained in:
Joakim Carlstein 2023-11-10 14:49:27 +01:00
parent 4e2a27ffeb
commit e159cd17bd
4 changed files with 149 additions and 2 deletions

View file

@ -0,0 +1,38 @@
import { describe, it } from 'node:test';
import assert from 'node:assert';
import { sanitizeMigrationName } from './index.js';
describe('sanitizeMigrationName', () => {
it('should replace spaces with underscores', () => {
assert.strictEqual(sanitizeMigrationName('foo bar'), 'foo_bar');
});
it('should replace disallowed filename characters with underscores', () => {
assert.strictEqual(sanitizeMigrationName('foo>bar'), 'foo_bar');
assert.strictEqual(sanitizeMigrationName('foo<bar'), 'foo_bar');
assert.strictEqual(sanitizeMigrationName('foo?bar'), 'foo_bar');
assert.strictEqual(sanitizeMigrationName('foo:bar'), 'foo_bar');
assert.strictEqual(sanitizeMigrationName('foo/bar'), 'foo_bar');
assert.strictEqual(sanitizeMigrationName('foo\\bar'), 'foo_bar');
assert.strictEqual(sanitizeMigrationName('foo*bar'), 'foo_bar');
assert.strictEqual(sanitizeMigrationName('foo|bar'), 'foo_bar');
assert.strictEqual(sanitizeMigrationName('foo"bar'), 'foo_bar');
assert.strictEqual(sanitizeMigrationName("foo'bar"), 'foo_bar');
});
it('should replace consecutive disallowed characters with only one underscore', () => {
assert.strictEqual(sanitizeMigrationName('foo? :bar'), 'foo_bar');
});
it('should remove leading disallowed characters', () => {
assert.strictEqual(sanitizeMigrationName('_? :*<>foo'), 'foo');
});
it('should remove trailing disallowed characters', () => {
assert.strictEqual(sanitizeMigrationName('foo_? :*<>'), 'foo');
});
it('should lower case the filename', () => {
assert.strictEqual(sanitizeMigrationName('Are you, Foo?'), 'are_you_foo');
});
});