mirror of
				https://github.com/notepad-plus-plus/notepad-plus-plus.git
				synced 2025-10-25 01:23:51 +02:00 
			
		
		
		
	[xml] Add SQL unit tests
And make unit test error message more explicit. Close #12627
This commit is contained in:
		
							parent
							
								
									e596baad11
								
							
						
					
					
						commit
						ee336b24c1
					
				
							
								
								
									
										154
									
								
								PowerEditor/Test/FunctionList/sql/comment_assignment/unitTest
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										154
									
								
								PowerEditor/Test/FunctionList/sql/comment_assignment/unitTest
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,154 @@ | |||||||
|  | create package CheckFunctionList_pck | ||||||
|  | as | ||||||
|  | 
 | ||||||
|  | function ctrlData( | ||||||
|  |   po_severity        in out nocopy varchar2, | ||||||
|  |   po_err_code        in out nocopy varchar2, | ||||||
|  |   po_err_message     in out nocopy varchar2, | ||||||
|  |   p_Data             in     ind_work_data_r | ||||||
|  | ) return boolean; | ||||||
|  | 
 | ||||||
|  |     procedure INIT_DECODE_RULES1  (po_severity        in  out         varchar2 | ||||||
|  |                                   ,po_err_code        in  out         varchar2 | ||||||
|  |                                   ,po_err_message     in  out         varchar2 | ||||||
|  |                                   ,po_tabDecRules         out nocopy  report_utl_pck.tTabDecRules | ||||||
|  |                                   ); | ||||||
|  |     | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     procedure INIT_DECODE_RULES2  (po_severity        in  out         varchar2 | ||||||
|  |                                   ,po_err_code        in  out         varchar2 | ||||||
|  |                                   ,po_err_message     in  out         varchar2 | ||||||
|  |                                   ,po_tabDecRules         out nocopy  report_utl_pck.tTabDecRules); | ||||||
|  |     | ||||||
|  | function GetEsecId | ||||||
|  | return tab1.esec_id%type; | ||||||
|  |      | ||||||
|  |     procedure pippo; | ||||||
|  |      | ||||||
|  |      | ||||||
|  |      | ||||||
|  |     procedure INIT_DECODE_RULES3  (po_severity        in  out         varchar2 | ||||||
|  |                                   ,po_err_code        in  out         varchar2 | ||||||
|  |                                   ,po_err_message     in  out         varchar2 | ||||||
|  |                                   ,po_guid            in              guid_list_t := guid_list_t() | ||||||
|  |                                   ,po_tabDecRules         out nocopy  report_utl_pck.tTabDecRules); | ||||||
|  |    | ||||||
|  |      | ||||||
|  |     procedure INIT_DECODE_RULES4  (po_severity        in  out         varchar2 | ||||||
|  |                                   ,po_err_code        in  out         varchar2 | ||||||
|  |                                   ,po_err_message     in  out         varchar2 | ||||||
|  |                                   ,po_guid            in              guid_list_t := guid_list_t() | ||||||
|  |                                   ,po_tabDecRules         out nocopy  report_utl_pck.tTabDecRules | ||||||
|  |                                   ); | ||||||
|  |      | ||||||
|  |     procedure INIT_DECODE_RULES5  (po_severity        in  out         varchar2 | ||||||
|  |                                   ,po_err_code        in  out         varchar2 | ||||||
|  |                                   ,po_err_message     in  out         varchar2 -- this is a comment with (brackets) | ||||||
|  |                                   ,po_tabDecRules         out nocopy  report_utl_pck.tTabDecRules); | ||||||
|  |      | ||||||
|  |      | ||||||
|  |     procedure INIT_DECODE_RULES6  (po_severity        in  out         varchar2 | ||||||
|  |                                   ,po_err_code        in  out         varchar2 | ||||||
|  |                                   ,po_err_message     in  out         varchar2 -- this is a comment with (brackets) | ||||||
|  |                                   ,po_tabDecRules         out nocopy  report_utl_pck.tTabDecRules | ||||||
|  |                                   ); | ||||||
|  |    | ||||||
|  | end CheckFunctionList_pck; | ||||||
|  | / | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | create package body CheckFunctionList_pck | ||||||
|  | as | ||||||
|  | 
 | ||||||
|  | function ctrlData( | ||||||
|  |   po_severity        in out nocopy varchar2, | ||||||
|  |   po_err_code        in out nocopy varchar2, | ||||||
|  |   po_err_message     in out nocopy varchar2, | ||||||
|  |   p_Data             in     ind_work_data_r | ||||||
|  | ) return boolean | ||||||
|  | is | ||||||
|  | begin | ||||||
|  |   return null; | ||||||
|  | end ctrlData; | ||||||
|  | 
 | ||||||
|  |     procedure INIT_DECODE_RULES1  (po_severity        in  out         varchar2 | ||||||
|  |                                   ,po_err_code        in  out         varchar2 | ||||||
|  |                                   ,po_err_message     in  out         varchar2 | ||||||
|  |                                   ,po_tabDecRules         out nocopy  report_utl_pck.tTabDecRules | ||||||
|  |                                   ) | ||||||
|  |     as | ||||||
|  |     begin | ||||||
|  |       null; | ||||||
|  |     end INIT_DECODE_RULES1; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     procedure INIT_DECODE_RULES2  (po_severity        in  out         varchar2 | ||||||
|  |                                   ,po_err_code        in  out         varchar2 | ||||||
|  |                                   ,po_err_message     in  out         varchar2 | ||||||
|  |                                   ,po_tabDecRules         out nocopy  report_utl_pck.tTabDecRules) | ||||||
|  |     as | ||||||
|  |     begin | ||||||
|  |       null; | ||||||
|  |     end INIT_DECODE_RULES2; | ||||||
|  |    | ||||||
|  |    | ||||||
|  | function GetEsecId | ||||||
|  | return tab1.esec_id%type | ||||||
|  | is | ||||||
|  | begin | ||||||
|  |   return null; | ||||||
|  | end GetEsecId; | ||||||
|  |    | ||||||
|  |      | ||||||
|  |     procedure pippo | ||||||
|  |     is | ||||||
|  |     begin | ||||||
|  |       null; | ||||||
|  |     end pippo; | ||||||
|  |      | ||||||
|  |      | ||||||
|  |     procedure INIT_DECODE_RULES3  (po_severity        in  out         varchar2 | ||||||
|  |                                   ,po_err_code        in  out         varchar2 | ||||||
|  |                                   ,po_err_message     in  out         varchar2 | ||||||
|  |                                   ,po_guid            in              guid_list_t := guid_list_t() | ||||||
|  |                                   ,po_tabDecRules         out nocopy  report_utl_pck.tTabDecRules) | ||||||
|  |     as | ||||||
|  |     begin | ||||||
|  |       null; | ||||||
|  |     end INIT_DECODE_RULES3; | ||||||
|  |      | ||||||
|  |     procedure INIT_DECODE_RULES4  (po_severity        in  out         varchar2 | ||||||
|  |                                   ,po_err_code        in  out         varchar2 | ||||||
|  |                                   ,po_err_message     in  out         varchar2 | ||||||
|  |                                   ,po_guid            in              guid_list_t := guid_list_t() | ||||||
|  |                                   ,po_tabDecRules         out nocopy  report_utl_pck.tTabDecRules | ||||||
|  |                                   ) | ||||||
|  |     as | ||||||
|  |     begin | ||||||
|  |       null; | ||||||
|  |     end INIT_DECODE_RULES4; | ||||||
|  |      | ||||||
|  |     procedure INIT_DECODE_RULES5  (po_severity        in  out         varchar2 | ||||||
|  |                                   ,po_err_code        in  out         varchar2 | ||||||
|  |                                   ,po_err_message     in  out         varchar2 -- this is a comment with (brackets) | ||||||
|  |                                   ,po_tabDecRules         out nocopy  report_utl_pck.tTabDecRules) | ||||||
|  |     as | ||||||
|  |     begin | ||||||
|  |       null; | ||||||
|  |     end INIT_DECODE_RULES5; | ||||||
|  |      | ||||||
|  |     procedure INIT_DECODE_RULES6  (po_severity        in  out         varchar2 | ||||||
|  |                                   ,po_err_code        in  out         varchar2 | ||||||
|  |                                   ,po_err_message     in  out         varchar2 -- this is a comment with (brackets) | ||||||
|  |                                   ,po_tabDecRules         out nocopy  report_utl_pck.tTabDecRules | ||||||
|  |                                   ) | ||||||
|  |     as | ||||||
|  |     begin | ||||||
|  |       null; | ||||||
|  |     end INIT_DECODE_RULES6; | ||||||
|  | 
 | ||||||
|  | end CheckFunctionList_pck; | ||||||
|  | / | ||||||
|  | 
 | ||||||
| @ -0,0 +1 @@ | |||||||
|  | {"leaves":["ctrlData(\r\n  po_severity        in out nocopy varchar2,\r\n  po_err_code        in out nocopy varchar2,\r\n  po_err_message     in out nocopy varchar2,\r\n  p_Data             in     ind_work_data_r\r\n) return boolean","INIT_DECODE_RULES1  (po_severity        in  out         varchar2\r\n                                  ,po_err_code        in  out         varchar2\r\n                                  ,po_err_message     in  out         varchar2\r\n                                  ,po_tabDecRules         out nocopy  report_utl_pck.tTabDecRules\r\n                                  )","INIT_DECODE_RULES2  (po_severity        in  out         varchar2\r\n                                  ,po_err_code        in  out         varchar2\r\n                                  ,po_err_message     in  out         varchar2\r\n                                  ,po_tabDecRules         out nocopy  report_utl_pck.tTabDecRules)","GetEsecId\r\nreturn tab1.esec_id%type","pippo","INIT_DECODE_RULES3  (po_severity        in  out         varchar2\r\n                                  ,po_err_code        in  out         varchar2\r\n                                  ,po_err_message     in  out         varchar2\r\n                                  ,po_guid            in              guid_list_t := guid_list_t()","INIT_DECODE_RULES4  (po_severity        in  out         varchar2\r\n                                  ,po_err_code        in  out         varchar2\r\n                                  ,po_err_message     in  out         varchar2\r\n                                  ,po_guid            in              guid_list_t := guid_list_t()","INIT_DECODE_RULES5  (po_severity        in  out         varchar2\r\n                                  ,po_err_code        in  out         varchar2\r\n                                  ,po_err_message     in  out         varchar2 -- this is a comment with (brackets)","INIT_DECODE_RULES6  (po_severity        in  out         varchar2\r\n                                  ,po_err_code        in  out         varchar2\r\n                                  ,po_err_message     in  out         varchar2 -- this is a comment with (brackets)","ctrlData(\r\n  po_severity        in out nocopy varchar2,\r\n  po_err_code        in out nocopy varchar2,\r\n  po_err_message     in out nocopy varchar2,\r\n  p_Data             in     ind_work_data_r\r\n) return boolean\r\nis\r\nbegin\r\n  return null","INIT_DECODE_RULES1  (po_severity        in  out         varchar2\r\n                                  ,po_err_code        in  out         varchar2\r\n                                  ,po_err_message     in  out         varchar2\r\n                                  ,po_tabDecRules         out nocopy  report_utl_pck.tTabDecRules\r\n                                  )","INIT_DECODE_RULES2  (po_severity        in  out         varchar2\r\n                                  ,po_err_code        in  out         varchar2\r\n                                  ,po_err_message     in  out         varchar2\r\n                                  ,po_tabDecRules         out nocopy  report_utl_pck.tTabDecRules)","GetEsecId\r\nreturn tab1.esec_id%type\r\nis\r\nbegin\r\n  return null","pippo","INIT_DECODE_RULES3  (po_severity        in  out         varchar2\r\n                                  ,po_err_code        in  out         varchar2\r\n                                  ,po_err_message     in  out         varchar2\r\n                                  ,po_guid            in              guid_list_t := guid_list_t()","INIT_DECODE_RULES4  (po_severity        in  out         varchar2\r\n                                  ,po_err_code        in  out         varchar2\r\n                                  ,po_err_message     in  out         varchar2\r\n                                  ,po_guid            in              guid_list_t := guid_list_t()","INIT_DECODE_RULES5  (po_severity        in  out         varchar2\r\n                                  ,po_err_code        in  out         varchar2\r\n                                  ,po_err_message     in  out         varchar2 -- this is a comment with (brackets)","INIT_DECODE_RULES6  (po_severity        in  out         varchar2\r\n                                  ,po_err_code        in  out         varchar2\r\n                                  ,po_err_message     in  out         varchar2 -- this is a comment with (brackets)"],"root":"unitTest"} | ||||||
							
								
								
									
										73
									
								
								PowerEditor/Test/FunctionList/sql/unitTest
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										73
									
								
								PowerEditor/Test/FunctionList/sql/unitTest
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,73 @@ | |||||||
|  | CREATE OR REPLACE PACKAGE BODY emp_mgmt AS  | ||||||
|  |    tot_emps NUMBER;  | ||||||
|  |    tot_depts NUMBER;  | ||||||
|  | FUNCTION hire  | ||||||
|  |    (last_name VARCHAR2, job_id VARCHAR2,  | ||||||
|  |     manager_id NUMBER, salary NUMBER,  | ||||||
|  |     commission_pct NUMBER, department_id NUMBER)  | ||||||
|  |    RETURN NUMBER IS new_empno NUMBER;  | ||||||
|  | BEGIN  | ||||||
|  |    SELECT employees_seq.NEXTVAL  | ||||||
|  |       INTO new_empno  | ||||||
|  |       FROM DUAL;  | ||||||
|  |    INSERT INTO employees  | ||||||
|  |       VALUES (new_empno, 'First', 'Last','first.last@oracle.com',  | ||||||
|  |               '(123)123-1234','18-JUN-02','IT_PROG',90000000,00,  | ||||||
|  |               100,110);  | ||||||
|  |       tot_emps := tot_emps + 1;  | ||||||
|  |    RETURN(new_empno);  | ||||||
|  | END;  | ||||||
|  | FUNCTION create_dept(department_id NUMBER, location_id NUMBER)  | ||||||
|  |    RETURN NUMBER IS  | ||||||
|  |       new_deptno NUMBER;  | ||||||
|  |    BEGIN  | ||||||
|  |       SELECT departments_seq.NEXTVAL  | ||||||
|  |          INTO new_deptno  | ||||||
|  |          FROM dual;  | ||||||
|  |       INSERT INTO departments  | ||||||
|  |          VALUES (new_deptno, 'department name', 100, 1700);  | ||||||
|  |       tot_depts := tot_depts + 1;  | ||||||
|  |       RETURN(new_deptno);  | ||||||
|  |    END;  | ||||||
|  | PROCEDURE remove_emp (employee_id NUMBER) IS  | ||||||
|  |    BEGIN  | ||||||
|  |       DELETE FROM employees  | ||||||
|  |       WHERE employees.employee_id = remove_emp.employee_id;  | ||||||
|  |       tot_emps := tot_emps - 1;  | ||||||
|  |    END;  | ||||||
|  | PROCEDURE remove_dept(department_id NUMBER) IS  | ||||||
|  |    BEGIN  | ||||||
|  |       DELETE FROM departments  | ||||||
|  |       WHERE departments.department_id = remove_dept.department_id;  | ||||||
|  |       tot_depts := tot_depts - 1;  | ||||||
|  |       SELECT COUNT(*) INTO tot_emps FROM employees;  | ||||||
|  |    END;  | ||||||
|  | PROCEDURE increase_sal(employee_id NUMBER, salary_incr NUMBER) IS  | ||||||
|  |    curr_sal NUMBER;  | ||||||
|  |    BEGIN  | ||||||
|  |       SELECT salary INTO curr_sal FROM employees  | ||||||
|  |       WHERE employees.employee_id = increase_sal.employee_id;  | ||||||
|  |       IF curr_sal IS NULL  | ||||||
|  |          THEN RAISE no_sal;  | ||||||
|  |       ELSE  | ||||||
|  |          UPDATE employees  | ||||||
|  |          SET salary = salary + salary_incr  | ||||||
|  |          WHERE employee_id = employee_id;  | ||||||
|  |       END IF;  | ||||||
|  |    END;  | ||||||
|  | PROCEDURE increase_comm(employee_id NUMBER, comm_incr NUMBER) IS  | ||||||
|  |    curr_comm NUMBER;  | ||||||
|  |    BEGIN  | ||||||
|  |       SELECT commission_pct  | ||||||
|  |       INTO curr_comm  | ||||||
|  |       FROM employees  | ||||||
|  |       WHERE employees.employee_id = increase_comm.employee_id;  | ||||||
|  |       IF curr_comm IS NULL  | ||||||
|  |          THEN RAISE no_comm;  | ||||||
|  |       ELSE  | ||||||
|  |          UPDATE employees  | ||||||
|  |          SET commission_pct = commission_pct + comm_incr;  | ||||||
|  |       END IF;  | ||||||
|  |    END;  | ||||||
|  | END emp_mgmt;  | ||||||
|  | /  | ||||||
| @ -0,0 +1 @@ | |||||||
|  | {"leaves":["hire \r\n   (last_name VARCHAR2, job_id VARCHAR2, \r\n    manager_id NUMBER, salary NUMBER, \r\n    commission_pct NUMBER, department_id NUMBER) \r\n   RETURN NUMBER IS new_empno NUMBER","create_dept(department_id NUMBER, location_id NUMBER) \r\n   RETURN NUMBER IS \r\n      new_deptno NUMBER","remove_emp (employee_id NUMBER)","remove_dept(department_id NUMBER)","increase_sal(employee_id NUMBER, salary_incr NUMBER)","increase_comm(employee_id NUMBER, comm_incr NUMBER)"],"root":"unitTest"} | ||||||
| @ -32,6 +32,11 @@ Try { | |||||||
| 		$expectedRes = Get-Content $testRoot$dirName\unitTest.expected.result | 		$expectedRes = Get-Content $testRoot$dirName\unitTest.expected.result | ||||||
| 		$generatedRes = Get-Content $testRoot$dirName\unitTest.result.json | 		$generatedRes = Get-Content $testRoot$dirName\unitTest.result.json | ||||||
| 		 | 		 | ||||||
|  | 		# Some parser results contain CRLF or LF (\r\n or \n) dependent of file EOL format | ||||||
|  | 		# In order to make tests pass in any environment, all the CRLF turning into LF (if any) in both strings  | ||||||
|  | 		$expectedRes = $expectedRes.replace('\r\n','\n') | ||||||
|  | 		$generatedRes = $generatedRes.replace('\r\n','\n') | ||||||
|  | 		 | ||||||
| 		if ($generatedRes -eq $expectedRes) | 		if ($generatedRes -eq $expectedRes) | ||||||
| 		{ | 		{ | ||||||
| 		   Remove-Item $testRoot$dirName\unitTest.result.json | 		   Remove-Item $testRoot$dirName\unitTest.result.json | ||||||
| @ -39,6 +44,9 @@ Try { | |||||||
| 		} | 		} | ||||||
| 		else | 		else | ||||||
| 		{ | 		{ | ||||||
|  | 			$expectedRes | ||||||
|  | 			"`nvs`n" | ||||||
|  | 			$generatedRes | ||||||
| 			return -1 | 			return -1 | ||||||
| 		}	 | 		}	 | ||||||
| 	} | 	} | ||||||
|  | |||||||
| @ -14,7 +14,7 @@ | |||||||
| 				mainExpr="^[ \t]*((PROCEDURE)|(FUNCTION))[\s]+[A-Za-z][\w_]*([\s]*(?'open'\().*?(\)))?(([\s]*;)|([\s]*([ia]s)\s)|([\s]+(RETURN)([\s]+[\w%\.]+)+(([\s]*;)|([\s]+([ia]s)\s))))" | 				mainExpr="^[ \t]*((PROCEDURE)|(FUNCTION))[\s]+[A-Za-z][\w_]*([\s]*(?'open'\().*?(\)))?(([\s]*;)|([\s]*([ia]s)\s)|([\s]+(RETURN)([\s]+[\w%\.]+)+(([\s]*;)|([\s]+([ia]s)\s))))" | ||||||
| 				displayMode="$className->$functionName" | 				displayMode="$className->$functionName" | ||||||
| 			> | 			> | ||||||
|         <functionName> | 			<functionName> | ||||||
| 					<nameExpr expr="[\s]+[A-Za-z][\w_]*([\s]*(?'open'\().*?(\)))?(([\s]*;)|([\s]*([ia]s)\s)|([\s]+(RETURN)([\s]+[\w%\.]+)+(([\s]*;)|([\s]+([ia]s)\s))))"/> | 					<nameExpr expr="[\s]+[A-Za-z][\w_]*([\s]*(?'open'\().*?(\)))?(([\s]*;)|([\s]*([ia]s)\s)|([\s]+(RETURN)([\s]+[\w%\.]+)+(([\s]*;)|([\s]+([ia]s)\s))))"/> | ||||||
| 					<nameExpr expr="[A-Za-z][\w_]*([\s]*(?'open'\().*?(\)))?(([\s]*;)|([\s]*([ia]s)\s)|([\s]+(RETURN)([\s]+[\w%\.]+)+(([\s]*;)|([\s]+([ia]s)\s))))"/> | 					<nameExpr expr="[A-Za-z][\w_]*([\s]*(?'open'\().*?(\)))?(([\s]*;)|([\s]*([ia]s)\s)|([\s]+(RETURN)([\s]+[\w%\.]+)+(([\s]*;)|([\s]+([ia]s)\s))))"/> | ||||||
| 					<nameExpr expr="[A-Za-z][\w_]*([\s]*\([^\)]*\))?(([\s]+(RETURN)([\s]+[\w%\.]+)+))*"/> | 					<nameExpr expr="[A-Za-z][\w_]*([\s]*\([^\)]*\))?(([\s]+(RETURN)([\s]+[\w%\.]+)+))*"/> | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user