ConceptPortal-public/rsconcept/frontend/src/components/RSInput/rslang/parser.test.ts
2023-12-26 14:46:46 +03:00

48 lines
3.7 KiB
TypeScript
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

import { printTree } from '@/utils/codemirror';
import { parser } from './parser';
const testData = [
['a1', '[Expression[Local[Index]]]'],
['A1', '[Expression[Global]]'],
['∅', '[Expression[Literal]]'],
['Z', '[Expression[Literal]]'],
['1', '[Expression[Literal]]'],
['12<41', '[Expression[LogicPredicate[Literal][<][Literal]]]'],
['12=41', '[Expression[LogicPredicate[Literal][=][Literal]]]'],
['ξ=ξ', '[Expression[LogicPredicate[Local][=][Local]]]'],
['0-5', '[Expression[BinaryOperation[Literal][-][Literal]]]'],
['¬2=2', '[Expression[LogicNegation[¬][LogicPredicate[Literal][=][Literal]]]]'],
['12+41', '[Expression[BinaryOperation[Literal][+][Literal]]]'],
['1+2*5', '[Expression[BinaryOperation[BinaryOperation[Literal][+][Literal]][*][Literal]]]'],
['a1Z', '[Expression[BinaryOperation[Local[Index]][][Literal]]]'],
['Pr1(X1)', '[Expression[TextFunctionExpression[TextFunction[ComplexIndex]][(][Global][)]]]'],
['Pr11(X1)', '[Expression[TextFunctionExpression[TextFunction[ComplexIndex]][(][Global][)]]]'],
['Pr11,21(X1)', '[Expression[TextFunctionExpression[TextFunction[ComplexIndex]][(][Global][)]]]'],
['pr1(S1)', '[Expression[TextFunctionExpression[TextFunction[ComplexIndex]][(][Global][)]]]'],
['Pr1,2(X1)', '[Expression[TextFunctionExpression[TextFunction[ComplexIndex]][(][Global][)]]]'],
['card(X1)', '[Expression[TextFunctionExpression[TextFunction][(][Global][)]]]'],
['red(X1)', '[Expression[TextFunctionExpression[TextFunction][(][Global][)]]]'],
['bool(X1)', '[Expression[TextFunctionExpression[TextFunction][(][Global][)]]]'],
['debool(X1)', '[Expression[TextFunctionExpression[TextFunction][(][Global][)]]]'],
['Fi1,2[ξ, ξ](ξ)', '[Expression[TextFunctionExpression[Filter[ComplexIndex]][[][Local][Local][]][(][Local][)]]]'],
['(X1)', '[Expression[Boolean[][Boolean[][(][Global][)]]]]'],
['P2[S1]', '[Expression[PredicateCall[Predicate][[][Global][]]]]'],
['[σ∈R1×R1] F6[σ]', '[Expression[FunctionDeclaration[[][Local][∈][BinaryOperation[Radical][×][Radical]][]][FunctionCall[Function][[][Local][]]]]]'],
['D{ξ∈red(S1) | ξ=ξ}', '[Expression[Declarative[PrefixD][{][Variable[Local]][∈][TextFunctionExpression[TextFunction][(][Global][)]][|][LogicPredicate[Local][=][Local]][}]]]'],
['I{(σ, γ) | σ:∈X1; γ:=F1[σ]; P1[σ, γ]}', '[Expression[Imperative[PrefixI][{][Tuple[(][Local][Local][)]][|][ImperativeBlocks[ImperativeBlocks[ImperativeBlocks[ImperativeIteration[Local][:∈][Global]]][;][ImperativeAssignment[Local][:=][FunctionCall[Function][[][Local][]]]]][;][ImperativeCondition[PredicateCall[Predicate][[][Local][Local][]]]]][}]]]'],
['R{ξ:=D1 | F1[ξ]≠∅ | ξF1[ξ]}', '[Expression[Recursion[PrefixR][{][Variable[Local]][:=][Global][|][LogicPredicate[FunctionCall[Function][[][Local][]]][≠][Literal]][|][BinaryOperation[Local][][FunctionCall[Function][[][Local][]]]][}]]]'],
['∀ξ∈∅ 1=1', '[Expression[LogicQuantor[∀][QuantorVariable[Variable[Local]]][∈][Literal][LogicPredicate[Literal][=][Literal]]]]'],
['∀ξ1∈β (ξ1≠∅ & ∀ξ2∈β ξ1∩ξ2=∅)', '[Expression[LogicQuantor[∀][QuantorVariable[Variable[Local[Index]]]][∈][Local][(][LogicBinary[LogicPredicate[Local[Index]][≠][Literal]][&][LogicQuantor[∀][QuantorVariable[Variable[Local[Index]]]][∈][Local][LogicPredicate[BinaryOperation[Local[Index]][∩][Local[Index]]][=][Literal]]]][)]]]']
];
describe('Testing RSParser', () => {
it.each(testData)('Parse %p',
(input: string, expectedTree: string) => {
// NOTE: use strict parser to determine exact error position
// const tree = parser.configure({strict: true}).parse(input);
const tree = parser.parse(input);
expect(printTree(tree)).toBe(expectedTree);
});
});