test35.spec.js 873 B

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