Add rudimentary ECMAScript tests.
authorLudovic Courtès <ludo@gnu.org>
Tue, 30 Mar 2010 22:09:40 +0000 (00:09 +0200)
committerLudovic Courtès <ludo@gnu.org>
Tue, 30 Mar 2010 22:42:01 +0000 (00:42 +0200)
* test-suite/Makefile.am (SCM_TESTS): Add `tests/ecmascript.test'.

* test-suite/tests/ecmascript.test: New file.

test-suite/Makefile.am
test-suite/tests/ecmascript.test [new file with mode: 0644]

index 94789d3..ad8a8f7 100644 (file)
@@ -34,6 +34,7 @@ SCM_TESTS = tests/alist.test                  \
            tests/common-list.test              \
            tests/control.test                  \
            tests/continuations.test            \
+           tests/ecmascript.test               \
            tests/elisp.test                    \
            tests/elisp-compiler.test           \
            tests/elisp-reader.test             \
diff --git a/test-suite/tests/ecmascript.test b/test-suite/tests/ecmascript.test
new file mode 100644 (file)
index 0000000..c5ef344
--- /dev/null
@@ -0,0 +1,74 @@
+;;;; ecmascript.test --- ECMAScript.      -*- mode: scheme; coding: utf-8; -*-
+;;;;
+;;;;   Copyright (C) 2010 Free Software Foundation, Inc.
+;;;;
+;;;; This library is free software; you can redistribute it and/or
+;;;; modify it under the terms of the GNU Lesser General Public
+;;;; License as published by the Free Software Foundation; either
+;;;; version 3 of the License, or (at your option) any later version.
+;;;;
+;;;; This library 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 Lesser General Public
+;;;; License along with this library; if not, write to the Free Software
+;;;; Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+
+(define-module (test-ecmascript)
+  #:use-module (test-suite lib)
+  #:use-module (language ecmascript parse)
+  #:use-module ((system base compile) #:select (compile)))
+
+\f
+(define (eread str)
+  (call-with-input-string str read-ecmascript))
+
+(define-syntax parse
+  (syntax-rules ()
+    ((_ expression expected)
+     (pass-if expression
+       (equal? expected (eread expression))))))
+
+(with-test-prefix "parser"
+
+  (parse "true;" 'true)
+  (parse "2 + 2;" '(+ (number 2) (number 2)))
+  (parse "\"hello\";" '(string "hello"))
+  (parse "function square(x) { return x * x; }"
+         '(var (square (lambda (x) (return (* (ref x) (ref x)))))))
+  (parse "document.write('Hello, world!');"
+         '(call (pref (ref document) write) ((string "Hello, world!"))))
+  (parse "var x = { foo: 12, bar: \"hello\" };"
+         '(begin (var (x (object (foo (number 12))
+                                 (bar (string "hello")))))
+                 (begin))))
+
+\f
+(define-syntax ecompile
+  (syntax-rules ()
+    ((_ expression expected)
+     (pass-if expression
+       (equal? expected
+               (compile (call-with-input-string expression read-ecmascript)
+                        #:from 'ecmascript
+                        #:to 'value))))))
+
+(with-test-prefix "compiler"
+
+  (ecompile "true;" #t)
+  (ecompile "2 + 2;" 4)
+  (ecompile "\"hello\";" "hello")
+
+  ;; FIXME: Broken!
+  ;; (ecompile "[1,2,3,4].map(function(x) { return x * x; });"
+  ;;           '(1 4 9 16))
+
+  ;; Examples from
+  ;; <http://wingolog.org/archives/2009/02/22/ecmascript-for-guile>.
+
+  (ecompile "42 + \" good times!\";"
+            "42 good times!")
+  (ecompile "[0,1,2,3,4,5].length * 7;"
+            42))