;;; test-ob-C.el --- tests for ob-C.el -*- lexical-binding: t; -*-
;; Copyright (c) 2010-2014, 2019 Sergey Litvinov, Thierry Banel
;; Authors: Sergey Litvinov, Thierry Banel
;; This file is not part of GNU Emacs.
;; This program 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.
;; This program 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 this program. If not, see .
;;; Code:
(unless (featurep 'ob-C)
(signal 'missing-test-dependency "Support for C code blocks"))
(ert-deftest ob-C/simple-program ()
"Hello world program."
(if (executable-find org-babel-C++-compiler)
(org-test-at-id "fa6db330-e960-4ea2-ac67-94bb845b8577"
(org-babel-next-src-block 1)
(should (= 42 (org-babel-execute-src-block))))))
(ert-deftest ob-C/symbol-include ()
"Hello world program with unquoted :includes."
(if (executable-find org-babel-C++-compiler)
(org-test-at-id "fa6db330-e960-4ea2-ac67-94bb845b8577"
(org-babel-next-src-block 2)
(should (= 42 (org-babel-execute-src-block))))))
(ert-deftest ob-D/simple-program ()
"Hello world program."
(if (executable-find org-babel-D-compiler)
(org-test-at-id "fa6db330-e960-4ea2-ac67-94bb845b8577"
(org-babel-next-src-block 3)
(should (= 42 (org-babel-execute-src-block))))))
(ert-deftest ob-C/integer-var ()
"Test of an integer variable."
(if (executable-find org-babel-C++-compiler)
(org-test-at-id "fa6db330-e960-4ea2-ac67-94bb845b8577"
(org-babel-next-src-block 4)
(should (= 12 (org-babel-execute-src-block))))))
(ert-deftest ob-D/integer-var ()
"Test of an integer variable."
(if (executable-find org-babel-D-compiler)
(org-test-at-id "fa6db330-e960-4ea2-ac67-94bb845b8577"
(org-babel-next-src-block 5)
(should (= 12 (org-babel-execute-src-block))))))
(ert-deftest ob-C/two-integer-var ()
"Test of two input variables"
(if (executable-find org-babel-C++-compiler)
(org-test-at-id "fa6db330-e960-4ea2-ac67-94bb845b8577"
(org-babel-next-src-block 6)
(should (= 22 (org-babel-execute-src-block))))))
(ert-deftest ob-D/two-integer-var ()
"Test of two input variables"
(if (executable-find org-babel-D-compiler)
(org-test-at-id "fa6db330-e960-4ea2-ac67-94bb845b8577"
(org-babel-next-src-block 7)
(should (= 22 (org-babel-execute-src-block))))))
(ert-deftest ob-C/string-var ()
"Test of a string input variable"
(if (executable-find org-babel-C++-compiler)
(org-test-at-id "fa6db330-e960-4ea2-ac67-94bb845b8577"
(org-babel-next-src-block 8)
(should (equal "word 4" (org-babel-execute-src-block))))))
(ert-deftest ob-D/string-var ()
"Test of a string input variable"
(if (executable-find org-babel-D-compiler)
(org-test-at-id "fa6db330-e960-4ea2-ac67-94bb845b8577"
(org-babel-next-src-block 9)
(should (equal "word 4" (org-babel-execute-src-block))))))
(ert-deftest ob-C/preprocessor ()
"Test of a string variable"
(if (executable-find org-babel-C++-compiler)
(org-test-at-id "fa6db330-e960-4ea2-ac67-94bb845b8577"
(org-babel-next-src-block 10)
(should (= 42 (org-babel-execute-src-block))))))
(ert-deftest ob-C/float-var ()
"Test that floats are passed without unnecessary rounding."
(if (executable-find org-babel-C++-compiler)
(org-test-with-temp-text
"#+source: float_var
#+begin_src cpp :var x=1.123456789012345678 :includes \"\" :results silent
double y = 1.123456789012345678;
std::cout << (x == y);
#+end_src"
(should (= 1 (org-babel-execute-src-block))))))
(ert-deftest ob-C/table ()
"Test of a table output"
(if (executable-find org-babel-C++-compiler)
(org-test-at-id "2df1ab83-3fa3-462a-a1f3-3aef6044a874"
(org-babel-next-src-block 1)
(should (equal '((1) (2)) (org-babel-execute-src-block))))))
(ert-deftest ob-D/table ()
"Test of a table output"
(if (executable-find org-babel-D-compiler)
(org-test-at-id "2df1ab83-3fa3-462a-a1f3-3aef6044a874"
(org-babel-next-src-block 2)
(should (equal '((1) (2)) (org-babel-execute-src-block))))))
(ert-deftest ob-C/list-var ()
"Test of a list input variable"
(if (executable-find org-babel-C++-compiler)
(org-test-at-id "cc65d6b3-8e8e-4f9c-94cd-f5a00cdeceb5"
(org-babel-next-src-block 1)
(should (string= "abcdef2" (org-babel-execute-src-block))))))
(ert-deftest ob-D/list-var ()
"Test of a list input variable"
(if (executable-find org-babel-D-compiler)
(org-test-at-id "cc65d6b3-8e8e-4f9c-94cd-f5a00cdeceb5"
(org-babel-next-src-block 2)
(should (string= "abcdef2" (org-babel-execute-src-block))))))
(ert-deftest ob-C/vector-var ()
"Test of a vector input variable"
(if (executable-find org-babel-C++-compiler)
(org-test-at-id "cc65d6b3-8e8e-4f9c-94cd-f5a00cdeceb5"
(org-babel-next-src-block 3)
(should (equal 122 (org-babel-execute-src-block))))))
(ert-deftest ob-D/vector-var ()
"Test of a vector input variable"
(if (executable-find org-babel-D-compiler)
(org-test-at-id "cc65d6b3-8e8e-4f9c-94cd-f5a00cdeceb5"
(org-babel-next-src-block 4)
(should (equal 122 (org-babel-execute-src-block))))))
(ert-deftest ob-C/list-list-var ()
"Test of a list list input variable"
(if (executable-find org-babel-C++-compiler)
(org-test-at-id "cc65d6b3-8e8e-4f9c-94cd-f5a00cdeceb5"
(org-babel-next-src-block 5)
(should (equal '((1 3) (2 4)) (org-babel-execute-src-block))))))
(ert-deftest ob-D/list-list-var ()
"Test of a list list input variable"
(if (executable-find org-babel-D-compiler)
(org-test-at-id "cc65d6b3-8e8e-4f9c-94cd-f5a00cdeceb5"
(org-babel-next-src-block 6)
(should (equal '((1 3) (2 4)) (org-babel-execute-src-block))))))
(ert-deftest ob-C/inhomogeneous_table ()
"Test inhomogeneous input table"
(if (executable-find org-babel-C++-compiler)
(org-test-at-id "e112bc2e-419a-4890-99c2-7ac4779531cc"
(org-babel-next-src-block 1)
(should (equal
'(("monday" 34)
("tuesday" 41)
("wednesday" 56)
("thursday" 17)
("friday" 12)
("saturday" 7)
("sunday" 4)
("Friday" "friday"))
(org-babel-execute-src-block))))))
(ert-deftest ob-D/inhomogeneous_table ()
"Test inhomogeneous input table"
(if (executable-find org-babel-D-compiler)
(org-test-at-id "e112bc2e-419a-4890-99c2-7ac4779531cc"
(org-babel-next-src-block 2)
(should (equal
'(("monday" 34)
("tuesday" 41)
("wednesday" 56)
("thursday" 17)
("friday" 12)
("saturday" 7)
("sunday" 4)
("Friday" "friday"))
(org-babel-execute-src-block))))))
(ert-deftest ob-C/ouput-doublequotes ()
"Double quotes not swallowed in raw output"
(if (executable-find org-babel-C++-compiler)
(org-test-at-id "9386490b-4063-4400-842c-4a634edbedf5"
(org-babel-next-src-block 1)
(should (equal
"\"line 1\"\n\"line 2\"\n\"line 3\"\n"
(org-babel-execute-src-block))))))
(ert-deftest ob-C/compile-only-1 ()
"Test `:compile-only' header argument."
(if (executable-find org-babel-C++-compiler)
(unwind-protect
(let* ((file (make-temp-name "hello-world-"))
(file.cpp (concat file ".cpp")))
(org-test-with-temp-text
(format "#+source: compile-only-1
#+begin_src cpp :includes :results none :compile-only yes :file %s
std::cout << \"Hello World!\\n\";
#+end_src
" file)
(should (null (org-babel-execute-src-block)))
(should (file-exists-p file))
(should (file-exists-p file.cpp))))
(ignore-errors (delete-file file))
(ignore-errors (delete-file file.cpp)))))
(ert-deftest ob-C/compile-only-2 ()
"Test `:compile-only' header argument.
A link to the binary file should be inserted."
(if (executable-find org-babel-C++-compiler)
(unwind-protect
(let* ((file (make-temp-name "hello-world-"))
(file.cpp (concat file ".cpp")))
(org-test-with-temp-text
(format "#+source: compile-only-2
#+begin_src cpp :includes :results file :compile-only yes :file %s
std::cout << \"Hello World!\\n\";
#+end_src
" file)
(should (string= file (org-babel-execute-src-block)))
(should (file-exists-p file))
(should (file-exists-p file.cpp))))
(ignore-errors (delete-file file))
(ignore-errors (delete-file file.cpp)))))
(ert-deftest ob-C/compile-only-3 ()
"Test `:compile-only' header argument.
The :file header is unset, which throws an error."
(if (executable-find org-babel-C++-compiler)
(org-test-with-temp-text
(format "#+source: compile-only-3
#+begin_src cpp :includes :results file :compile-only yes
std::cout << \"Hello World!\\n\";
#+end_src
")
(should-error (org-babel-execute-src-block)))))
(ert-deftest ob-C/compile-only-4 ()
"Test `:compile-only' header argument.
A C++ syntax error throws a compiler error. The compiler's error
output is caught in `org-babel-error-buffer-name'; that buffer's
contents are the result of the source block."
(if (executable-find org-babel-C++-compiler)
(unwind-protect
(let* ((file (make-temp-name "hello-world-"))
(file.cpp (concat file ".cpp")))
(org-test-with-temp-text
(format "#+source: compile-only-4.0
#+begin_src cpp :includes :results output :compile-only yes :file %s
std::cout << \"Hello World!\\n\" <== syntax error
#+end_src
" file)
(should (string-match "error:" (org-babel-execute-src-block)))
(should (get-buffer org-babel-error-buffer-name))
(should (file-exists-p file.cpp))))
(ignore-errors (kill-buffer org-babel-error-buffer-name))
(ignore-errors (delete-file file))
(ignore-errors (delete-file file.cpp)))))
(ert-deftest ob-C/compile-only-5 ()
"Test `:compile-only' header argument.
A C++ warning is emitted on stderr. The compiler's warning is
caught in `org-babel-error-buffer-name'; that buffer's contents
are the result of the source block."
(if (executable-find org-babel-C++-compiler)
(unwind-protect
(let* ((file (make-temp-name "hello-world-"))
(file.cpp (concat file ".cpp")))
(org-test-with-temp-text
(format "#+source: compile-only-4.0
#+begin_src cpp :includes :flags -Wall :results output :compile-only yes :file %s
int i;
std::cout << \"Hello World!\\n\";
#+end_src
" file)
(should (string-match "warning:" (org-babel-execute-src-block)))
(should (get-buffer org-babel-error-buffer-name))
(should (file-exists-p file.cpp))))
(ignore-errors (kill-buffer org-babel-error-buffer-name))
(ignore-errors (delete-file file))
(ignore-errors (delete-file file.cpp)))))
(provide 'test-ob-C)
;;; test-ob-C.el ends here