2024-10-08 07:15:26 +00:00
|
|
|
import { describe, expect, it, beforeAll } from 'vitest'
|
2024-10-09 14:47:31 +00:00
|
|
|
import { mount } from '@vue/test-utils';
|
|
|
|
import { defineComponent, Component } from 'vue'
|
|
|
|
import { useFormatTypes, FormatTypeStore } from '../use-format-types';
|
2024-10-08 07:15:26 +00:00
|
|
|
import { create, removeReservedCharacters } from '../create';
|
|
|
|
import { OBJECT_REPLACEMENT_CHARACTER, ZWNBSP } from '../special-characters';
|
|
|
|
import { createElement } from '../create-element';
|
|
|
|
import { getSparseArrayLength, spec, specWithRegistration } from './helpers';
|
|
|
|
|
|
|
|
describe( 'create', () => {
|
2024-10-09 14:47:31 +00:00
|
|
|
const em = { type: 'em', attributes: {} };
|
|
|
|
const strong = { type: 'strong', attributes: {} };
|
2024-10-08 07:15:26 +00:00
|
|
|
|
2024-10-09 14:47:31 +00:00
|
|
|
let TestComponent: Component;
|
|
|
|
let store: FormatTypeStore;
|
|
|
|
beforeAll(async () => {
|
|
|
|
TestComponent = defineComponent({
|
|
|
|
setup () {
|
|
|
|
return useFormatTypes();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
store = mount(TestComponent).vm;
|
|
|
|
});
|
2024-10-08 07:15:26 +00:00
|
|
|
|
|
|
|
spec.forEach( ( { description, html, createRange, record } ) => {
|
|
|
|
if ( html === undefined ) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// eslint-disable-next-line jest/valid-title
|
|
|
|
it( description, () => {
|
|
|
|
const element = createElement( document, html );
|
|
|
|
const range = createRange( element );
|
|
|
|
const createdRecord = create( {
|
|
|
|
element,
|
|
|
|
range,
|
2024-10-09 14:47:31 +00:00
|
|
|
}, store );
|
2024-10-08 07:15:26 +00:00
|
|
|
const formatsLength = getSparseArrayLength( record.formats );
|
|
|
|
const createdFormatsLength = getSparseArrayLength(
|
|
|
|
createdRecord.formats
|
|
|
|
);
|
|
|
|
|
|
|
|
expect( createdRecord ).toEqual( record );
|
|
|
|
expect( createdFormatsLength ).toEqual( formatsLength );
|
|
|
|
} );
|
|
|
|
} );
|
|
|
|
|
|
|
|
specWithRegistration.forEach(
|
|
|
|
( {
|
|
|
|
description,
|
|
|
|
formatName,
|
|
|
|
formatType,
|
|
|
|
html,
|
|
|
|
value: expectedValue,
|
|
|
|
} ) => {
|
|
|
|
// eslint-disable-next-line jest/valid-title
|
|
|
|
it( description, () => {
|
|
|
|
if ( formatName ) {
|
2024-10-09 14:47:31 +00:00
|
|
|
store.registerFormatTypes( formatName, formatType );
|
2024-10-08 07:15:26 +00:00
|
|
|
}
|
|
|
|
|
2024-10-09 14:47:31 +00:00
|
|
|
const result = create({ html }, store);
|
2024-10-08 07:15:26 +00:00
|
|
|
|
|
|
|
if ( formatName ) {
|
2024-10-09 14:47:31 +00:00
|
|
|
store.unregisterFormatTypes( formatName );
|
2024-10-08 07:15:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
expect( result ).toEqual( expectedValue );
|
|
|
|
} );
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
|
|
|
it( 'should reference formats', () => {
|
2024-10-09 14:47:31 +00:00
|
|
|
const value = create( { html: '<em>te<strong>st</strong></em>' }, store );
|
2024-10-08 07:15:26 +00:00
|
|
|
|
|
|
|
expect( value ).toEqual( {
|
|
|
|
formats: [ [ em ], [ em ], [ em, strong ], [ em, strong ] ],
|
|
|
|
replacements: [ , , , , ],
|
|
|
|
text: 'test',
|
|
|
|
} );
|
|
|
|
|
|
|
|
// Format objects.
|
|
|
|
expect( value.formats[ 0 ][ 0 ] ).toBe( value.formats[ 1 ][ 0 ] );
|
|
|
|
expect( value.formats[ 0 ][ 0 ] ).toBe( value.formats[ 2 ][ 0 ] );
|
|
|
|
expect( value.formats[ 2 ][ 1 ] ).toBe( value.formats[ 3 ][ 1 ] );
|
|
|
|
|
|
|
|
// Format arrays per index.
|
|
|
|
expect( value.formats[ 0 ] ).toBe( value.formats[ 1 ] );
|
|
|
|
expect( value.formats[ 2 ] ).toBe( value.formats[ 3 ] );
|
|
|
|
} );
|
|
|
|
|
|
|
|
it( 'should use different reference for equal format', () => {
|
2024-10-09 14:47:31 +00:00
|
|
|
const value = create( { html: '<a href="#">a</a><a href="#">a</a>' }, store );
|
2024-10-08 07:15:26 +00:00
|
|
|
|
|
|
|
// Format objects.
|
|
|
|
expect( value.formats[ 0 ][ 0 ] ).not.toBe( value.formats[ 1 ][ 0 ] );
|
|
|
|
|
|
|
|
// Format arrays per index.
|
|
|
|
expect( value.formats[ 0 ] ).not.toBe( value.formats[ 1 ] );
|
|
|
|
} );
|
|
|
|
|
|
|
|
it( 'should use different reference for different format', () => {
|
2024-10-09 14:47:31 +00:00
|
|
|
const value = create( { html: '<a href="#">a</a><a href="#a">a</a>' }, store );
|
2024-10-08 07:15:26 +00:00
|
|
|
|
|
|
|
// Format objects.
|
|
|
|
expect( value.formats[ 0 ][ 0 ] ).not.toBe( value.formats[ 1 ][ 0 ] );
|
|
|
|
|
|
|
|
// Format arrays per index.
|
|
|
|
expect( value.formats[ 0 ] ).not.toBe( value.formats[ 1 ] );
|
|
|
|
} );
|
|
|
|
|
|
|
|
it( 'removeReservedCharacters should remove all reserved characters', () => {
|
|
|
|
expect(
|
|
|
|
removeReservedCharacters( `${ OBJECT_REPLACEMENT_CHARACTER }` )
|
|
|
|
).toEqual( '' );
|
|
|
|
expect( removeReservedCharacters( `${ ZWNBSP }` ) ).toEqual( '' );
|
|
|
|
expect(
|
|
|
|
removeReservedCharacters(
|
|
|
|
`${ OBJECT_REPLACEMENT_CHARACTER }c${ OBJECT_REPLACEMENT_CHARACTER }at${ OBJECT_REPLACEMENT_CHARACTER }`
|
|
|
|
)
|
|
|
|
).toEqual( 'cat' );
|
|
|
|
expect(
|
|
|
|
removeReservedCharacters( `${ ZWNBSP }b${ ZWNBSP }at${ ZWNBSP }` )
|
|
|
|
).toEqual( 'bat' );
|
|
|
|
expect(
|
|
|
|
removeReservedCharacters(
|
|
|
|
`te${ OBJECT_REPLACEMENT_CHARACTER }st${ ZWNBSP }${ ZWNBSP }`
|
|
|
|
)
|
|
|
|
).toEqual( 'test' );
|
|
|
|
} );
|
|
|
|
} );
|