UNPKG

@designliquido/foles

Version:

Linguagem de folhas de estilo para documentos em geral em português

200 lines 12.4 kB
"use strict"; 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