summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--ccwl/ccwl.scm7
-rw-r--r--tests/ccwl.scm9
2 files changed, 14 insertions, 2 deletions
diff --git a/ccwl/ccwl.scm b/ccwl/ccwl.scm
index a319105..695fa8d 100644
--- a/ccwl/ccwl.scm
+++ b/ccwl/ccwl.scm
@@ -347,8 +347,11 @@ RUN-ARGS. If such an input is not present in RUN-ARGS, return #f."
                                           (begin
                                             (ensure-input-is-defined #'input)
                                             #''input))
-                                         (_ (error "Invalid command element:"
-                                                   (syntax->datum x)))))
+                                         (_
+                                          (raise-exception
+                                           (condition (ccwl-violation x)
+                                                      (formatted-message "Invalid command element ~a. Command elements must either be input identifiers or literal strings."
+                                                                         (syntax->datum x)))))))
                                      run)))
                      #,(and stdin #`'#,stdin)
                      #,(if (and stderr
diff --git a/tests/ccwl.scm b/tests/ccwl.scm
index 334633b..aef2a85 100644
--- a/tests/ccwl.scm
+++ b/tests/ccwl.scm
@@ -252,4 +252,13 @@
                       #:run "echo" ("-x" n)))
            #f)))
 
+(test-assert "command definitions with invalid #:run arguments must raise a &ccwl-violation condition"
+  (guard (exception
+          (else (and (ccwl-violation? exception)
+                     (string=? (formatted-message-format exception)
+                               "Invalid command element ~a. Command elements must either be input identifiers or literal strings."))))
+    (begin (macroexpand
+            '(command #:run "echo" 42))
+           #f)))
+
 (test-end "ccwl")