test35.spec.js 909 B

1234567891011121314151617181920212223242526272829303132333435
  1. import Lexers from './../grammar/';
  2. import { IVProgParser } from './../js/ast/ivprogParser';
  3. import { IVProgProcessor} from './../js/processor/ivprogProcessor'
  4. import { LanguageService } from '../js/services/languageService';
  5. describe('A recursive call', function () {
  6. let input = `programa {
  7. funcao inicio() {
  8. inteiro a = fib(3)
  9. }
  10. funcao inteiro fib(inteiro n) {
  11. se (n <= 0 ) {
  12. retorne 0
  13. } senao se (n == 1) {
  14. retorne 1
  15. } senao {
  16. retorne fib(n-1) + fib(n-2)
  17. }
  18. }
  19. }`;
  20. const lexer = LanguageService.getCurrentLexer();
  21. it(`should produce a valid state`, function (done) {
  22. const parser = new IVProgParser(input, lexer);
  23. const exec = new IVProgProcessor(parser.parseTree());
  24. exec.interpretAST().then(sto => {
  25. expect(sto.applyStore('a').value).toEqual(2);
  26. done();
  27. }).catch( err => done(err));
  28. });
  29. });