[functional-tests/run-test] add list command.

This commit is contained in:
Joe Thornber 2017-08-29 10:28:56 +01:00
parent 1940945d6f
commit 61d747b246

View File

@ -83,6 +83,10 @@
(exit) (exit)
(exit #f)))) (exit #f))))
(define (exec-list args)
(let ((pred (mk-filter args)))
(describe-scenarios (filter pred (list-scenarios)))))
;;------------------------------------------------ ;;------------------------------------------------
;; Command line parser ;; Command line parser
@ -93,6 +97,9 @@
(>> (opt whitespace) (>> (opt whitespace)
(<* ma (opt whitespace)))) (<* ma (opt whitespace))))
(define (cmd-word str)
(whitespace-delim (lit str)))
(define (switch str) (define (switch str)
(whitespace-delim (>> (lit "--") (lit str)))) (whitespace-delim (>> (lit "--") (lit str))))
@ -107,11 +114,11 @@
(pure #f))) (pure #f)))
(define help-command-line (define help-command-line
(>> (switch "help") (pure exec-help))) (>> (cmd-word "help") (pure exec-help)))
(define run-command-line (define run-command-line
(parse-m (parse-m
(switch "run") (cmd-word "run")
(<- dunlink (maybe (switch "disable-unlink"))) (<- dunlink (maybe (switch "disable-unlink")))
(<- args (many* not-switch)) (<- args (many* not-switch))
(pure (lambda () (pure (lambda ()
@ -119,8 +126,16 @@
(disable-unlink (exec-run args)) (disable-unlink (exec-run args))
(exec-run args)))))) (exec-run args))))))
(define list-command-line
(parse-m
(cmd-word "list")
(<- args (many* not-switch))
(pure (lambda () (exec-list args)))))
(define command-line-parser (define command-line-parser
(one-of help-command-line run-command-line)) (one-of help-command-line
run-command-line
list-command-line))
(define (bad-command-line) (define (bad-command-line)
(fmt (current-error-port) (dsp "bad command line\n"))) (fmt (current-error-port) (dsp "bad command line\n")))