mirror of
https://git.savannah.gnu.org/git/emacs.git
synced 2025-01-16 17:19:41 +00:00
7e09ef09a4
Run admin/update-copyright.
868 lines
25 KiB
EmacsLisp
868 lines
25 KiB
EmacsLisp
;;; semantic-utest.el --- Tests for semantic's parsing system.
|
|
|
|
;;; Copyright (C) 2003-2004, 2007-2015 Free Software Foundation, Inc.
|
|
|
|
;; Author: Eric M. Ludlam <zappo@gnu.org>
|
|
|
|
;; This file is part of GNU Emacs.
|
|
|
|
;; GNU Emacs 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.
|
|
|
|
;; GNU Emacs 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 GNU Emacs. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
;;; Commentary:
|
|
;;
|
|
;; Semantic's parsing and partial parsing system is pretty complex.
|
|
;; These unit tests attempt to emulate semantic's partial reparsing
|
|
;; and full reparsing system, and anything else I may feel the urge
|
|
;; to write a test for.
|
|
|
|
(require 'semantic)
|
|
|
|
(load-file "cedet-utests.el")
|
|
|
|
(defvar semantic-utest-temp-directory (if (fboundp 'temp-directory)
|
|
(temp-directory)
|
|
temporary-file-directory)
|
|
"Temporary directory to use when creating files.")
|
|
|
|
(defun semantic-utest-fname (name)
|
|
"Create a filename for NAME in /tmp."
|
|
(expand-file-name name semantic-utest-temp-directory))
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
;; Data for C tests
|
|
|
|
(defvar semantic-utest-C-buffer-contents
|
|
"/* Test file for C language for Unit Tests */
|
|
|
|
#include <stdio.h>
|
|
#include \"sutest.h\"
|
|
|
|
struct mystruct1 {
|
|
int slot11;
|
|
char slot12;
|
|
float slot13;
|
|
};
|
|
|
|
int var1;
|
|
|
|
float funp1(char arg11, char arg12);
|
|
|
|
char fun2(int arg_21, int arg_22) /*1*/
|
|
{
|
|
struct mystruct1 *ms1 = malloc(sizeof(struct mystruct1));
|
|
|
|
char sv = calc_sv(var1);
|
|
|
|
if (var1 == 0) {
|
|
sv = 1;
|
|
} else if (arg_21 == 0) {
|
|
sv = 2;
|
|
} else if (arg_22 == 0) {
|
|
sv = 3;
|
|
} else {
|
|
sv = 4;
|
|
}
|
|
|
|
printf(\"SV = %d\\n\", sv);
|
|
|
|
/* Memory Leak */
|
|
ms1.slot1 = sv;
|
|
|
|
return 'A' + sv;
|
|
}
|
|
"
|
|
"Contents of a C buffer initialized by this unit test.
|
|
Be sure to change `semantic-utest-C-name-contents' when you
|
|
change this variable.")
|
|
|
|
(defvar semantic-utest-C-h-buffer-contents
|
|
"/* Test file for C language header file for Unit Tests */
|
|
|
|
int calc_sv(int);
|
|
|
|
"
|
|
"Contents of a C header file buffer initialized by this unit test.")
|
|
|
|
(defvar semantic-utest-C-filename (semantic-utest-fname "sutest.c")
|
|
"File to open and erase during this test for C.")
|
|
|
|
(defvar semantic-utest-C-filename-h
|
|
(concat (file-name-sans-extension semantic-utest-C-filename)
|
|
".h")
|
|
"Header file filename for C")
|
|
|
|
|
|
(defvar semantic-utest-C-name-contents
|
|
'(("stdio.h" include
|
|
(:system-flag t)
|
|
nil (overlay 48 66 "sutest.c"))
|
|
("sutest.h" include nil nil (overlay 67 86 "sutest.c"))
|
|
("mystruct1" type
|
|
(:members
|
|
(("slot11" variable
|
|
(:type "int")
|
|
(reparse-symbol classsubparts)
|
|
(overlay 109 120 "sutest.c"))
|
|
("slot12" variable
|
|
(:type "char")
|
|
(reparse-symbol classsubparts)
|
|
(overlay 123 135 "sutest.c"))
|
|
("slot13" variable
|
|
(:type "float")
|
|
(reparse-symbol classsubparts)
|
|
(overlay 138 151 "sutest.c")))
|
|
:type "struct")
|
|
nil (overlay 88 154 "sutest.c"))
|
|
("var1" variable
|
|
(:type "int")
|
|
nil (overlay 156 165 "sutest.c"))
|
|
("funp1" function
|
|
(:prototype-flag t :arguments
|
|
(("arg11" variable
|
|
(:type "char")
|
|
(reparse-symbol arg-sub-list)
|
|
(overlay 179 190 "sutest.c"))
|
|
("arg12" variable
|
|
(:type "char")
|
|
(reparse-symbol arg-sub-list)
|
|
(overlay 191 202 "sutest.c")))
|
|
:type "float")
|
|
nil (overlay 167 203 "sutest.c"))
|
|
("fun2" function
|
|
(:arguments
|
|
(("arg_21" variable
|
|
(:type "int")
|
|
(reparse-symbol arg-sub-list)
|
|
(overlay 215 226 "sutest.c"))
|
|
("arg_22" variable
|
|
(:type "int")
|
|
(reparse-symbol arg-sub-list)
|
|
(overlay 227 238 "sutest.c")))
|
|
:type "char")
|
|
nil (overlay 205 566 "sutest.c")))
|
|
"List of expected tag names for C.")
|
|
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
;; Data for Python tests
|
|
|
|
(defvar semantic-utest-Python-buffer-contents
|
|
"
|
|
def fun1(a,b,c):
|
|
return a
|
|
|
|
def fun2(a,b,c): #1
|
|
return b
|
|
|
|
"
|
|
|
|
|
|
)
|
|
; "python test case. notice that python is indentation sensitive
|
|
|
|
|
|
(defvar semantic-utest-Python-name-contents
|
|
'(("fun1" function
|
|
(:arguments
|
|
(("a" variable nil
|
|
(reparse-symbol function_parameters)
|
|
(overlay 10 11 "tst.py"))
|
|
("b" variable nil
|
|
(reparse-symbol function_parameters)
|
|
(overlay 12 13 "tst.py"))
|
|
("c" variable nil
|
|
(reparse-symbol function_parameters)
|
|
(overlay 14 15 "tst.py"))))
|
|
nil (overlay 1 31 "tst.py"))
|
|
("fun2" function
|
|
(:arguments
|
|
(("a" variable nil
|
|
(reparse-symbol function_parameters)
|
|
(overlay 41 42 "tst.py"))
|
|
("b" variable nil
|
|
(reparse-symbol function_parameters)
|
|
(overlay 43 44 "tst.py"))
|
|
("c" variable nil
|
|
(reparse-symbol function_parameters)
|
|
(overlay 45 46 "tst.py"))))
|
|
nil (overlay 32 65 "tst.py")))
|
|
|
|
"List of expected tag names for Python.")
|
|
|
|
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
;; Data for Java tests
|
|
|
|
(defvar semantic-utest-Java-buffer-contents
|
|
"
|
|
class JavaTest{
|
|
void fun1(int a,int b){
|
|
return a;
|
|
}
|
|
|
|
void fun2(int a,int b){ //1
|
|
return b;
|
|
}
|
|
|
|
}
|
|
"
|
|
)
|
|
|
|
(defvar semantic-utest-Java-name-contents
|
|
'(("JavaTest" type
|
|
(:members
|
|
(("fun1" function
|
|
(:arguments
|
|
(("a" variable
|
|
(:type "int")
|
|
(reparse-symbol formal_parameters)
|
|
(overlay 30 35 "JavaTest.java"))
|
|
("b" variable
|
|
(:type "int")
|
|
(reparse-symbol formal_parameters)
|
|
(overlay 36 41 "JavaTest.java")))
|
|
:type "void")
|
|
(reparse-symbol class_member_declaration)
|
|
(overlay 20 61 "JavaTest.java"))
|
|
("fun2" function
|
|
(:arguments
|
|
(("a" variable
|
|
(:type "int")
|
|
(reparse-symbol formal_parameters)
|
|
(overlay 75 80 "JavaTest.java"))
|
|
("b" variable
|
|
(:type "int")
|
|
(reparse-symbol formal_parameters)
|
|
(overlay 81 86 "JavaTest.java")))
|
|
:type "void")
|
|
(reparse-symbol class_member_declaration)
|
|
(overlay 65 110 "JavaTest.java")))
|
|
:type "class")
|
|
nil (overlay 2 113 "JavaTest.java")))
|
|
"List of expected tag names for Java."
|
|
)
|
|
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
;; Data for Javascript tests
|
|
|
|
(defvar semantic-utest-Javascript-buffer-contents
|
|
"
|
|
function fun1(a, b){
|
|
return a;
|
|
}
|
|
|
|
function fun2(a,b){ //1
|
|
return b;
|
|
}
|
|
"
|
|
)
|
|
|
|
|
|
(defvar semantic-utest-Javascript-name-contents
|
|
'(("fun1" function
|
|
(:arguments
|
|
(("a" variable nil
|
|
(reparse-symbol FormalParameterList)
|
|
(overlay 15 16 "tst.js"))
|
|
("b" variable nil
|
|
(reparse-symbol FormalParameterList)
|
|
(overlay 18 19 "tst.js"))))
|
|
nil (overlay 1 39 "tst.js"))
|
|
("fun2" function
|
|
(:arguments
|
|
(("a" variable nil
|
|
(reparse-symbol FormalParameterList)
|
|
(overlay 55 56 "tst.js"))
|
|
("b" variable nil
|
|
(reparse-symbol FormalParameterList)
|
|
(overlay 57 58 "tst.js"))))
|
|
nil (overlay 41 82 "tst.js")))
|
|
|
|
"List of expected tag names for Javascript.")
|
|
|
|
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
;; Data for Makefile tests
|
|
|
|
(defvar semantic-utest-Makefile-buffer-contents
|
|
"
|
|
t1:
|
|
\techo t1
|
|
|
|
t2:t1 #1
|
|
\techo t2
|
|
|
|
|
|
"
|
|
)
|
|
|
|
|
|
(defvar semantic-utest-Makefile-name-contents
|
|
'(("t1" function nil nil (overlay 1 9 "Makefile"))
|
|
("t2" function
|
|
(:arguments
|
|
("t1"))
|
|
nil (overlay 18 28 "Makefile")))
|
|
"List of expected tag names for Makefile.")
|
|
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
;; Data for Scheme tests
|
|
|
|
(defvar semantic-utest-Scheme-buffer-contents
|
|
"
|
|
(define fun1 2)
|
|
|
|
(define fun2 3 ;1
|
|
)
|
|
")
|
|
|
|
(defvar semantic-utest-Scheme-name-contents
|
|
'(("fun1" variable
|
|
(:default-value ("2"))
|
|
nil (overlay 3 18 "tst.scm"))
|
|
("fun2" variable
|
|
(:default-value ("3"))
|
|
nil (overlay 21 55 "tst.scm")))
|
|
)
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
;; Data for Html tests
|
|
|
|
(defvar semantic-utest-Html-buffer-contents
|
|
"
|
|
<html>
|
|
<body>
|
|
<h1>hello</h1>
|
|
</body><!--1-->
|
|
</html>
|
|
"
|
|
)
|
|
|
|
(defvar semantic-utest-Html-name-contents
|
|
'(("hello" section
|
|
(:members
|
|
(("hello" section nil nil (overlay 21 24 "tst.html"))))
|
|
nil (overlay 10 15 "tst.html")))
|
|
)
|
|
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
;; Data for PHP tests
|
|
|
|
(defvar semantic-utest-PHP-buffer-contents
|
|
"<?php
|
|
|
|
function fun1(){
|
|
return \"fun1\";
|
|
}
|
|
|
|
function fun2($arg1){
|
|
$output = \"argument to fun2: \" . $arg1;
|
|
return $output;
|
|
}
|
|
|
|
class aClass {
|
|
public function fun1($a, $b){
|
|
return $a;
|
|
}
|
|
|
|
public function fun2($a, $b){
|
|
return $b;
|
|
}
|
|
}
|
|
?> "
|
|
)
|
|
|
|
(defvar semantic-utest-PHP-name-contents
|
|
'(("fun1" function nil
|
|
nil (overlay 9 45 "phptest.php"))
|
|
("fun2" function
|
|
(:arguments (("$arg1" variable nil (reparse-symbol formal_parameters) (overlay 61 66 "phptest.php"))))
|
|
nil
|
|
(overlay 47 132 "phptest.php"))
|
|
("aClass" type
|
|
(:members (("fun1" function
|
|
(:typemodifiers ("public") :arguments
|
|
(("$a" variable nil (reparse-symbol formal_parameters) (overlay 174 176 "phptest.php"))
|
|
("$b" variable nil (reparse-symbol formal_parameters) (overlay 178 180 "phptest.php"))))
|
|
|
|
nil
|
|
(overlay 153 204 "phptest.php"))
|
|
|
|
("fun2" function
|
|
(:typemodifiers ("public") :arguments
|
|
(("$a" variable nil (reparse-symbol formal_parameters) (overlay 230 232 "phptest.php"))
|
|
("$b" variable nil (reparse-symbol formal_parameters) (overlay 234 236 "phptest.php"))
|
|
))
|
|
nil
|
|
(overlay 209 260 "phptest.php"))) :type "class")
|
|
nil
|
|
(overlay 135 262 "phptest.php"))
|
|
)
|
|
"Expected results from the PHP Unit test"
|
|
)
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
;; Data for Csharp C# tests
|
|
|
|
(defvar semantic-utest-Csharp-buffer-contents
|
|
"
|
|
class someClass {
|
|
int fun1(int a, int b) {
|
|
return a; }
|
|
int fun2(int a, int b) {
|
|
return b; }
|
|
}
|
|
")
|
|
|
|
(defvar semantic-utest-Csharp-name-contents
|
|
'(("someClass" type
|
|
(:members
|
|
(("fun1" function
|
|
(:arguments
|
|
(("a" variable
|
|
(:type "int")
|
|
(reparse-symbol formal_parameters)
|
|
(overlay 30 35 "tst.cs"))
|
|
("b" variable
|
|
(:type "int")
|
|
(reparse-symbol formal_parameters)
|
|
(overlay 37 42 "tst.cs")))
|
|
:type "int")
|
|
(reparse-symbol class_member_declaration)
|
|
(overlay 21 61 "tst.cs"))
|
|
("fun2" function
|
|
(:arguments
|
|
(("a" variable
|
|
(:type "int")
|
|
(reparse-symbol formal_parameters)
|
|
(overlay 73 78 "tst.cs"))
|
|
("b" variable
|
|
(:type "int")
|
|
(reparse-symbol formal_parameters)
|
|
(overlay 80 85 "tst.cs")))
|
|
:type "int")
|
|
(reparse-symbol class_member_declaration)
|
|
(overlay 64 104 "tst.cs")))
|
|
:type "class")
|
|
nil (overlay 1 106 "tst.cs")))
|
|
)
|
|
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
|
|
|
|
(defun semantic-utest-makebuffer (filename contents)
|
|
"Create a buffer for FILENAME for use in a unit test.
|
|
Pre-fill the buffer with CONTENTS."
|
|
(let ((buff (semantic-find-file-noselect filename)))
|
|
(set-buffer buff)
|
|
(setq buffer-offer-save nil)
|
|
(font-lock-mode -1) ;; Font lock has issues in Emacs 23
|
|
(toggle-read-only -1) ;; In case /tmp doesn't exist.
|
|
(erase-buffer)
|
|
(insert contents)
|
|
;(semantic-fetch-tags) ;JAVE could this go here?
|
|
(set-buffer-modified-p nil)
|
|
buff
|
|
)
|
|
)
|
|
|
|
(defun semantic-utest-C ()
|
|
"Run semantic's C unit test."
|
|
(interactive)
|
|
(save-excursion
|
|
(let ((buff (semantic-utest-makebuffer semantic-utest-C-filename semantic-utest-C-buffer-contents))
|
|
(buff2 (semantic-utest-makebuffer semantic-utest-C-filename-h semantic-utest-C-h-buffer-contents))
|
|
)
|
|
(semantic-fetch-tags)
|
|
(set-buffer buff)
|
|
|
|
;; Turn off a range of modes
|
|
(semantic-idle-scheduler-mode -1)
|
|
|
|
;; Turn on some modes
|
|
(semantic-highlight-edits-mode 1)
|
|
|
|
;; Update tags, and show it.
|
|
(semantic-fetch-tags)
|
|
|
|
(switch-to-buffer buff)
|
|
(sit-for 0)
|
|
|
|
;; Run the tests.
|
|
;;(message "First parsing test.")
|
|
(semantic-utest-verify-names semantic-utest-C-name-contents)
|
|
|
|
;;(message "Invalid tag test.")
|
|
(semantic-utest-last-invalid semantic-utest-C-name-contents '("fun2") "/\\*1\\*/" "/* Deleted this line */")
|
|
(semantic-utest-verify-names semantic-utest-C-name-contents)
|
|
|
|
(set-buffer-modified-p nil)
|
|
;; Clean up
|
|
;; (kill-buffer buff)
|
|
;; (kill-buffer buff2)
|
|
))
|
|
(message "All C tests passed.")
|
|
)
|
|
|
|
|
|
|
|
|
|
(defun semantic-utest-generic (testname filename contents name-contents names-removed killme insertme)
|
|
"Generic unit test according to template.
|
|
Should work for languages without .h files, python javascript java.
|
|
TESTNAME is the name of the test.
|
|
FILENAME is the name of the file to create.
|
|
CONTENTS is the contents of the file to test.
|
|
NAME-CONTENTS is the list of names that should be in the contents.
|
|
NAMES-REMOVED is the list of names that gets removed in the removal step.
|
|
KILLME is the name of items to be killed.
|
|
INSERTME is the text to be inserted after the deletion."
|
|
(save-excursion
|
|
(let ((buff (semantic-utest-makebuffer filename contents))
|
|
)
|
|
;; Turn off a range of modes
|
|
(semantic-idle-scheduler-mode -1)
|
|
|
|
;; Turn on some modes
|
|
(semantic-highlight-edits-mode 1)
|
|
|
|
;; Update tags, and show it.
|
|
(semantic-fetch-tags)
|
|
(switch-to-buffer buff)
|
|
(sit-for 0)
|
|
|
|
;; Run the tests.
|
|
;;(message "First parsing test %s." testname)
|
|
(semantic-utest-verify-names name-contents)
|
|
|
|
;;(message "Invalid tag test %s." testname)
|
|
(semantic-utest-last-invalid name-contents names-removed killme insertme)
|
|
(semantic-utest-verify-names name-contents)
|
|
|
|
(set-buffer-modified-p nil)
|
|
;; Clean up
|
|
;; (kill-buffer buff)
|
|
))
|
|
(message "All %s tests passed." testname)
|
|
)
|
|
|
|
(defun semantic-utest-Python()
|
|
(interactive)
|
|
(if (fboundp 'python-mode)
|
|
(semantic-utest-generic "Python" (semantic-utest-fname "pytest.py") semantic-utest-Python-buffer-contents semantic-utest-Python-name-contents '("fun2") "#1" "#deleted line")
|
|
(message "Skilling Python test: NO major mode."))
|
|
)
|
|
|
|
|
|
(defun semantic-utest-Javascript()
|
|
(interactive)
|
|
(if (fboundp 'javascript-mode)
|
|
(semantic-utest-generic "Javascript" (semantic-utest-fname "javascripttest.js") semantic-utest-Javascript-buffer-contents semantic-utest-Javascript-name-contents '("fun2") "//1" "//deleted line")
|
|
(message "Skipping JavaScript test: NO major mode."))
|
|
)
|
|
|
|
(defun semantic-utest-Java()
|
|
(interactive)
|
|
;; If JDE is installed, it might mess things up depending on the version
|
|
;; that was installed.
|
|
(let ((auto-mode-alist '(("\\.java\\'" . java-mode))))
|
|
(semantic-utest-generic "Java" (semantic-utest-fname "JavaTest.java") semantic-utest-Java-buffer-contents semantic-utest-Java-name-contents '("fun2") "//1" "//deleted line")
|
|
))
|
|
|
|
(defun semantic-utest-Makefile()
|
|
(interactive)
|
|
(semantic-utest-generic "Makefile" (semantic-utest-fname "Makefile") semantic-utest-Makefile-buffer-contents semantic-utest-Makefile-name-contents '("fun2") "#1" "#deleted line")
|
|
)
|
|
|
|
(defun semantic-utest-Scheme()
|
|
(interactive)
|
|
(semantic-utest-generic "Scheme" (semantic-utest-fname "tst.scm") semantic-utest-Scheme-buffer-contents semantic-utest-Scheme-name-contents '("fun2") ";1" ";deleted line")
|
|
)
|
|
|
|
|
|
(defun semantic-utest-Html()
|
|
(interactive)
|
|
;; Disable html-helper auto-fill-in mode.
|
|
(let ((html-helper-build-new-buffer nil))
|
|
(semantic-utest-generic "HTML" (semantic-utest-fname "tst.html") semantic-utest-Html-buffer-contents semantic-utest-Html-name-contents '("fun2") "<!--1-->" "<!--deleted line-->")
|
|
))
|
|
|
|
(defun semantic-utest-PHP()
|
|
(interactive)
|
|
(if (fboundp 'php-mode)
|
|
(semantic-utest-generic "PHP" (semantic-utest-fname "phptest.php") semantic-utest-PHP-buffer-contents semantic-utest-PHP-name-contents '("fun1") "fun2" "%^@")
|
|
(message "Skipping PHP Test. No php-mode loaded."))
|
|
)
|
|
|
|
;look at http://mfgames.com/linux/csharp-mode
|
|
(defun semantic-utest-Csharp() ;; hmm i don't even know how to edit a scharp file. need a csharp mode implementation i suppose
|
|
(interactive)
|
|
(if (fboundp 'csharp-mode)
|
|
(semantic-utest-generic "C#" (semantic-utest-fname "csharptest.cs") semantic-utest-Csharp-buffer-contents semantic-utest-Csharp-name-contents '("fun2") "//1" "//deleted line")
|
|
(message "Skipping C# test. No csharp-mode loaded."))
|
|
)
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
;; stubs
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
; stuff for Erlang
|
|
;;-module(hello).
|
|
;-export([hello_world/0]).
|
|
;
|
|
;hello_world()->
|
|
; io:format("Hello World ~n").
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
;(defun semantic-utest-Erlang()
|
|
; (interactive)
|
|
; (semantic-utest-generic "Erlang" (semantic-utest-fname "tst.erl") semantic-utest-Erlang-buffer-contents semantic-utest-Erlang-name-contents '("fun2") "//1" "//deleted line")
|
|
; )
|
|
;
|
|
;;texi is also supported
|
|
;(defun semantic-utest-Texi()
|
|
; (interactive)
|
|
; (semantic-utest-generic "texi" (semantic-utest-fname "tst.texi") semantic-utest-Texi-buffer-contents semantic-utest-Texi-name-contents '("fun2") "//1" "//deleted line")
|
|
; )
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
;;;###autoload
|
|
(defun semantic-utest-main()
|
|
(interactive)
|
|
"call all utests"
|
|
(cedet-utest-log-start "multi-lang parsing")
|
|
(cedet-utest-log " * C tests...")
|
|
(semantic-utest-C)
|
|
(cedet-utest-log " * Python tests...")
|
|
(semantic-utest-Python)
|
|
(cedet-utest-log " * Java tests...")
|
|
(semantic-utest-Java)
|
|
(cedet-utest-log " * Javascript tests...")
|
|
(semantic-utest-Javascript)
|
|
(cedet-utest-log " * Makefile tests...")
|
|
(semantic-utest-Makefile)
|
|
(cedet-utest-log " * Scheme tests...")
|
|
(semantic-utest-Scheme)
|
|
(cedet-utest-log " * Html tests...")
|
|
(semantic-utest-Html)
|
|
(cedet-utest-log " * PHP tests...")
|
|
(semantic-utest-PHP)
|
|
(cedet-utest-log " * Csharp tests...")
|
|
(semantic-utest-Csharp)
|
|
|
|
(cedet-utest-log-shutdown "multi-lang parsing")
|
|
)
|
|
|
|
;;; Buffer contents validation
|
|
;;
|
|
(defun semantic-utest-match-attributes (attr1 attr2 skipnames)
|
|
"Compare attribute lists ATTR1 and ATTR2.
|
|
Argument SKIPNAMES is a list of names that may be child nodes to skip."
|
|
(let ((res t))
|
|
(while (and res attr1 attr2)
|
|
|
|
;; Compare
|
|
(setq res
|
|
(cond ((and (listp (car attr1))
|
|
(semantic-tag-p (car (car attr1))))
|
|
;; Compare the list of tags...
|
|
(semantic-utest-taglists-equivalent-p
|
|
(car attr2) (car attr1) skipnames)
|
|
)
|
|
(t
|
|
(equal (car attr1) (car attr2)))))
|
|
|
|
(if (not res)
|
|
(error "TAG INTERNAL DIFF: %S %S"
|
|
(car attr1) (car attr2)))
|
|
|
|
(setq attr1 (cdr attr1)
|
|
attr2 (cdr attr2)))
|
|
res))
|
|
|
|
(defun semantic-utest-equivalent-tag-p (tag1 tag2 skipnames)
|
|
"Determine if TAG1 and TAG2 are the same.
|
|
SKIPNAMES includes lists of possible child nodes that should be missing."
|
|
(and (equal (semantic-tag-name tag1) (semantic-tag-name tag2))
|
|
(semantic-tag-of-class-p tag1 (semantic-tag-class tag2))
|
|
(semantic-utest-match-attributes
|
|
(semantic-tag-attributes tag1) (semantic-tag-attributes tag2)
|
|
skipnames)
|
|
))
|
|
|
|
(defun semantic-utest-taglists-equivalent-p (table names skipnames)
|
|
"Compare TABLE and NAMES, where skipnames allow list1 to be different.
|
|
SKIPNAMES is a list of names that should be skipped in the NAMES list."
|
|
(let ((SN skipnames))
|
|
(while SN
|
|
(setq names (remove (car SN) names))
|
|
(setq SN (cdr SN))))
|
|
(while (and names table)
|
|
(if (not (semantic-utest-equivalent-tag-p (car names)
|
|
(car table)
|
|
skipnames))
|
|
(error "Expected %s, found %s"
|
|
(semantic-format-tag-prototype (car names))
|
|
(semantic-format-tag-prototype (car table))))
|
|
(setq names (cdr names)
|
|
table (cdr table)))
|
|
(when names (error "Items forgotten: %S"
|
|
(mapcar 'semantic-tag-name names)
|
|
))
|
|
(when table (error "Items extra: %S"
|
|
(mapcar 'semantic-tag-name table)))
|
|
t)
|
|
|
|
(defun semantic-utest-verify-names (name-contents &optional skipnames)
|
|
"Verify the names of the test buffer from NAME-CONTENTS.
|
|
Argument SKIPNAMES is a list of names that should be skipped
|
|
when analyzing the file.
|
|
|
|
JAVE this thing would need to be recursive to handle java and csharp"
|
|
(let ((names name-contents)
|
|
(table (semantic-fetch-tags))
|
|
)
|
|
(semantic-utest-taglists-equivalent-p table names skipnames)
|
|
))
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;
|
|
; JAVE redefine a new validation function
|
|
; is not quite as good as the old one yet
|
|
(defun semantic-utest-verify-names-jave (name-contents &optional skipnames)
|
|
"JAVE version of `semantic-utest-verify-names'.
|
|
NAME-CONTENTS is a sample of the tags buffer to test against.
|
|
SKIPNAMES is a list of names to remove from NAME-CONTENTS"
|
|
(assert (semantic-utest-verify-names-2 name-contents (semantic-fetch-tags))
|
|
nil "failed test")
|
|
)
|
|
|
|
(defun semantic-utest-verify-names-2 (l1 l2)
|
|
(cond ( (and (consp l1) (equal (car l1) 'overlay))
|
|
(overlayp l2))
|
|
((not (consp l1))
|
|
(equal l1 l2))
|
|
((consp l1)
|
|
(and (semantic-utest-verify-names-2 (car l1) (car l2)) (semantic-utest-verify-names-2 (cdr l1) (cdr l2))))
|
|
(t (error "internal error"))))
|
|
|
|
|
|
|
|
|
|
|
|
;;; Kill indicator line
|
|
;;
|
|
(defvar semantic-utest-last-kill-text nil
|
|
"The text from the last kill.")
|
|
|
|
(defvar semantic-utest-last-kill-pos nil
|
|
"The position of the last kill.")
|
|
|
|
(defun semantic-utest-kill-indicator ( killme insertme)
|
|
"Kill the line with KILLME on it and insert INSERTME in its place."
|
|
(goto-char (point-min))
|
|
; (re-search-forward (concat "/\\*" indicator "\\*/")); JAVE this isn't generic enough for different languages
|
|
(re-search-forward killme)
|
|
(beginning-of-line)
|
|
(setq semantic-utest-last-kill-pos (point))
|
|
(setq semantic-utest-last-kill-text
|
|
(buffer-substring (point) (point-at-eol)))
|
|
(delete-region (point) (point-at-eol))
|
|
(insert insertme)
|
|
(sit-for 0)
|
|
)
|
|
|
|
(defun semantic-utest-unkill-indicator ()
|
|
"Unkill the last indicator."
|
|
(goto-char semantic-utest-last-kill-pos)
|
|
(delete-region (point) (point-at-eol))
|
|
(insert semantic-utest-last-kill-text)
|
|
(sit-for 0)
|
|
)
|
|
|
|
;;; EDITING TESTS
|
|
;;
|
|
|
|
(defun semantic-utest-last-invalid (name-contents names-removed killme insertme)
|
|
"Make the last fcn invalid."
|
|
(semantic-utest-kill-indicator killme insertme)
|
|
; (semantic-utest-verify-names name-contents names-removed); verify its gone ;new validator doesn't handle skipnames yet
|
|
(semantic-utest-unkill-indicator);put back killed stuff
|
|
)
|
|
|
|
|
|
|
|
|
|
;"#<overlay from \\([0-9]+\\) to \\([0-9]+\\) in \\([^>]*\\)>"
|
|
;#<overlay from \([0-9]+\) to \([0-9]+\) in \([^>]*\)>
|
|
;(overlay \1 \2 "\3")
|
|
|
|
|
|
;; JAVE
|
|
;; these are some unit tests for cedet that I got from Eric and modified a bit for:
|
|
;; python
|
|
;; javascript
|
|
;; java
|
|
;; I tried to generalize the structure of the tests a bit to make it easier to add languages
|
|
|
|
;; Mail from Eric:
|
|
;; Many items in the checklist look like:
|
|
|
|
;; M-x global-semantic-highlight-edits-mode RET
|
|
;; - Edit a file. See the highlight of newly inserted text.
|
|
;; - Customize `semantic-edits-verbose-flag' to be non-nil.
|
|
;; - Wait for the idle scheduler, it should clean up the edits.
|
|
;; - observe messages from incremental parser. Do they relate
|
|
;; to the edits?
|
|
;; - M-x bovinate RET - verify your changes are reflected.
|
|
|
|
;; It's all about watching the behavior. Timers go off, things get
|
|
;; cleaned up, you type in new changes, etc. An example I tried to
|
|
;; do is below, but covers only 1 language, and not very well at that.
|
|
;; I seem to remember seeing a unit test framework going by one of the
|
|
;; lists. I'm not sure if that would help.
|
|
|
|
;; Another that might be automatable:
|
|
|
|
;; M-x semantic-analyze-current-context RET
|
|
;; - Do this in different contexts in your language
|
|
;; files. Verify that reasonable results are returned
|
|
;; such as identification of assignments, function arguments, etc.
|
|
|
|
;; Anyway, those are some ideas. Any effort you put it will be helpful!
|
|
|
|
;; Thanks
|
|
;; Eric
|
|
|
|
;; -----------
|
|
|
|
|
|
|
|
;;; semantic-utest.el ends here
|