;;; Test the Info engine. -*- Scheme -*- ;;; ;;; Copyright (C) 2012 Ludovic Courtès <ludo@gnu.org> ;;; ;;; This file is part of Skribilo. ;;; ;;; Skribilo is free software; you can redistribute it and/or modify it ;;; under the terms of the GNU General Public License as published by ;;; the Free Software Foundation; either version 3 of the License, or (at ;;; your option) any later version. ;;; ;;; Skribilo is distributed in the hope that it will be useful, but ;;; WITHOUT ANY WARRANTY; without even the implied warranty of ;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser ;;; General Public License for more details. ;;; ;;; You should have received a copy of the GNU General Public License ;;; along with this program. If not, see <http://www.gnu.org/licenses/>. (define-module (tests engines info) :use-module (skribilo ast) :use-module (skribilo engine) :use-module (skribilo resolve) :use-module (skribilo package base) :use-module (srfi srfi-1) :use-module (srfi srfi-11) :use-module (srfi srfi-64)) (define %info (find-engine 'info)) (define node-next+prev+up (@@ (skribilo engine info) node-next+prev+up)) (test-begin "info") (test-assert "empty document" (let*-values (((doc) (document #:title "t")) ((next prev up) (node-next+prev+up doc %info))) (and (equal? next "Top") (equal? prev "(dir)") (equal? up "(dir)")))) (test-assert "two chapters" (let ((doc (document #:title "t" (chapter #:title "c" "body") (chapter #:title "d" "body")))) (resolve! doc %info '()) (let-values (((next prev up) (node-next+prev+up doc %info))) (and (equal? up "(dir)") (equal? prev "(dir)") (equal? next "c") (let*-values (((ch) (car (markup-body doc))) ((next prev up) (node-next+prev+up ch %info))) (and (equal? up "Top") (equal? prev "Top") (equal? next "d"))) (let*-values (((ch) (cadr (markup-body doc))) ((next prev up) (node-next+prev+up ch %info))) (and (equal? up "Top") (equal? prev "c") (not next))))))) (test-assert "nest" (let ((doc (document #:title "t" "hello" (chapter #:ident "c" #:title "c" (p "body") (section #:ident "s" #:title "s" "body")) (chapter #:ident "d" #:title "d" "body")))) (resolve! doc %info '()) (and (let*-values (((ch) (document-lookup-node doc "c")) ((next prev up) (node-next+prev+up ch %info))) (and (equal? up "Top") (equal? prev "Top") (equal? next "d"))) (let*-values (((sec) (document-lookup-node doc "s")) ((next prev up) (node-next+prev+up sec %info))) (and (equal? up "c") (not prev) (not next))) (let*-values (((sec) (document-lookup-node doc "d")) ((next prev up) (node-next+prev+up sec %info))) (and (equal? up "Top") (equal? prev "c") (not next)))))) (test-end "info") (exit (= (test-runner-fail-count (test-runner-current)) 0)) ;; Local Variables: ;; coding: utf-8 ;; eval: (put 'test-assert 'scheme-indent-function 1) ;; End: