Increase test coverage (#4742)
* Add tests for path type inferers * Add test for babel-types.valueToNode * Add tests for babel-types.toKeyAlias * Add tests for babel-types.toStatement * Add tests for babel-types.toExpression * Lint fixes in babel-traverse/test/inference
This commit is contained in:
committed by
Daniel Tschinder
parent
beda884f41
commit
fd4667e649
147
packages/babel-types/test/converters.js
Normal file
147
packages/babel-types/test/converters.js
Normal file
@@ -0,0 +1,147 @@
|
||||
import * as t from "../lib";
|
||||
import { assert } from "chai";
|
||||
|
||||
describe("converters", function () {
|
||||
describe("valueToNode", function () {
|
||||
it("number", function () {
|
||||
assert.deepEqual(t.valueToNode(Math.PI), t.numericLiteral(Math.PI));
|
||||
assert.deepEqual(t.valueToNode(-Infinity), t.numericLiteral(-Infinity));
|
||||
assert.deepEqual(t.valueToNode(NaN), t.numericLiteral(NaN));
|
||||
});
|
||||
it("string", function () {
|
||||
assert.deepEqual(t.valueToNode("This is a \"string\""), t.stringLiteral("This is a \"string\""));
|
||||
});
|
||||
it("boolean", function () {
|
||||
assert.deepEqual(t.valueToNode(true), t.booleanLiteral(true));
|
||||
assert.deepEqual(t.valueToNode(false), t.booleanLiteral(false));
|
||||
});
|
||||
it("null", function () {
|
||||
assert.deepEqual(t.valueToNode(null), t.nullLiteral());
|
||||
});
|
||||
it("undefined", function () {
|
||||
assert.deepEqual(t.valueToNode(undefined), t.identifier("undefined"));
|
||||
});
|
||||
it("RegExp", function () {
|
||||
assert.deepEqual(t.valueToNode(/abc.+/gm), t.regExpLiteral("abc.+", "gm"));
|
||||
});
|
||||
it("array", function () {
|
||||
assert.deepEqual(t.valueToNode([1, "a"]), t.arrayExpression([t.numericLiteral(1), t.stringLiteral("a")]));
|
||||
});
|
||||
it("object", function () {
|
||||
assert.deepEqual(t.valueToNode({
|
||||
a: 1,
|
||||
"b c": 2
|
||||
}), t.objectExpression([
|
||||
t.objectProperty(t.identifier("a"), t.numericLiteral(1)),
|
||||
t.objectProperty(t.stringLiteral("b c"), t.numericLiteral(2))
|
||||
]));
|
||||
});
|
||||
it("throws if cannot convert", function () {
|
||||
assert.throws(function () {
|
||||
t.valueToNode(Object);
|
||||
});
|
||||
assert.throws(function () {
|
||||
t.valueToNode(Symbol());
|
||||
});
|
||||
});
|
||||
});
|
||||
describe("toKeyAlias", function () {
|
||||
beforeEach(function () {
|
||||
// make tests deterministic
|
||||
t.toKeyAlias.uid = 0;
|
||||
});
|
||||
it("doesn't change string literals", function () {
|
||||
assert.equal(t.toKeyAlias(t.objectProperty(t.stringLiteral("a"), t.nullLiteral())), "\"a\"");
|
||||
});
|
||||
it("wraps around at Number.MAX_SAFE_INTEGER", function () {
|
||||
assert.equal(t.toKeyAlias(t.objectMethod("method", t.identifier("a"), [], t.blockStatement([]))), "0");
|
||||
});
|
||||
});
|
||||
describe("toStatement", function () {
|
||||
it("noop on statements", function () {
|
||||
const node = t.emptyStatement();
|
||||
assert.equal(t.toStatement(node), node);
|
||||
t.assertEmptyStatement(node);
|
||||
});
|
||||
it("mutate class expression to declaration", function () {
|
||||
const node = t.classExpression(t.identifier("A"), null, t.classBody([]), []);
|
||||
t.toStatement(node);
|
||||
t.assertClassDeclaration(node);
|
||||
});
|
||||
it("fail if class expression has no id", function () {
|
||||
const node = t.classExpression(null, null, t.classBody([]), []);
|
||||
assert.throws(function() {
|
||||
t.toStatement(node);
|
||||
});
|
||||
assert.strictEqual(t.toStatement(node, /* ignore = */ true), false);
|
||||
t.assertClassExpression(node);
|
||||
});
|
||||
it("mutate function expression to declaration", function () {
|
||||
const node = t.functionExpression(t.identifier("A"), [], t.blockStatement([]));
|
||||
t.toStatement(node);
|
||||
t.assertFunctionDeclaration(node);
|
||||
});
|
||||
it("fail if function expression has no id", function () {
|
||||
const node = t.functionExpression(null, [], t.blockStatement([]));
|
||||
assert.throws(function() {
|
||||
t.toStatement(node);
|
||||
});
|
||||
assert.strictEqual(t.toStatement(node, /* ignore = */ true), false);
|
||||
t.assertFunctionExpression(node);
|
||||
});
|
||||
it("assignment expression", function () {
|
||||
const node = t.assignmentExpression("+=", t.identifier("x"), t.numericLiteral(1));
|
||||
t.assertExpressionStatement(t.toStatement(node));
|
||||
t.assertAssignmentExpression(node);
|
||||
});
|
||||
it("fail if cannot convert node type", function () {
|
||||
const node = t.yieldExpression(t.identifier("foo"));
|
||||
assert.throws(function() {
|
||||
t.toStatement(node);
|
||||
});
|
||||
assert.strictEqual(t.toStatement(node, /* ignore = */ true), false);
|
||||
t.assertYieldExpression(node);
|
||||
});
|
||||
});
|
||||
describe("toExpression", function () {
|
||||
it("noop on expressions", function () {
|
||||
const node = t.identifier("a");
|
||||
assert.equal(t.toExpression(node), node);
|
||||
t.assertIdentifier(node);
|
||||
});
|
||||
it("mutate class declaration to expression", function () {
|
||||
const node = t.classDeclaration(t.identifier("A"), null, t.classBody([]), []);
|
||||
t.toExpression(node);
|
||||
t.assertClassExpression(node);
|
||||
});
|
||||
it("mutate function declaration to expression", function () {
|
||||
const node = t.functionDeclaration(t.identifier("A"), [], t.blockStatement([]));
|
||||
t.toExpression(node);
|
||||
t.assertFunctionExpression(node);
|
||||
});
|
||||
it("mutate object method to expression", function () {
|
||||
const node = t.objectMethod("method", t.identifier("A"), [], t.blockStatement([]));
|
||||
t.toExpression(node);
|
||||
t.assertFunctionExpression(node);
|
||||
});
|
||||
it("mutate class method to expression", function () {
|
||||
const node = t.classMethod("constructor", t.identifier("A"), [], t.blockStatement([]));
|
||||
t.toExpression(node);
|
||||
t.assertFunctionExpression(node);
|
||||
});
|
||||
it("expression statement", function () {
|
||||
const inner = t.yieldExpression(t.identifier("foo"));
|
||||
const node = t.expressionStatement(inner);
|
||||
t.assertYieldExpression(t.toExpression(node));
|
||||
assert.equal(t.toExpression(node), inner);
|
||||
t.assertExpressionStatement(node);
|
||||
});
|
||||
it("fail if cannot convert node type", function () {
|
||||
const node = t.program([]);
|
||||
assert.throws(function() {
|
||||
t.toExpression(node);
|
||||
});
|
||||
t.assertProgram(node);
|
||||
});
|
||||
});
|
||||
});
|
||||
Reference in New Issue
Block a user