@designliquido/foles
Version:
Linguagem de folhas de estilo para documentos em geral em português
200 lines • 12.4 kB
JavaScript
;
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
const avaliador_sintatico_1 = require("../../fontes/avaliador-sintatico");
const importador_1 = require("../../fontes/importador");
const lexador_1 = require("../../fontes/lexador");
const superclasse_1 = require("../../fontes/modificadores/superclasse");
const foles_1 = __importDefault(require("../../fontes/tipos-de-simbolos/foles"));
const serializadores_1 = require("../../fontes/serializadores");
const status_1 = require("../listas/status");
const declaracoes_1 = require("../../fontes/declaracoes");
describe('Testando Seletores com STATUS como atributo', () => {
describe('Testes Unitários', () => {
let lexador;
let importador;
let avaliador;
let tradutor;
beforeEach(() => {
lexador = new lexador_1.Lexador();
importador = new importador_1.Importador(lexador);
avaliador = new avaliador_sintatico_1.AvaliadorSintatico(importador);
tradutor = new serializadores_1.Serializador();
});
it('Casos de sucesso - Valor válido (auto)', () => {
for (let index = 0; index < status_1.StatusAuto.length; index += 1) {
const seletor = new superclasse_1.SeletorModificador(status_1.StatusAuto[index], 'auto', null);
// A classe do modificador deve aceitar 'auto' como valor
expect(seletor['valor']).toEqual('auto');
// Lexador
const resultadoLexador = lexador.mapear([
"corpo {",
`${status_1.StatusAuto[index]}: ${seletor['valor']};`,
"}"
]);
// O Lexador deve montar um objeto de comprimento 7 sem retornar nenhum erro
expect(resultadoLexador.simbolos).toHaveLength(7);
expect(resultadoLexador.erros).toHaveLength(0);
// O valor recebido deve ser mapeado como QUALITATIVO
expect(resultadoLexador.simbolos).toEqual(expect.arrayContaining([
expect.objectContaining({ tipo: foles_1.default.QUALITATIVO }),
]));
// O Lexador não deve encontrar nenhum número ou quantificador no mapeamento
expect(resultadoLexador.simbolos).not.toEqual(expect.arrayContaining([
expect.objectContaining({ tipo: foles_1.default.NUMERO }),
expect.objectContaining({ tipo: foles_1.default.QUANTIFICADOR }),
]));
// Avaliador Sintático
const resultadoAvaliadorSintatico = avaliador.analisar(resultadoLexador.simbolos);
// O Avaliador deve montar um objeto com os devidos nomes FolEs e CSS
expect(resultadoAvaliadorSintatico.length).toBeGreaterThanOrEqual(1);
const primeiroResultado = resultadoAvaliadorSintatico[0];
expect(primeiroResultado).toBeInstanceOf(declaracoes_1.BlocoDeclaracao);
const primeiroResultadoTipado = primeiroResultado;
expect(primeiroResultadoTipado.modificadores.length).toBeGreaterThanOrEqual(1);
expect(primeiroResultadoTipado.modificadores[0].nomeFoles).toStrictEqual(seletor['nomeFoles']);
expect(primeiroResultadoTipado.modificadores[0].propriedadeCss).toStrictEqual(seletor['propriedadeCss']);
// // Tradutor
const resultadoTradutor = tradutor.serializar(resultadoAvaliadorSintatico);
expect(resultadoTradutor).toContain(seletor['propriedadeCss']);
expect(resultadoTradutor).toContain('auto');
}
});
it('Casos de Falha - Lexador, Avaliador e Tradutor', () => {
for (let index = 0; index < status_1.StatusAuto.length; index += 1) {
// Lexador - Status não informado
const resultadoLexador = lexador.mapear([
"lmht {",
`${status_1.StatusAuto[index]}: ;`,
"}"
]);
expect(resultadoLexador.simbolos).not.toHaveLength(7);
expect(resultadoLexador.simbolos).not.toEqual(expect.arrayContaining([
expect.objectContaining({ tipo: foles_1.default.QUALITATIVO }),
]));
// Causar erro de digitação
const seletorIncorreto = status_1.StatusAuto[index].replace(status_1.StatusAuto[index][0], '');
const novoLexador = lexador.mapear([
"lmht {",
`${seletorIncorreto}: automatico;`,
"}"
]);
// Avaliador Sintático - Erro esperado como retorno
expect(() => {
avaliador.analisar(novoLexador.simbolos);
}).toThrow(`O seletor '${seletorIncorreto}' não existe.`);
// Tradutor - Não deve traduzir devido ao erro do Avaliador Sintático
expect(() => {
tradutor.serializar(avaliador.analisar(novoLexador.simbolos));
}).toHaveLength(0);
}
});
it('Casos de sucesso - Valor válido (nenhum)', () => {
for (let index = 0; index < status_1.StatusNenhum.length; index += 1) {
const seletor = new superclasse_1.SeletorModificador(status_1.StatusNenhum[index], 'nenhum', null);
// A classe do modificador deve aceitar 'normal' como valor
expect(seletor['valor']).toEqual('nenhum');
// Lexador
const resultadoLexador = lexador.mapear([
"corpo {",
`${status_1.StatusNenhum[index]}: ${seletor['valor']};`,
"}"
]);
// O Lexador deve montar um objeto de comprimento 7 sem retornar nenhum erro
expect(resultadoLexador.simbolos).toHaveLength(7);
expect(resultadoLexador.erros).toHaveLength(0);
// O valor recebido deve ser mapeado como QUALITATIVO
expect(resultadoLexador.simbolos).toEqual(expect.arrayContaining([
expect.objectContaining({ tipo: foles_1.default.QUALITATIVO }),
]));
// Avaliador Sintático
const resultadoAvaliadorSintatico = avaliador.analisar(resultadoLexador.simbolos);
// O Avaliador deve montar um objeto com os devidos nomes FolEs e CSS
expect(resultadoAvaliadorSintatico.length).toBeGreaterThanOrEqual(1);
const primeiroResultado = resultadoAvaliadorSintatico[0];
expect(primeiroResultado).toBeInstanceOf(declaracoes_1.BlocoDeclaracao);
const primeiroResultadoTipado = primeiroResultado;
expect(primeiroResultadoTipado.modificadores.length).toBeGreaterThanOrEqual(1);
expect(primeiroResultadoTipado.modificadores[0].nomeFoles).toStrictEqual(seletor['nomeFoles']);
expect(primeiroResultadoTipado.modificadores[0].propriedadeCss).toStrictEqual(seletor['propriedadeCss']);
// // Tradutor
const resultadoTradutor = tradutor.serializar(resultadoAvaliadorSintatico);
expect(resultadoTradutor).toContain(seletor['propriedadeCss']);
expect(resultadoTradutor).toContain('none');
}
});
it('Casos de sucesso - Valor válido (normal)', () => {
for (let index = 0; index < status_1.StatusNormal.length; index += 1) {
const seletor = new superclasse_1.SeletorModificador(status_1.StatusNormal[index], 'normal', null);
// A classe do modificador deve aceitar 'normal' como valor
expect(seletor['valor']).toEqual('normal');
// Lexador
const resultadoLexador = lexador.mapear([
"corpo {",
`${status_1.StatusNormal[index]}: ${seletor['valor']};`,
"}"
]);
// O Lexador deve montar um objeto de comprimento 7 sem retornar nenhum erro
expect(resultadoLexador.simbolos).toHaveLength(7);
expect(resultadoLexador.erros).toHaveLength(0);
// O valor recebido deve ser mapeado como IDENTIFICADOR
expect(resultadoLexador.simbolos).toEqual(expect.arrayContaining([
expect.objectContaining({ tipo: foles_1.default.IDENTIFICADOR }),
]));
// Avaliador Sintático
const resultadoAvaliadorSintatico = avaliador.analisar(resultadoLexador.simbolos);
// O Avaliador deve montar um objeto com os devidos nomes FolEs e CSS
expect(resultadoAvaliadorSintatico.length).toBeGreaterThanOrEqual(1);
const primeiroResultado = resultadoAvaliadorSintatico[0];
expect(primeiroResultado).toBeInstanceOf(declaracoes_1.BlocoDeclaracao);
const primeiroResultadoTipado = primeiroResultado;
expect(primeiroResultadoTipado.modificadores.length).toBeGreaterThanOrEqual(1);
expect(primeiroResultadoTipado.modificadores[0].nomeFoles).toStrictEqual(seletor['nomeFoles']);
expect(primeiroResultadoTipado.modificadores[0].propriedadeCss).toStrictEqual(seletor['propriedadeCss']);
// // Tradutor
const resultadoTradutor = tradutor.serializar(resultadoAvaliadorSintatico);
expect(resultadoTradutor).toContain(seletor['propriedadeCss']);
expect(resultadoTradutor).toContain('normal');
}
});
it('Caso de Sucesso - Status atribuído por meio de variável', () => {
for (let index = 0; index < status_1.StatusAuto.length; index += 1) {
const seletor = new superclasse_1.SeletorModificador(status_1.StatusAuto[index], 'auto', null);
// Lexador
const resultadoLexador = lexador.mapear([
'$status-padrao: auto;',
"lmht {",
` ${status_1.StatusAuto[index]}: $status-padrao;`,
"}"
]);
// O Lexador deve montar o objeto de acordo, sem retornar erros.
expect(resultadoLexador.simbolos).toHaveLength(13);
expect(resultadoLexador.erros).toHaveLength(0);
// O mapeamento deve conter o tipo variável
expect(resultadoLexador.simbolos).toEqual(expect.arrayContaining([
expect.objectContaining({ tipo: foles_1.default.VARIAVEL }),
]));
// Avaliador Sintático
const resultadoAvaliadorSintatico = avaliador.analisar(resultadoLexador.simbolos);
// O Avaliador deve montar um objeto com os devidos nomes FolEs e CSS
expect(resultadoAvaliadorSintatico.length).toBeGreaterThanOrEqual(1);
// O primeiro item do mapeamento deve ser a declaração da variável
const primeiroResultado = resultadoAvaliadorSintatico[0];
expect(primeiroResultado).toBeInstanceOf(declaracoes_1.DeclaracaoVariavel);
// O segundo item do mapeamento deve conter as devidas traduções
const segundoResultado = resultadoAvaliadorSintatico[1];
const segundoResultadoTipado = segundoResultado;
expect(segundoResultadoTipado.modificadores.length).toBeGreaterThanOrEqual(1);
expect(segundoResultadoTipado.modificadores[0].nomeFoles).toStrictEqual(seletor['nomeFoles']);
expect(segundoResultadoTipado.modificadores[0].propriedadeCss).toStrictEqual(seletor['propriedadeCss']);
// Tradutor
const resultadoTradutor = tradutor.serializar(resultadoAvaliadorSintatico);
expect(resultadoTradutor).toContain(seletor['propriedadeCss']);
expect(resultadoTradutor).toContain('auto');
}
});
});
});
//# sourceMappingURL=status.test.js.map