123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336 |
- import { BabelPolyfill } from 'polyfills/BabelPolyfill';
- import { IBlockStatementNode } from "../src/interfaces/nodes/IBlockStatementNode";
- import { IFunctionDeclarationNode } from "../src/interfaces/nodes/IFunctionDeclarationNode";
- import { IIdentifierNode } from "../src/interfaces/nodes/IIdentifierNode";
- import { IIfStatementNode } from "../src/interfaces/nodes/IIfStatementNode";
- import { ILiteralNode } from "../src/interfaces/nodes/ILiteralNode";
- import { INode } from "../src/interfaces/nodes/INode";
- import { IProgramNode } from "../src/interfaces/nodes/IProgramNode";
- import { NodeType } from "../src/enums/NodeType";
- import { NodeUtils } from '../src/NodeUtils';
- const assert: any = require('chai').assert;
- BabelPolyfill.append();
- function getProgramNode (bodyNodes: INode[] = []): IProgramNode {
- return {
- type: NodeType.Program,
- body: bodyNodes
- };
- }
- function getBlockStatementNode (bodyNodes: INode[] = []): IBlockStatementNode {
- return {
- type: NodeType.BlockStatement,
- body: bodyNodes
- };
- }
- function getFunctionDeclarationNode (blockStatementNode: IBlockStatementNode): IFunctionDeclarationNode {
- return {
- type: NodeType.FunctionDeclaration,
- id: {
- type: NodeType.Identifier,
- name: 'test'
- },
- params: [],
- body: blockStatementNode,
- generator: false,
- expression: false
- };
- }
- function getIfStatementNode (blockStatementNode: IBlockStatementNode): IIfStatementNode {
- return {
- type: 'IfStatement',
- test: {
- type: 'Literal',
- value: true,
- raw: 'true'
- },
- consequent: blockStatementNode,
- alternate: null
- };
- }
- function getIdentifierNode (): IIdentifierNode {
- return {
- type: NodeType.Identifier,
- name: 'identifier',
- };
- }
- function getLiteralNode (): ILiteralNode {
- return {
- type: NodeType.Literal,
- value: 'string',
- raw: `'string'`,
- 'x-verbatim-property': `'string'`
- };
- }
- describe('NodeUtils', () => {
- describe('addXVerbatimPropertyToLiterals (node: INode): void', () => {
- let literalNode: any,
- expectedLiteralNode: any;
- beforeEach(() => {
- literalNode = getLiteralNode();
- expectedLiteralNode = Object.assign({}, literalNode);
- expectedLiteralNode['x-verbatim-property'] = `'string'`;
- NodeUtils.addXVerbatimPropertyToLiterals(literalNode);
- });
- it('should add `x-verbatim-property` to `Literal` node', () => {
- assert.deepEqual(literalNode, expectedLiteralNode);
- });
- });
- describe('appendNode (blockScopeBody: INode[], node: INode): void', () => {
- let blockStatementNode: IBlockStatementNode,
- expectedBlockStatementNode: IBlockStatementNode,
- identifierNode: IIdentifierNode;
- beforeEach(() => {
- identifierNode = getIdentifierNode();
- blockStatementNode = getBlockStatementNode();
- expectedBlockStatementNode = Object.assign({}, blockStatementNode);
- expectedBlockStatementNode.body.push(identifierNode);
- NodeUtils.appendNode(blockStatementNode.body, identifierNode);
- });
- it('should append given node to a `BlockStatement` node body', () => {
- assert.deepEqual(blockStatementNode, expectedBlockStatementNode);
- });
- it('should does not change `BlockStatement` node body if given node is not a valid Node', () => {
- assert.doesNotChange(
- () => NodeUtils.appendNode(blockStatementNode.body, <INode>null),
- blockStatementNode,
- 'body'
- );
- assert.doesNotChange(
- () => NodeUtils.appendNode(blockStatementNode.body, <INode>{}),
- blockStatementNode,
- 'body'
- );
- });
- });
- describe('getBlockStatementNodeByIndex (node: INode, index: number = 0): INode', () => {
- let blockStatementNode: IBlockStatementNode,
- identifierNode: IIdentifierNode,
- literalNode: ILiteralNode;
- beforeEach(() => {
- identifierNode = getIdentifierNode();
- literalNode = getLiteralNode();
- blockStatementNode = getBlockStatementNode([
- identifierNode,
- literalNode
- ]);
- });
- it('should return block-statement child node of given node if that node has block-statement', () => {
- assert.deepEqual(NodeUtils.getBlockStatementNodeByIndex(blockStatementNode), identifierNode);
- assert.deepEqual(NodeUtils.getBlockStatementNodeByIndex(blockStatementNode, 1), literalNode);
- });
- it('should throw a `ReferenceError` if index is out of boundaries', () => {
- assert.throws(() => NodeUtils.getBlockStatementNodeByIndex(blockStatementNode, 2), ReferenceError);
- });
- it('should throw a `TypeError` if node have no a block-statement', () => {
- assert.throws(() => NodeUtils.getBlockStatementNodeByIndex(identifierNode, 1), TypeError);
- });
- });
- describe('getBlockScopeOfNode (node: INode, depth: number = 0): TNodeWithBlockStatement', () => {
- let functionDeclarationBlockStatementNode: IBlockStatementNode,
- ifStatementBlockStatementNode1: IBlockStatementNode,
- ifStatementBlockStatementNode2: IBlockStatementNode,
- ifStatementNode1: IIfStatementNode,
- ifStatementNode2: IIfStatementNode,
- identifierNode: IIdentifierNode,
- functionDeclarationNode: IFunctionDeclarationNode,
- literalNode1: ILiteralNode,
- literalNode2: ILiteralNode,
- programNode: IProgramNode;
- beforeEach(() => {
- identifierNode = getIdentifierNode();
- literalNode1 = getLiteralNode();
- literalNode2 = getLiteralNode();
- ifStatementBlockStatementNode2 = getBlockStatementNode([
- literalNode1,
- literalNode2
- ]);
- ifStatementNode2 = getIfStatementNode(ifStatementBlockStatementNode2);
- ifStatementBlockStatementNode1 = getBlockStatementNode([
- ifStatementNode2
- ]);
- ifStatementNode1 = getIfStatementNode(ifStatementBlockStatementNode1);
- functionDeclarationBlockStatementNode = getBlockStatementNode([
- identifierNode,
- ifStatementNode1
- ]);
- functionDeclarationNode = getFunctionDeclarationNode(functionDeclarationBlockStatementNode);
- programNode = getProgramNode([
- functionDeclarationNode
- ]);
- programNode['parentNode'] = programNode;
- functionDeclarationNode['parentNode'] = programNode;
- functionDeclarationBlockStatementNode['parentNode'] = functionDeclarationNode;
- identifierNode['parentNode'] = functionDeclarationBlockStatementNode;
- ifStatementNode1['parentNode'] = functionDeclarationBlockStatementNode;
- ifStatementBlockStatementNode1['parentNode'] = ifStatementNode1;
- ifStatementNode2['parentNode'] = ifStatementBlockStatementNode1;
- ifStatementBlockStatementNode2['parentNode'] = ifStatementNode2;
- literalNode1['parentNode'] = ifStatementBlockStatementNode2;
- });
- it('should return block-scope node for given node', () => {
- assert.deepEqual(NodeUtils.getBlockScopeOfNode(identifierNode), functionDeclarationBlockStatementNode);
- assert.deepEqual(NodeUtils.getBlockScopeOfNode(identifierNode, 1), programNode);
- assert.deepEqual(NodeUtils.getBlockScopeOfNode(functionDeclarationNode), programNode);
- assert.deepEqual(NodeUtils.getBlockScopeOfNode(functionDeclarationBlockStatementNode), programNode);
- assert.deepEqual(NodeUtils.getBlockScopeOfNode(programNode), programNode);
- assert.deepEqual(NodeUtils.getBlockScopeOfNode(literalNode1), functionDeclarationBlockStatementNode);
- });
- it('should throw a `ReferenceError` if node has no `parentNode` property', () => {
- assert.throws(() => NodeUtils.getBlockScopeOfNode(literalNode2), ReferenceError);
- });
- });
- describe('insertNodeAtIndex (blockScopeBody: INode[], node: INode, index: number): void', () => {
- let blockStatementNode: IBlockStatementNode,
- expectedBlockStatementNode: IBlockStatementNode,
- identifierNode: IIdentifierNode,
- literalNode: ILiteralNode;
- beforeEach(() => {
- identifierNode = getIdentifierNode();
- literalNode = getLiteralNode();
- blockStatementNode = getBlockStatementNode([
- identifierNode
- ]);
- expectedBlockStatementNode = Object.assign({}, blockStatementNode);
- expectedBlockStatementNode['body'].push(literalNode);
- NodeUtils.insertNodeAtIndex(blockStatementNode.body, literalNode, 1);
- });
- it('should insert given node in `BlockStatement` node body at index', () => {
- assert.deepEqual(blockStatementNode, expectedBlockStatementNode);
- });
- it('should does not change `BlockStatement` node body if given node is not a valid Node', () => {
- assert.doesNotChange(
- () => NodeUtils.insertNodeAtIndex(blockStatementNode.body, <INode>null, 1),
- blockStatementNode,
- 'body'
- );
- assert.doesNotChange(
- () => NodeUtils.insertNodeAtIndex(blockStatementNode.body, <INode>{}, 1),
- blockStatementNode,
- 'body'
- );
- });
- });
- describe('parentize (node: INode): void', () => {
- let blockStatementNode: IBlockStatementNode,
- identifierNode: IIdentifierNode,
- literalNode: ILiteralNode,
- programNode: IProgramNode;
- beforeEach(() => {
- identifierNode = getIdentifierNode();
- literalNode = getLiteralNode();
- blockStatementNode = getBlockStatementNode([
- identifierNode,
- literalNode
- ]);
- programNode = getProgramNode([
- blockStatementNode
- ]);
- NodeUtils.parentize(blockStatementNode);
- });
- it('should parentize given AST-tree', () => {
- assert.deepEqual(blockStatementNode['parentNode'], programNode);
- assert.deepEqual(identifierNode['parentNode'], blockStatementNode);
- assert.deepEqual(literalNode['parentNode'], blockStatementNode);
- });
- });
- describe('prependNode (blockScopeBody: INode[], node: INode): void', () => {
- let blockStatementNode: IBlockStatementNode,
- expectedBlockStatementNode: IBlockStatementNode,
- identifierNode: IIdentifierNode,
- literalNode: ILiteralNode;
- beforeEach(() => {
- identifierNode = getIdentifierNode();
- literalNode = getLiteralNode();
- blockStatementNode = getBlockStatementNode([
- identifierNode
- ]);
- expectedBlockStatementNode = Object.assign({}, blockStatementNode);
- expectedBlockStatementNode['body'].unshift(literalNode);
- NodeUtils.prependNode(blockStatementNode.body, literalNode);
- });
- it('should prepend given node to a `BlockStatement` node body', () => {
- assert.deepEqual(blockStatementNode, expectedBlockStatementNode);
- });
- it('should does not change `BlockStatement` node body if given node is not a valid Node', () => {
- assert.doesNotChange(
- () => NodeUtils.prependNode(blockStatementNode.body, <INode>null),
- blockStatementNode,
- 'body'
- );
- assert.doesNotChange(
- () => NodeUtils.prependNode(blockStatementNode.body, <INode>{}),
- blockStatementNode,
- 'body'
- );
- });
- });
- });
|