import { Case, Grammeme, NounGrams, Plurality, VerbGrams } from './language'; import { getCompatibleGrams, grammemeCompare, parseEntityReference, parseGrammemes, parseSyntacticReference, wordFormEquals } from './languageAPI'; describe('Testing wordform equality', () => { test('empty input', () => { expect(wordFormEquals({text: '', grams: []}, {text: '', grams: []})).toEqual(true); expect(wordFormEquals({text: '', grams: []}, {text: '11', grams: []})).toEqual(true); expect(wordFormEquals({text: '11', grams: []}, {text: '', grams: []})).toEqual(true); expect(wordFormEquals({text: '11', grams: []}, {text: '42', grams: []})).toEqual(true); expect(wordFormEquals({text: '', grams: ['nomn']}, {text: '', grams: []})).toEqual(false); expect(wordFormEquals({text: '11', grams: ['nomn']}, {text: '11', grams: []})).toEqual(false); expect(wordFormEquals({text: '', grams: []}, {text: '', grams: ['nomn']})).toEqual(false); expect(wordFormEquals({text: '11', grams: []}, {text: '11', grams: ['nomn']})).toEqual(false); }); test('regular grammemes', () => { expect(wordFormEquals({text: '', grams: ['nomn']}, {text: '', grams: ['nomn']})).toEqual(true); expect(wordFormEquals({text: '', grams: ['nomn']}, {text: '', grams: ['sing']})).toEqual(false); expect(wordFormEquals({text: '', grams: ['nomn', 'sing']}, {text: '', grams: ['nomn', 'sing']})).toEqual(true); expect(wordFormEquals({text: '', grams: ['nomn', 'sing']}, {text: '11', grams: ['nomn', 'sing']})).toEqual(true); expect(wordFormEquals({text: '11', grams: ['nomn', 'sing']}, {text: '', grams: ['nomn', 'sing']})).toEqual(true); expect(wordFormEquals({text: '11', grams: ['nomn', 'sing']}, {text: '11', grams: ['nomn', 'sing']})).toEqual(true); expect(wordFormEquals({text: '42', grams: ['nomn', 'sing']}, {text: '11', grams: ['nomn', 'sing']})).toEqual(true); expect(wordFormEquals({text: '', grams: ['nomn', 'sing']}, {text: '', grams: ['sing', 'nomn']})).toEqual(false); expect(wordFormEquals({text: '', grams: ['nomn', 'sing']}, {text: '', grams: ['nomn']})).toEqual(false); expect(wordFormEquals({text: '', grams: ['nomn', 'nomn']}, {text: '', grams: ['nomn']})).toEqual(false); }); test('custom grammemes', () => { expect(wordFormEquals({text: '', grams: ['с1']}, {text: '', grams: ['с1']})).toEqual(true); expect(wordFormEquals({text: '', grams: ['с1']}, {text: '', grams: ['с2']})).toEqual(false); expect(wordFormEquals({text: '', grams: ['sing']}, {text: '', grams: ['с1']})).toEqual(false); }); }); describe('Testing grammeme ordering', () => { test('empty input', () => { expect(grammemeCompare('', '')).toEqual(0); expect(grammemeCompare(' ', ' ')).toEqual(0); expect(grammemeCompare('', '123')).toBeLessThan(0); expect(grammemeCompare('123', '')).toBeGreaterThan(0); }); test('regular grammemes', () => { expect(grammemeCompare('NOUN', 'NOUN')).toEqual(0); expect(grammemeCompare('NOUN', Grammeme.NOUN)).toEqual(0); expect(grammemeCompare(Grammeme.sing, Grammeme.plur)).toBeLessThan(0); expect(grammemeCompare('sing', 'plur')).toBeLessThan(0); expect(grammemeCompare('plur', 'sing')).toBeGreaterThan(0); expect(grammemeCompare('NOUN', 'ADJF')).toBeLessThan(0); expect(grammemeCompare('ADJF', 'NOUN')).toBeGreaterThan(0); expect(grammemeCompare('ADJS', 'NOUN')).toBeGreaterThan(0); expect(grammemeCompare('ADJS', 'ADJF')).toBeGreaterThan(0); expect(grammemeCompare('loct', 'ablt')).toBeGreaterThan(0); expect(grammemeCompare('ablt', 'accs')).toBeGreaterThan(0); expect(grammemeCompare('accs', 'datv')).toBeGreaterThan(0); expect(grammemeCompare('datv', 'gent')).toBeGreaterThan(0); expect(grammemeCompare('gent', 'nomn')).toBeGreaterThan(0); }); test('custom grammemes', () => { expect(grammemeCompare('noun', 'noun')).toEqual(0); expect(grammemeCompare('NOUN', 'noun')).toBeLessThan(0); expect(grammemeCompare('PRTF', 'noun')).toBeLessThan(0); expect(grammemeCompare('noun', 'NOUN')).toBeGreaterThan(0); expect(grammemeCompare('aab', 'aaa')).toBeGreaterThan(0); expect(grammemeCompare('aaa', 'aab')).toBeLessThan(0); expect(grammemeCompare('test', 'abcd')).toBeGreaterThan(0); }); }); describe('Testing grammeme parsing', () => { test('empty input', () => { expect(parseGrammemes('')).toStrictEqual([]); expect(parseGrammemes(' ')).toStrictEqual([]); expect(parseGrammemes(' , ')).toStrictEqual([]); }); test('regular grammemes', () => { expect(parseGrammemes('NOUN')).toStrictEqual([Grammeme.NOUN]); expect(parseGrammemes('sing,nomn')).toStrictEqual([Grammeme.sing, Grammeme.nomn]); expect(parseGrammemes('nomn,sing')).toStrictEqual([Grammeme.sing, Grammeme.nomn]); }); test('custom grammemes', () => { expect(parseGrammemes('nomn,invalid,sing')).toStrictEqual([Grammeme.sing, Grammeme.nomn, 'invalid']); expect(parseGrammemes('invalid,test')).toStrictEqual(['invalid', 'test']); }); }); describe('Testing grammeme compatibility', () => { test('empty input', () => { expect(getCompatibleGrams([])).toStrictEqual([...VerbGrams, ...NounGrams]); }); test('regular grammemes', () => { expect(getCompatibleGrams([Grammeme.NOUN])).toStrictEqual([...Case, ...Plurality]); }); }); describe('Testing reference parsing', () => { test('entity reference', () => { expect(parseEntityReference('@{ X1 | NOUN,sing }')).toStrictEqual({entity: 'X1', form: 'NOUN,sing'}); expect(parseEntityReference('@{X1|NOUN,sing}')).toStrictEqual({entity: 'X1', form: 'NOUN,sing'}); expect(parseEntityReference('@{X111|NOUN,sing}')).toStrictEqual({entity: 'X111', form: 'NOUN,sing'}); }); test('syntactic reference', () => { expect(parseSyntacticReference('@{1|test test}')).toStrictEqual({offset: 1, nominal: 'test test'}); expect(parseSyntacticReference('@{101|test test}')).toStrictEqual({offset: 101, nominal: 'test test'}); expect(parseSyntacticReference('@{-1|test test}')).toStrictEqual({offset: -1, nominal: 'test test'}); expect(parseSyntacticReference('@{-99|test test}')).toStrictEqual({offset: -99, nominal: 'test test'}); }); });