|
@@ -1,8 +1,7 @@
|
|
import { IBlockStatementNode } from "../src/interfaces/nodes/IBlockStatementNode";
|
|
import { IBlockStatementNode } from "../src/interfaces/nodes/IBlockStatementNode";
|
|
|
|
+import { IExpressionStatementNode } from "../src/interfaces/nodes/IExpressionStatementNode";
|
|
import { IFunctionDeclarationNode } from "../src/interfaces/nodes/IFunctionDeclarationNode";
|
|
import { IFunctionDeclarationNode } from "../src/interfaces/nodes/IFunctionDeclarationNode";
|
|
-import { IIdentifierNode } from "../src/interfaces/nodes/IIdentifierNode";
|
|
|
|
import { IIfStatementNode } from "../src/interfaces/nodes/IIfStatementNode";
|
|
import { IIfStatementNode } from "../src/interfaces/nodes/IIfStatementNode";
|
|
-import { ILiteralNode } from "../src/interfaces/nodes/ILiteralNode";
|
|
|
|
import { INode } from "../src/interfaces/nodes/INode";
|
|
import { INode } from "../src/interfaces/nodes/INode";
|
|
import { IProgramNode } from "../src/interfaces/nodes/IProgramNode";
|
|
import { IProgramNode } from "../src/interfaces/nodes/IProgramNode";
|
|
|
|
|
|
@@ -33,17 +32,17 @@ describe('NodeUtils', () => {
|
|
describe('appendNode (blockScopeBody: INode[], node: INode): void', () => {
|
|
describe('appendNode (blockScopeBody: INode[], node: INode): void', () => {
|
|
let blockStatementNode: IBlockStatementNode,
|
|
let blockStatementNode: IBlockStatementNode,
|
|
expectedBlockStatementNode: IBlockStatementNode,
|
|
expectedBlockStatementNode: IBlockStatementNode,
|
|
- identifierNode: IIdentifierNode;
|
|
|
|
|
|
+ expressionStatementNode: IExpressionStatementNode;
|
|
|
|
|
|
beforeEach(() => {
|
|
beforeEach(() => {
|
|
- identifierNode = NodeMocks.getIdentifierNode();
|
|
|
|
|
|
+ expressionStatementNode = NodeMocks.getExpressionStatementNode();
|
|
|
|
|
|
blockStatementNode = NodeMocks.getBlockStatementNode();
|
|
blockStatementNode = NodeMocks.getBlockStatementNode();
|
|
|
|
|
|
expectedBlockStatementNode = Object.assign({}, blockStatementNode);
|
|
expectedBlockStatementNode = Object.assign({}, blockStatementNode);
|
|
- expectedBlockStatementNode.body.push(identifierNode);
|
|
|
|
|
|
+ expectedBlockStatementNode.body.push(expressionStatementNode);
|
|
|
|
|
|
- NodeUtils.appendNode(blockStatementNode.body, identifierNode);
|
|
|
|
|
|
+ NodeUtils.appendNode(blockStatementNode.body, expressionStatementNode);
|
|
});
|
|
});
|
|
|
|
|
|
it('should append given node to a `BlockStatement` node body', () => {
|
|
it('should append given node to a `BlockStatement` node body', () => {
|
|
@@ -67,23 +66,22 @@ describe('NodeUtils', () => {
|
|
|
|
|
|
describe('getBlockStatementNodeByIndex (node: INode, index: number = 0): INode', () => {
|
|
describe('getBlockStatementNodeByIndex (node: INode, index: number = 0): INode', () => {
|
|
let blockStatementNode: IBlockStatementNode,
|
|
let blockStatementNode: IBlockStatementNode,
|
|
- identifierNode: IIdentifierNode,
|
|
|
|
- literalNode: ILiteralNode;
|
|
|
|
|
|
+ expressionStatementNode1: IExpressionStatementNode,
|
|
|
|
+ expressionStatementNode2: IExpressionStatementNode;
|
|
|
|
|
|
beforeEach(() => {
|
|
beforeEach(() => {
|
|
- identifierNode = NodeMocks.getIdentifierNode();
|
|
|
|
-
|
|
|
|
- literalNode = NodeMocks.getLiteralNode();
|
|
|
|
|
|
+ expressionStatementNode1 = NodeMocks.getExpressionStatementNode();
|
|
|
|
+ expressionStatementNode2 = NodeMocks.getExpressionStatementNode();
|
|
|
|
|
|
blockStatementNode = NodeMocks.getBlockStatementNode([
|
|
blockStatementNode = NodeMocks.getBlockStatementNode([
|
|
- identifierNode,
|
|
|
|
- literalNode
|
|
|
|
|
|
+ expressionStatementNode1,
|
|
|
|
+ expressionStatementNode2
|
|
]);
|
|
]);
|
|
});
|
|
});
|
|
|
|
|
|
it('should return block-statement child node of given node if that node has block-statement', () => {
|
|
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);
|
|
|
|
|
|
+ assert.deepEqual(NodeUtils.getBlockStatementNodeByIndex(blockStatementNode), expressionStatementNode1);
|
|
|
|
+ assert.deepEqual(NodeUtils.getBlockStatementNodeByIndex(blockStatementNode, 1), expressionStatementNode2);
|
|
});
|
|
});
|
|
|
|
|
|
it('should throw a `ReferenceError` if index is out of boundaries', () => {
|
|
it('should throw a `ReferenceError` if index is out of boundaries', () => {
|
|
@@ -91,7 +89,7 @@ describe('NodeUtils', () => {
|
|
});
|
|
});
|
|
|
|
|
|
it('should throw a `TypeError` if node have no a block-statement', () => {
|
|
it('should throw a `TypeError` if node have no a block-statement', () => {
|
|
- assert.throws(() => NodeUtils.getBlockStatementNodeByIndex(identifierNode, 1), TypeError);
|
|
|
|
|
|
+ assert.throws(() => NodeUtils.getBlockStatementNodeByIndex(expressionStatementNode1, 1), TypeError);
|
|
});
|
|
});
|
|
});
|
|
});
|
|
|
|
|
|
@@ -101,21 +99,20 @@ describe('NodeUtils', () => {
|
|
ifStatementBlockStatementNode2: IBlockStatementNode,
|
|
ifStatementBlockStatementNode2: IBlockStatementNode,
|
|
ifStatementNode1: IIfStatementNode,
|
|
ifStatementNode1: IIfStatementNode,
|
|
ifStatementNode2: IIfStatementNode,
|
|
ifStatementNode2: IIfStatementNode,
|
|
- identifierNode: IIdentifierNode,
|
|
|
|
|
|
+ expressionStatementNode1: IExpressionStatementNode,
|
|
|
|
+ expressionStatementNode2: IExpressionStatementNode,
|
|
|
|
+ expressionStatementNode3: IExpressionStatementNode,
|
|
functionDeclarationNode: IFunctionDeclarationNode,
|
|
functionDeclarationNode: IFunctionDeclarationNode,
|
|
- literalNode1: ILiteralNode,
|
|
|
|
- literalNode2: ILiteralNode,
|
|
|
|
programNode: IProgramNode;
|
|
programNode: IProgramNode;
|
|
|
|
|
|
beforeEach(() => {
|
|
beforeEach(() => {
|
|
- identifierNode = NodeMocks.getIdentifierNode();
|
|
|
|
-
|
|
|
|
- literalNode1 = NodeMocks.getLiteralNode();
|
|
|
|
- literalNode2 = NodeMocks.getLiteralNode();
|
|
|
|
|
|
+ expressionStatementNode1 = NodeMocks.getExpressionStatementNode();
|
|
|
|
+ expressionStatementNode2 = NodeMocks.getExpressionStatementNode();
|
|
|
|
+ expressionStatementNode3 = NodeMocks.getExpressionStatementNode();
|
|
|
|
|
|
ifStatementBlockStatementNode2 = NodeMocks.getBlockStatementNode([
|
|
ifStatementBlockStatementNode2 = NodeMocks.getBlockStatementNode([
|
|
- literalNode1,
|
|
|
|
- literalNode2
|
|
|
|
|
|
+ expressionStatementNode1,
|
|
|
|
+ expressionStatementNode2
|
|
]);
|
|
]);
|
|
|
|
|
|
ifStatementNode2 = NodeMocks.getIfStatementNode(ifStatementBlockStatementNode2);
|
|
ifStatementNode2 = NodeMocks.getIfStatementNode(ifStatementBlockStatementNode2);
|
|
@@ -127,7 +124,7 @@ describe('NodeUtils', () => {
|
|
ifStatementNode1 = NodeMocks.getIfStatementNode(ifStatementBlockStatementNode1);
|
|
ifStatementNode1 = NodeMocks.getIfStatementNode(ifStatementBlockStatementNode1);
|
|
|
|
|
|
functionDeclarationBlockStatementNode = NodeMocks.getBlockStatementNode([
|
|
functionDeclarationBlockStatementNode = NodeMocks.getBlockStatementNode([
|
|
- identifierNode,
|
|
|
|
|
|
+ expressionStatementNode3,
|
|
ifStatementNode1
|
|
ifStatementNode1
|
|
]);
|
|
]);
|
|
|
|
|
|
@@ -140,47 +137,46 @@ describe('NodeUtils', () => {
|
|
programNode['parentNode'] = programNode;
|
|
programNode['parentNode'] = programNode;
|
|
functionDeclarationNode['parentNode'] = programNode;
|
|
functionDeclarationNode['parentNode'] = programNode;
|
|
functionDeclarationBlockStatementNode['parentNode'] = functionDeclarationNode;
|
|
functionDeclarationBlockStatementNode['parentNode'] = functionDeclarationNode;
|
|
- identifierNode['parentNode'] = functionDeclarationBlockStatementNode;
|
|
|
|
|
|
+ expressionStatementNode3['parentNode'] = functionDeclarationBlockStatementNode;
|
|
ifStatementNode1['parentNode'] = functionDeclarationBlockStatementNode;
|
|
ifStatementNode1['parentNode'] = functionDeclarationBlockStatementNode;
|
|
ifStatementBlockStatementNode1['parentNode'] = ifStatementNode1;
|
|
ifStatementBlockStatementNode1['parentNode'] = ifStatementNode1;
|
|
ifStatementNode2['parentNode'] = ifStatementBlockStatementNode1;
|
|
ifStatementNode2['parentNode'] = ifStatementBlockStatementNode1;
|
|
ifStatementBlockStatementNode2['parentNode'] = ifStatementNode2;
|
|
ifStatementBlockStatementNode2['parentNode'] = ifStatementNode2;
|
|
- literalNode1['parentNode'] = ifStatementBlockStatementNode2;
|
|
|
|
|
|
+ expressionStatementNode1['parentNode'] = ifStatementBlockStatementNode2;
|
|
});
|
|
});
|
|
|
|
|
|
it('should return block-scope node for given node', () => {
|
|
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(expressionStatementNode3), functionDeclarationBlockStatementNode);
|
|
|
|
+ assert.deepEqual(NodeUtils.getBlockScopeOfNode(expressionStatementNode3, 1), programNode);
|
|
assert.deepEqual(NodeUtils.getBlockScopeOfNode(functionDeclarationNode), programNode);
|
|
assert.deepEqual(NodeUtils.getBlockScopeOfNode(functionDeclarationNode), programNode);
|
|
assert.deepEqual(NodeUtils.getBlockScopeOfNode(functionDeclarationBlockStatementNode), programNode);
|
|
assert.deepEqual(NodeUtils.getBlockScopeOfNode(functionDeclarationBlockStatementNode), programNode);
|
|
assert.deepEqual(NodeUtils.getBlockScopeOfNode(programNode), programNode);
|
|
assert.deepEqual(NodeUtils.getBlockScopeOfNode(programNode), programNode);
|
|
- assert.deepEqual(NodeUtils.getBlockScopeOfNode(literalNode1), functionDeclarationBlockStatementNode);
|
|
|
|
|
|
+ assert.deepEqual(NodeUtils.getBlockScopeOfNode(expressionStatementNode1), functionDeclarationBlockStatementNode);
|
|
});
|
|
});
|
|
|
|
|
|
it('should throw a `ReferenceError` if node has no `parentNode` property', () => {
|
|
it('should throw a `ReferenceError` if node has no `parentNode` property', () => {
|
|
- assert.throws(() => NodeUtils.getBlockScopeOfNode(literalNode2), ReferenceError);
|
|
|
|
|
|
+ assert.throws(() => NodeUtils.getBlockScopeOfNode(expressionStatementNode2), ReferenceError);
|
|
});
|
|
});
|
|
});
|
|
});
|
|
|
|
|
|
describe('insertNodeAtIndex (blockScopeBody: INode[], node: INode, index: number): void', () => {
|
|
describe('insertNodeAtIndex (blockScopeBody: INode[], node: INode, index: number): void', () => {
|
|
let blockStatementNode: IBlockStatementNode,
|
|
let blockStatementNode: IBlockStatementNode,
|
|
expectedBlockStatementNode: IBlockStatementNode,
|
|
expectedBlockStatementNode: IBlockStatementNode,
|
|
- identifierNode: IIdentifierNode,
|
|
|
|
- literalNode: ILiteralNode;
|
|
|
|
|
|
+ expressionStatementNode1: IExpressionStatementNode,
|
|
|
|
+ expressionStatementNode2: IExpressionStatementNode;
|
|
|
|
|
|
beforeEach(() => {
|
|
beforeEach(() => {
|
|
- identifierNode = NodeMocks.getIdentifierNode();
|
|
|
|
-
|
|
|
|
- literalNode = NodeMocks.getLiteralNode();
|
|
|
|
|
|
+ expressionStatementNode1 = NodeMocks.getExpressionStatementNode();
|
|
|
|
+ expressionStatementNode2 = NodeMocks.getExpressionStatementNode();
|
|
|
|
|
|
blockStatementNode = NodeMocks.getBlockStatementNode([
|
|
blockStatementNode = NodeMocks.getBlockStatementNode([
|
|
- identifierNode
|
|
|
|
|
|
+ expressionStatementNode1
|
|
]);
|
|
]);
|
|
|
|
|
|
expectedBlockStatementNode = Object.assign({}, blockStatementNode);
|
|
expectedBlockStatementNode = Object.assign({}, blockStatementNode);
|
|
- expectedBlockStatementNode['body'].push(literalNode);
|
|
|
|
|
|
+ expectedBlockStatementNode['body'].push(expressionStatementNode2);
|
|
|
|
|
|
- NodeUtils.insertNodeAtIndex(blockStatementNode.body, literalNode, 1);
|
|
|
|
|
|
+ NodeUtils.insertNodeAtIndex(blockStatementNode.body, expressionStatementNode2, 1);
|
|
});
|
|
});
|
|
|
|
|
|
it('should insert given node in `BlockStatement` node body at index', () => {
|
|
it('should insert given node in `BlockStatement` node body at index', () => {
|
|
@@ -203,54 +199,56 @@ describe('NodeUtils', () => {
|
|
});
|
|
});
|
|
|
|
|
|
describe('parentize (node: INode): void', () => {
|
|
describe('parentize (node: INode): void', () => {
|
|
- let blockStatementNode: IBlockStatementNode,
|
|
|
|
- identifierNode: IIdentifierNode,
|
|
|
|
- literalNode: ILiteralNode,
|
|
|
|
|
|
+ let ifStatementNode: IIfStatementNode,
|
|
|
|
+ ifStatementBlockStatementNode: IBlockStatementNode,
|
|
|
|
+ expressionStatementNode1: IExpressionStatementNode,
|
|
|
|
+ expressionStatementNode2: IExpressionStatementNode,
|
|
programNode: IProgramNode;
|
|
programNode: IProgramNode;
|
|
|
|
|
|
beforeEach(() => {
|
|
beforeEach(() => {
|
|
- identifierNode = NodeMocks.getIdentifierNode();
|
|
|
|
|
|
+ expressionStatementNode1 = NodeMocks.getExpressionStatementNode();
|
|
|
|
+ expressionStatementNode2 = NodeMocks.getExpressionStatementNode();
|
|
|
|
|
|
- literalNode = NodeMocks.getLiteralNode();
|
|
|
|
-
|
|
|
|
- blockStatementNode = NodeMocks.getBlockStatementNode([
|
|
|
|
- identifierNode,
|
|
|
|
- literalNode
|
|
|
|
|
|
+ ifStatementBlockStatementNode = NodeMocks.getBlockStatementNode([
|
|
|
|
+ expressionStatementNode1,
|
|
|
|
+ expressionStatementNode2
|
|
]);
|
|
]);
|
|
|
|
|
|
|
|
+ ifStatementNode = NodeMocks.getIfStatementNode(ifStatementBlockStatementNode);
|
|
|
|
+
|
|
programNode = NodeMocks.getProgramNode([
|
|
programNode = NodeMocks.getProgramNode([
|
|
- blockStatementNode
|
|
|
|
|
|
+ ifStatementNode
|
|
]);
|
|
]);
|
|
|
|
|
|
- NodeUtils.parentize(blockStatementNode);
|
|
|
|
|
|
+ NodeUtils.parentize(ifStatementNode);
|
|
});
|
|
});
|
|
|
|
|
|
it('should parentize given AST-tree', () => {
|
|
it('should parentize given AST-tree', () => {
|
|
- assert.deepEqual(blockStatementNode['parentNode'], programNode);
|
|
|
|
- assert.deepEqual(identifierNode['parentNode'], blockStatementNode);
|
|
|
|
- assert.deepEqual(literalNode['parentNode'], blockStatementNode);
|
|
|
|
|
|
+ assert.deepEqual(ifStatementNode['parentNode'], programNode);
|
|
|
|
+ assert.deepEqual(ifStatementBlockStatementNode['parentNode'], ifStatementNode);
|
|
|
|
+ assert.deepEqual(expressionStatementNode1['parentNode'], ifStatementBlockStatementNode);
|
|
|
|
+ assert.deepEqual(expressionStatementNode2['parentNode'], ifStatementBlockStatementNode);
|
|
});
|
|
});
|
|
});
|
|
});
|
|
|
|
|
|
describe('prependNode (blockScopeBody: INode[], node: INode): void', () => {
|
|
describe('prependNode (blockScopeBody: INode[], node: INode): void', () => {
|
|
let blockStatementNode: IBlockStatementNode,
|
|
let blockStatementNode: IBlockStatementNode,
|
|
expectedBlockStatementNode: IBlockStatementNode,
|
|
expectedBlockStatementNode: IBlockStatementNode,
|
|
- identifierNode: IIdentifierNode,
|
|
|
|
- literalNode: ILiteralNode;
|
|
|
|
|
|
+ expressionStatementNode1: IExpressionStatementNode,
|
|
|
|
+ expressionStatementNode2: IExpressionStatementNode;
|
|
|
|
|
|
beforeEach(() => {
|
|
beforeEach(() => {
|
|
- identifierNode = NodeMocks.getIdentifierNode();
|
|
|
|
-
|
|
|
|
- literalNode = NodeMocks.getLiteralNode();
|
|
|
|
|
|
+ expressionStatementNode1 = NodeMocks.getExpressionStatementNode();
|
|
|
|
+ expressionStatementNode2 = NodeMocks.getExpressionStatementNode();
|
|
|
|
|
|
blockStatementNode = NodeMocks.getBlockStatementNode([
|
|
blockStatementNode = NodeMocks.getBlockStatementNode([
|
|
- identifierNode
|
|
|
|
|
|
+ expressionStatementNode1
|
|
]);
|
|
]);
|
|
|
|
|
|
expectedBlockStatementNode = Object.assign({}, blockStatementNode);
|
|
expectedBlockStatementNode = Object.assign({}, blockStatementNode);
|
|
- expectedBlockStatementNode['body'].unshift(literalNode);
|
|
|
|
|
|
+ expectedBlockStatementNode['body'].unshift(expressionStatementNode2);
|
|
|
|
|
|
- NodeUtils.prependNode(blockStatementNode.body, literalNode);
|
|
|
|
|
|
+ NodeUtils.prependNode(blockStatementNode.body, expressionStatementNode2);
|
|
});
|
|
});
|
|
|
|
|
|
it('should prepend given node to a `BlockStatement` node body', () => {
|
|
it('should prepend given node to a `BlockStatement` node body', () => {
|