mirror of
https://github.com/tenrok/BBob.git
synced 2026-06-20 20:00:33 +03:00
add parser tests
This commit is contained in:
@@ -17,7 +17,7 @@ const Tokenizer = require('./Tokenizer');
|
|||||||
const TokenChar = Tokenizer.CHAR;
|
const TokenChar = Tokenizer.CHAR;
|
||||||
const getChar = Tokenizer.getChar;
|
const getChar = Tokenizer.getChar;
|
||||||
|
|
||||||
const createTagNode = (name, attrs = {}, content = []) => ({ tag: name, attrs, content });
|
const createTagNode = (tag, attrs = {}, content = []) => ({ tag, attrs, content });
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -1,11 +1,35 @@
|
|||||||
const Parser = require('./Parser');
|
const Parser = require('./Parser');
|
||||||
const TOKEN = require('./token');
|
const TOKEN = require('./token');
|
||||||
|
|
||||||
|
const parse = input => (new Parser(input).parse());
|
||||||
|
|
||||||
describe('Parser', () => {
|
describe('Parser', () => {
|
||||||
test('parse paired tags tokens', () => {
|
test('parse paired tags tokens', () => {
|
||||||
const parser = new Parser([
|
const input = [
|
||||||
[TOKEN.TYPE_TAG, 'ch'],
|
[TOKEN.TYPE_TAG, 'best'],
|
||||||
[TOKEN.TYPE_TAG, '/ch'],
|
[TOKEN.TYPE_ATTR_NAME, 'name'],
|
||||||
|
[TOKEN.TYPE_ATTR_VALUE, 'value'],
|
||||||
|
[TOKEN.TYPE_WORD, 'Foo'],
|
||||||
|
[TOKEN.TYPE_SPACE, ' '],
|
||||||
|
[TOKEN.TYPE_WORD, 'Bar'],
|
||||||
|
[TOKEN.TYPE_TAG, '/best'],
|
||||||
|
];
|
||||||
|
|
||||||
|
const ast = parse(input);
|
||||||
|
|
||||||
|
expect(ast).toBeInstanceOf(Array);
|
||||||
|
expect(ast).toEqual([
|
||||||
|
{
|
||||||
|
tag: 'best',
|
||||||
|
attrs: {
|
||||||
|
name: 'value',
|
||||||
|
},
|
||||||
|
content: [
|
||||||
|
'Foo',
|
||||||
|
' ',
|
||||||
|
'Bar',
|
||||||
|
],
|
||||||
|
},
|
||||||
]);
|
]);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -2,10 +2,12 @@ const Tokenizer = require('./Tokenizer');
|
|||||||
|
|
||||||
const TYPE = Tokenizer.TYPE;
|
const TYPE = Tokenizer.TYPE;
|
||||||
|
|
||||||
|
const tokenize = input => (new Tokenizer(input).tokenize());
|
||||||
|
|
||||||
describe('Tokenizer', () => {
|
describe('Tokenizer', () => {
|
||||||
test('tokenize single tag', () => {
|
test('tokenize single tag', () => {
|
||||||
const input = '[SingleTag]';
|
const input = '[SingleTag]';
|
||||||
const tokens = new Tokenizer(input).tokenize();
|
const tokens = tokenize(input);
|
||||||
|
|
||||||
expect(tokens).toBeInstanceOf(Array);
|
expect(tokens).toBeInstanceOf(Array);
|
||||||
expect(tokens).toEqual([
|
expect(tokens).toEqual([
|
||||||
@@ -15,7 +17,7 @@ describe('Tokenizer', () => {
|
|||||||
|
|
||||||
test('tokenize single tag with spaces', () => {
|
test('tokenize single tag with spaces', () => {
|
||||||
const input = '[Single Tag]';
|
const input = '[Single Tag]';
|
||||||
const tokens = new Tokenizer(input).tokenize();
|
const tokens = tokenize(input);
|
||||||
|
|
||||||
expect(tokens).toBeInstanceOf(Array);
|
expect(tokens).toBeInstanceOf(Array);
|
||||||
expect(tokens).toEqual([
|
expect(tokens).toEqual([
|
||||||
@@ -25,7 +27,7 @@ describe('Tokenizer', () => {
|
|||||||
|
|
||||||
test('tokenize tag as param', () => {
|
test('tokenize tag as param', () => {
|
||||||
const input = '[color="#ff0000"]Text[/color]';
|
const input = '[color="#ff0000"]Text[/color]';
|
||||||
const tokens = new Tokenizer(input).tokenize();
|
const tokens = tokenize(input);
|
||||||
|
|
||||||
expect(tokens).toBeInstanceOf(Array);
|
expect(tokens).toBeInstanceOf(Array);
|
||||||
expect(tokens).toEqual([
|
expect(tokens).toEqual([
|
||||||
@@ -38,7 +40,7 @@ describe('Tokenizer', () => {
|
|||||||
|
|
||||||
test('tokenize tag param without quotemarks', () => {
|
test('tokenize tag param without quotemarks', () => {
|
||||||
const input = '[style color=#ff0000]Text[/style]';
|
const input = '[style color=#ff0000]Text[/style]';
|
||||||
const tokens = new Tokenizer(input).tokenize();
|
const tokens = tokenize(input);
|
||||||
|
|
||||||
expect(tokens).toBeInstanceOf(Array);
|
expect(tokens).toBeInstanceOf(Array);
|
||||||
expect(tokens).toEqual([
|
expect(tokens).toEqual([
|
||||||
@@ -57,7 +59,7 @@ describe('Tokenizer', () => {
|
|||||||
[*] Item 3.
|
[*] Item 3.
|
||||||
[/list]`;
|
[/list]`;
|
||||||
|
|
||||||
const tokens = new Tokenizer(input).tokenize();
|
const tokens = tokenize(input);
|
||||||
|
|
||||||
expect(tokens).toBeInstanceOf(Array);
|
expect(tokens).toBeInstanceOf(Array);
|
||||||
expect(tokens).toEqual([
|
expect(tokens).toEqual([
|
||||||
@@ -136,7 +138,7 @@ describe('Tokenizer', () => {
|
|||||||
];
|
];
|
||||||
|
|
||||||
inputs.forEach((input, idx) => {
|
inputs.forEach((input, idx) => {
|
||||||
const tokens = new Tokenizer(input).tokenize();
|
const tokens = tokenize(input);
|
||||||
|
|
||||||
expect(tokens).toBeInstanceOf(Array);
|
expect(tokens).toBeInstanceOf(Array);
|
||||||
expect(tokens).toEqual(asserts[idx]);
|
expect(tokens).toEqual(asserts[idx]);
|
||||||
|
|||||||
@@ -11,14 +11,14 @@ const TOKEN_TYPE_SPACE = 'space';
|
|||||||
const TOKEN_TYPE_NEW_LINE = 'new-line';
|
const TOKEN_TYPE_NEW_LINE = 'new-line';
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
TYPE_ID: TOKEN_TYPE_ID,
|
TYPE_ID: TOKEN_TYPE_ID,
|
||||||
VALUE_ID: TOKEN_VALUE_ID,
|
VALUE_ID: TOKEN_VALUE_ID,
|
||||||
LINE_ID: TOKEN_LINE_ID,
|
LINE_ID: TOKEN_LINE_ID,
|
||||||
COLUMN_ID: TOKEN_COLUMN_ID,
|
COLUMN_ID: TOKEN_COLUMN_ID,
|
||||||
TYPE_WORD: TOKEN_TYPE_WORD,
|
TYPE_WORD: TOKEN_TYPE_WORD,
|
||||||
TYPE_TAG: TOKEN_TYPE_TAG,
|
TYPE_TAG: TOKEN_TYPE_TAG,
|
||||||
TYPE_ATTR_NAME: TOKEN_TYPE_ATTR_NAME,
|
TYPE_ATTR_NAME: TOKEN_TYPE_ATTR_NAME,
|
||||||
TYPE_ATTR_VALUE: TOKEN_TYPE_ATTR_VALUE,
|
TYPE_ATTR_VALUE: TOKEN_TYPE_ATTR_VALUE,
|
||||||
TYPE_SPACE: TOKEN_TYPE_SPACE,
|
TYPE_SPACE: TOKEN_TYPE_SPACE,
|
||||||
TYPE_NEW_LINE: TOKEN_TYPE_NEW_LINE
|
TYPE_NEW_LINE: TOKEN_TYPE_NEW_LINE
|
||||||
};
|
};
|
||||||
Reference in New Issue
Block a user