aboutsummaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
Diffstat (limited to 'tests')
-rw-r--r--tests/ccwl.scm22
-rw-r--r--tests/cwl.scm44
2 files changed, 66 insertions, 0 deletions
diff --git a/tests/ccwl.scm b/tests/ccwl.scm
index 117f93f..6890017 100644
--- a/tests/ccwl.scm
+++ b/tests/ccwl.scm
@@ -27,6 +27,16 @@
(define output
(@@ (ccwl ccwl) output))
+(define make-array-type
+ (@@ (ccwl ccwl) make-array-type))
+
+(define-syntax construct-type-syntax-wrapper
+ (lambda (x)
+ (syntax-case x ()
+ ((_ type-spec)
+ ((@@ (ccwl ccwl) construct-type-syntax)
+ #'type-spec)))))
+
(test-begin "ccwl")
(test-assert "stdin input should not have inputBinding"
@@ -317,4 +327,16 @@
#:other '((secondaryFiles . ".fai"))))
#f)))
+(test-eq "construct-type-syntax on primitive types"
+ 'File
+ (construct-type-syntax-wrapper File))
+
+(test-eq "construct-type-syntax on array types"
+ (make-array-type 'File)
+ (construct-type-syntax-wrapper (array File)))
+
+(test-eq "construct-type-syntax on nested array types"
+ (make-array-type (make-array-type 'File))
+ (construct-type-syntax-wrapper (array (array File))))
+
(test-end "ccwl")
diff --git a/tests/cwl.scm b/tests/cwl.scm
new file mode 100644
index 0000000..ba619ab
--- /dev/null
+++ b/tests/cwl.scm
@@ -0,0 +1,44 @@
+;;; ccwl --- Concise Common Workflow Language
+;;; Copyright © 2023 Arun Isaac <arunisaac@systemreboot.net>
+;;;
+;;; This file is part of ccwl.
+;;;
+;;; ccwl 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.
+;;;
+;;; ccwl 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
+;;; General Public License for more details.
+;;;
+;;; You should have received a copy of the GNU General Public License
+;;; along with ccwl. If not, see <https://www.gnu.org/licenses/>.
+
+(use-modules (srfi srfi-64))
+
+(define type->cwl
+ (@@ (ccwl cwl) type->cwl))
+
+(define make-array-type
+ (@@ (ccwl ccwl) make-array-type))
+
+(test-begin "cwl")
+
+(test-equal "type->cwl on primitive types"
+ 'File
+ (type->cwl 'File))
+
+(test-equal "type->cwl on array types"
+ '((type . array)
+ (items . File))
+ (type->cwl (make-array-type 'File)))
+
+(test-equal "type->cwl on nested array types"
+ '((type . array)
+ (items . ((type . array)
+ (items . File))))
+ (type->cwl (make-array-type (make-array-type 'File))))
+
+(test-end "cwl")