Bài giảng Kỹ Thuật lập trình - Chương 6: Testing - Vũ Đức Vượng

Summary External testing taxonomy Boundary testing Statement testing Path testing Stress testing Internal testing techniques Checking invariants Verifying conservation properties Checking function return values Changing code temporarily Leaving testing code intact General testing strategies Testing incrementally Regression testing Scaffolds and stubs Automation Comparing independent implementations Bug-driven testing Fault injection Test the code, the tests – and the specification! Kiểm chứng code, kiểm chứng việc kiểm chứng – và kiểm chứng cả đặc tả !

ppt52 trang | Chia sẻ: hachi492 | Ngày: 07/01/2022 | Lượt xem: 241 | Lượt tải: 0download
Bạn đang xem trước 20 trang tài liệu Bài giảng Kỹ Thuật lập trình - Chương 6: Testing - Vũ Đức Vượng, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
Testing 1 Mục đích Giúp hiểu về : Internal testing External testing General testing strategies Vì sao ? Khó có thể khẳng định 1 CT lớn có làm việc chuẩn hay không Khi XD 1 CT lớn , 1 LTV chuyên nghiệp sẽ dành thời gian cho việc viết test code không ít hơn tg dành cho viết bản thân CT LTV chuyên nghiệp là người có khả năng , kiến thức rộng về các kỹ thuật và chiến lược testing 2 Testing and debugging Testing & debugging đi cùng với nhau như 1 cặp : Testing tìm errors; debugging định vị và sửa chúng . Ta có mô hình “testing/debugging cycle”: Ta test, rồi debug, rồi lặp lại . Bất kỳ 1 debugging nào nên được tiếp theo là 1 sự áp dụng lại của hàng loạt các tests liên quan , đặc biệt là các bài tests hồi quy . Điều này giúp tránh nảy sinh các lỗi mới khi debugging. Testing & debugging không nên được thực hiện bởi cùng 1 người ( thường là không nên ). 3 Khái niệm Testing Beizer : Việc thực hiện test là để chứng minh tính đúng đắn giữa 1 phần tử và các đặc tả của nó . Myers: Là quá trình thực hiện 1 CT với mục đích tìm ra những lỗi . IEEE: Là quá trình kiểm tra hay đánh giá 1 hệ thống hay 1 thành phần hệ thống một cách thủ công hay tự động để kiểm chứng rằng nó thỏa mãn những yêu cầu đặc thù hoặc để xác định sự khác biệt giữa kết quả mong đợi và kết quả thực tế 4 Program Verification Lý tưởng : Chứng minh được rằng CT của ta là chính xác , đúng đắn Có thể chứng minh các thuộc tính của CT? Có thể CM điều đó kể cả khi CT kết thúc ?!!! Program Checker program.c Right/Wrong Specification ? 5 Program Testing Thực dụng : Thuyết phục bản thân rằng CT có thể làm việc Testing Strategy program.c Probably Right/Wrong Specification 6 External vs. Internal Testing Các loại testing External testing Thiết kế dữ liệu để test program Internal testing Thiết kế program để CT tự test itself 7 External Testing External testing: TK dữ liệu để test CT External testing taxonomy (1) Kiểm chứng giá trị biên : Boundary testing (2) Kiểm chứng lệnh : Statement testing (3) Kiểm chứng có hệ thống : Path testing (4) Stress testing 8 Boundary Testing (1) Boundary testing “ Là kỹ thuật kiểm chứng sử dụng các giá trị nhập vào ở trên hoặc dưới một miền giới hạn của 1 đầu vào và với các giá trị đầu vào tạo ra các đầu ra ở biên của 1 đầu ra .” ‒ Glossary of Computerized System and Software Development Terminology Còn gọi là kiểm tra điều kiện biên - corner case testing Hầu hết các lỗi đều xảy ra ở các điều kiện biên - boundary conditions Nếu CT làm việc ở đk biên , nó sẽ làm việc đúng với các đk khác 9 Boundary Testing Example VD : đọc 1 dòng từ stdin và đưa vào mảng ký tự Boundary conditions Dòng rỗng -Input starts with '\n' In ra empty string (“\0”) => in ra “||” , ok Nếu gặp EOF - End of file trước '\n‘ Tiếp tục gọi getchar () và lưu ӱ vào s[i ] Nếu gặp ngay EOF (empty file) Tiếp tục gọi getchar () và lưu ӱ vào s[i ] int i; char s[MAXLINE ]; for (i=0; ( s[i ]= getchar ()) != '\n' && i < MAXLINE-1; i++) ; s[i ] = '\0'; printf("String : |% s|\n ", s); 10 Boundary Testing Example (cont.) Boundary conditions ( tt ) Dòng chứa đúng MAXLINE-1 ký tự In ra đúng , với ‘\0’ tại s[MAXLINE-1] Dòng chứa đúng MAXLINE ký tự Ký tự cuối cùng bị ghi đè , và dòng mới không bao giờ đc đọc Dòng dài hơn MAXLINE ký tự 1 số ký tự , kể cả newline , không đc đọc và sót lại trong stdin int i; char s[MAXLINE ]; for (i=0; ( s[i ]= getchar ()) != '\n' && i < MAXLINE-1; i++) ; s[i ] = '\0'; printf("String : |% s|\n ", s); 11 Boundary Testing Example (cont.) Rewrite the code Another boundary condition: EOF What are other boundary conditions? Nearly full Exactly full Over full int i; char s[MAXLINE ]; for (i=0; i<MAXLINE-1; i++) if (( s[i ] = getchar ()) == '\n') break; s[i ] = '\0'; for (i=0; i<MAXLINE-1; i++) if (( s[i ] = getchar ()) == '\n' || s[i ] == EOF) break; s[i ] = '\0'; This is wrong. Why? 12 Boundary Testing Example (cont.) Rewrite yet again Output: There’s still a problem... Input: Four score and seven years Four Ø score an Ø seven Ø years Ø Where’s the ‘d’? for (i=0; ; i++) { int c = getchar (); if (c==EOF || c=='\n' || i==MAXLINE-1) { s[i ] = '\0'; break; } else s[i ] = c; } 13 Ambiguity in Specification Nếu dòng quá dài , xử lý thế nào ? Giữ MAXLINE ký tự đầu , bỏ qua phần còn lại ? Giữ MAXLINE ký tự đầu + ‘\0’, bỏ qua phần còn lại ? Giữ MAXLINE ký tự đầu+’\0’, lưu phần còn lại cho lần gọi sau của input function? Có thể phần đặc tả - specification không hề đề cập khi MAXLINE bị quá Có thể người ta không muốn dòng dài quá giới hạn trong mọi trường hợp Đạo đức : kiểm tra đã phát hiện ra một vấn đề thiết kế , thậm chí có thể là một vấn đề đặc điểm kỹ thuật ! Quyết định phải làm gì Cắt những dòng quá dài ? Lưu phần còn lại để đọc như 1 dòng mới ? 14 Vấn đề đạo đức Phức tạp , các trường hợp ranh giới lộn xộn thường là triệu chứng của việc thiết kế tồi hay mô tả đặc điểm kỹ thuật tồi Xóa bỏ đặc tả nếu bạn có thể Nếu không thể sửa specification, thì hãy sửa code 15 Kiểm tra đk trước và đk sau Xác định những thuộc tính cần đi trước ( đk trước ) và sau ( đk sau ) mã nguồn đc thi hành Ví dụ : các giá trị đầu vào phải thuộc 1 phạm vi cho trước double avg ( double a[], int n) { int i; double sum=0.0; for ( i = 0; i<n; i++) sum+= a[i ]; return sum/n; } Nếu n=0 ?, nếu n<0 ? Có thể thay : return n <=0 ? 0.0: sum/n; Tháng 11/1998, chiến hạm Yorktown bị chìm : nhập vào giá trị 0, Ct không kiểm tra dl nhập dẫn đến chia cho 0, và lỗi làm tầu rối loạn , hệ thống đẩy ngưng hoạt động , tàu chìm !!! 16 Statement Testing (2) Statement testing “Testing để thỏa mãn điều kiện rằng mỗi statement trong 1 CT phải thực hiện ít nhất trong khi testing.” ‒ Glossary of Computerized System and Software Development Terminology 17 Statement Testing Example Example pseudocode : Đòi hỏi 2 tập dữ liệu;vd : condition1 là đúng và condition2 là đúng Thực hiện statement1 và statement3 condition1 là sai và condition2 là sai Thực hiện statement2 và statement4 if ( condition1 ) statement1 ; else statement2 ; if ( condition2 ) statement3 ; else statement4 ; Statement testing: Phải chắc chắn cả lệnh “if” và 4 lệnh lồng phải đc thực hiện 18 Path Testing (3) Path testing “ Kiểm tra để đáp ứng các tiêu chuẩn đảm bảo rằng mỗi đường dẫn logic xuyên suốt chương trình được kiểm tra . Thường thì đường dẫn xuyên suốt chương trình này được nhóm thành một tập hữu hạn các lớp . Một đường dẫn từ mỗi lớp sau đó được kiểm tra . " ‒ Glossary of Computerized System and Software Development Terminology Khó hơn nhiều so với statement testing Với các CT đơn giản , có thể liệt kê các nhánh đường dẫn xuyên suốt code Ngược lại , bằng các đầu vào ngẫu nhiên tạo các đường dẫn theo ct 19 Path Testing Example Example pseudocode : Đòi hỏi 4 tập dữ liệu : condition1 là true và condition2 là true condition1 là true và condition2 là false condition1 là false và condition2 là true condition1 là false và condition2 la false Chương trình thực tế => bùng nổ các tổ hợp !!! if ( condition1 ) statement1 ; else statement2 ; if ( condition2 ) statement3 ; else statement4 ; Path testing: Cần đảm bảo tất cả các đường dẫn được thực hiện 20 Consider an example (1) input(A,B ) if (A>0) then (2) Z := A else (3) Z := 0 end_if_else if (B>0) then (4) Z := Z+B end_if (5) output(Z ) What is the path condition for path ? A>0 F 2 3 1 4 5 B>0 T F T (A>0) Л (B 0) 21 Consider ANOTHER example (1) input(A,B ) if (A>B) then (2) B := B*B end_if if (B<0) then (3) Z := A else (4) Z := B end_if_else (5) output(Z ) What is the path condition for path ? (A>B) Л (B <0) A>B F 2 4 1 3 5 T F T B<0 22 Consider ANOTHER example (1) input(A,B ) if (A>B) then (2) B := B*B end_if if (B<0) then (3) Z := A else (4) Z := B end_if_else (5) output(Z ) What is the path condition for path ? (A>B) Л (B <0) (B 2 <0) = FALSE A>B F 2 4 1 3 5 T F T T B<0 23 Stress Testing (4) Stress testing “ Tiến hành thử nghiệm để đánh giá một hệ thống hay thành phần tại hoặc vượt quá các giới hạn của các yêu cầu cụ thể của nó ” ‒ Glossary of Computerized System and Software Development Terminology Phải tạo : Một tập lớn đầu vào - Very large inputs Các đầu vào ngẫu nhiên - Random inputs (binary vs. ASCII) Nên dùng máy tính để tạo đầu vào 24 Stress Testing Example 1 Example program: Mục tiêu : Copy tất cả các ký tự từ stdin vào stdout ; nhưng lưu ý bug!!! Làm việc với tập dữ liệu ASCII chuẩn ( tự tạo ) Máy tính tự tạo ngẫu nhiên tập dữ liệu dạng 255 (decimal), hay 11111111 (binary), và EOF để dừng vòng lặp #include int main(void ) { char c; while ((c = getchar ()) != EOF) putchar(c ); return 0; } Stress testing: Phải cung cấp random (binary and ASCII) inputs 25 Stress Testing Example 2 Example program: Mục tiêu : Đếm và in số các kỹ tự trong stdin Làm việc với tập dữ lieuj có kích thước phù hợp Sẽ có lỗi với tập dữ liệu do máy tạo chứa hơn 32767 characters #include int main(void ) { short charCount = 0; while ( getchar () != EOF) charCount ++; printf("%hd\n ", charCount ); return 0; } Stress testing: Phải cung cấp very large inputs 26 Uses of assert Typical uses of assert Validate formal parameters Check for “impossible” logical flow Make sure dynamic memory allocation requests worked assert(ptr != NULL); size_t Str_getLength(const char * str ) { assert(str != NULL); } switch (state) { case START: break; case COMMENT: break; default: assert(0); /* Never should get here */ } 27 Internal Testing Internal testing: Thiết kế CT để CT tự test itself Internal testing techniques (1) Kiểm tra bất biến - Testing invariants (2) Kiểm tra các thuộc tính lưu trữ -Verifying conservation properties (3) Kiểm tra các giá trị trả về -Checking function return values (4) Tạm thay đổi code -Changing code temporarily (5) Giữ nguyên mã thử nghiệm -Leaving testing code intact 28 Testing Invariants (1) Testing invariants Thử nghiệm các đk trước và sau Vài khía cạnh của cấu trức dữ liệu không đc thay đổi 1 hàm tác động đến cấu trúc dữ liệu phải kiểm tra các bất biến ở đầu và cuối nó Ví dụ : Hàm “doubly-linked list insertion” Kiểm tra ở đầu và cuối Xoay doubly-linked list Khi node x trỏ ngược lại node y, thì liệu node y có trỏ ngược lại node x? Example: “binary search tree insertion” function Kiểm tra ở đầu và cuối Xoay tree Các nodes có còn đc sắp xếp không ? 29 Testing Invariants (cont.) Tiện cho việc dùng assert để test invariants # ifndef NDEBUG int isValid (MyType object) { Test invariants here. Return 1 (TRUE) if object passes all tests, and 0 (FALSE) otherwise. } # endif void myFunction(MyType object) { assert(isValid(object )); Manipulate object here. assert(isValid(object )); } Có thể dùng NDEBUG trong code, giống như assert 30 Kiểm tra các thuộc tính lưu trữ Khái quát hóa của testing invariants 1 hàm cần kiểm tra các cấu trúc dữ liệu bị tác động tại các điểm đầu và cuối VD: hàm Str_concat () Tại điểm đầu , tìm độ dài của 2 xâu đã cho ; tính tổng Tại điểm cuối , tìm độ dài của xâu kết quả 2 độ dài có bằng nhau không ? VD: Hàm chèn thêm PT vào danh sách -List insertion function Tại điểm khởi đầu , tính độ dài ds Tại điểm cuối , Tính độ dài mới Độ dài mới = độ dài cũ + 1? 31 Kiểm tra GT trả về Checking Return Values Trong Java và C++: Phương thức bị phát hiện có lỗi có thể tung ra một “checked exception” Phương thưc triệu gọi phải xử lý ngoại lệ Trong C: Không có cơ chế xử lý exception Hàm phát hiện có lỗi chủ yếu thông qua giá trị trả về Người LT thường dễ dàng quên kiểm tra GT trả về Nói chung là chúng ta nên kiểm tra GT trả về 32 Checking Return Values (cont.) VD: scanf () trả về số của các giá trị đc đọc VD: printf () có thể bị lỗi nếu ghi ra file và đĩa bị đầy ; Hàm này trả về số ký tự được ghi ( không phải giá trị ) int i; if ( scanf("%d ", &i) != 1) /* Error */ int i = 100; if ( printf("%d ", i) != 3) /* Error */ int i; scanf("%d ", &i); Bad code Good code int i = 100; printf("%d ", i); Bad code??? Good code, or overkill??? 33 Tạm thay đổi code Tạm thay đổi code để tạo ranh giới nhân tạo hoặc stress tests VD: CT sắp xếp trên mảng Tạm đặt kích thước mảng nhỏ CT có xử lý tràn số hay không ? Viết 1 phiên bản hàm cấp phát bộ nhớ và phát hiện ra lỗi sớm , để kiểm chứng đoạn mã nguồn bị lỗi thiếu bộ nhớ : void * testmalloc ( size_t n) { static int count =0; if (++count . 10) return NULL; else return malloc(n ); } 34 Để nguyên đoạn code kiểm tra Hãy để nguyên trạng các đoạn kiểm tra trên code Có thể khoanh lại = # ifndef NDEBUG # endif Kiểm tra với tùy chọn –DNDEBUG gcc Bặt/Tắt assert macro Cũng có thể Bật/tắt debugging code Cẩn trọng với mâu thuẫn - conflict: Mở rộng thử nghiệm nội bộ có thể giảm chi phí bảo trì Code rõ ràng có thể giảm chi phí bảo trì Nhưng ... Mở rộng thử nghiệm nội bộ có thể làm giảm độ rõ ràng của Code ! 35 Các chiến lược testing General testing strategies (1) Kiểm chứng tăng dần -Testing incrementally (2) So sanh các cài đặt -Comparing implementations (3) Kiểm chứng tự động - Automation (4) Bug-driven testing (5) Tiêm , gài lỗi - Fault injection 36 Testing Incrementally (1) Testing incrementally Test khi viết code Thêm tests khi tạo 1 lựa chọn mới - new cases Test phần đơn giản trước phần phức tạp Test units ( tức là từng module riêng lẻ ) trước khi testing toàn hệ thống Thực hiện regression testing – kiểm thử hồi quy Xử lý đc 1 lỗi thường tạo ra những lỗi mới trong 1 he thống lớn , vì vậy Phải đảm bảo chắc chắn hệ thống không “ thoái lui ” kiểu như chức năng trước kia đang làm việc giờ bị broken, nên Test mọi khả năng để so sanh phiên bản mới với phiên bản cũ 37 Testing Incrementally (cont.) (1) Testing incrementally (cont.) Tạo “ giàn giáo ” - scaffolds và “ mẫu ” - stubs để test đoạn code mà ta quan tâm Đoạn code cần quan tâm Hàm được gọi bởi đoạn code cần quan tâm Hàm được gọi bởi đoạn code cần quan tâm Hàm gọi đến code mà ta quan tâm Scaffold : Đoạn code tạm thời gọi đến code Mà ta quan tâm Stub : Đoạn code Tạm thời được gọi Bởi đoạn code cần Quan tâm 38 So sánh các cài đặt (2) Compare implementations Hãy chắc chắn rằng các triển khai độc lập hành xử như nhau Example: So sánh hành vi của CT mà bạn dịch ( TB C++3.0 ) với GCC Example: So sánh hành vi của các hàm bạn tạo trong str.h với các hàm trong thư viện string.h Đôi khi 1 kq có thể đc tính = 2 cách khác nhau , 1 bài toán có thể giải = 2 phương pháp , thuật toán # nhau . Ta có thể xd cả 2 CT, nếu chúng có cùng KQ thì có thể khẳng định cả 2 cùng đúng , còn kq khách nhau thì ít nhất 1 trong 2 ct bị sai 39 Kiểm chứng tự động - Automation (3) Automation Testing thủ công rất nặng nhọc và tốn kém và nhàm chán thậm chí không đủ đọ tin cậy . Ba quá trình kiểm chúng bao gồm : Thực hiện kiểm chứng nhiều lần Dùng nhiều bộ dữ liệu nhập Nhiều lần so sánh dữ liệu xuất vì vậy cần kiểm chứng = chương trình để : tránh mệt mỏi , giảm sự bất cẩn Tạo testing code Viết 1 bộ kiểm chứng để kiểm tra toàn bộ chương trình mỗi khi có sự thay đổi , sau khi biên dịch thành công Cần biết cái gì được chờ đợi Tạo ra các đầu ra , sao cho dễ dàng nhận biết là đúng hay sai Tự động kiểm chứng có thể cung cấp : Tốt hơn nhiều so với kiểm chứng thủ công 40 Tự động hóa kiểm chứng lùi Tuần tự kiểm chứng so sánh các phiên bản mới với những phiên bản cũ tương ứng . Mục đích : đảm bảo việc sửa lỗi sẽ không làm ảnh hưởng nhưng phần khác trừ khi chúng ta muốn 1 số hệ thống có công cụ trợ giúp kiểm chứng tự động : Ngôn ngữ scripts : cho phép viết các đoạn script để test tuần tự Unix : có các thao tác trên tệp tin như cmp và diff để so sanh dữ liệu xuất , sort sắp xếp các phần tử , grep để kiểm chứng dữ liệu xuất , ưc , sum va freq để ttong kết dữ liệu xuất Khi kiểm chứng lùi , cần đảm bảo phiên bản cũ là đúng , nếu sai thì rất khó xác định và kết quả sẽ không chính xác Cần phải kiểm tra chính việc kiểm chứng lùi 1 cách định kỳ để đảm bảo nó vẫn hợp lệ 41 Tạo ra những kiểm chứng độc lập Kiểm chứng độc lập với các giá trị nhập và giá trị xuất mong đợi sẽ bổ xung cho kiểm chứng lùi Ví dụ : dùng ngôn ngữ NewAwk thực hiện kiểm chứng 1 ct ngắn , dữ liệu xuất đc ghi vào 1 tệp tin, kq đúng đc ghi vào 1 tệp khác rồi so sánh 2 tệp , nếu khác nhau thì tbaos lỗi echo 3 5 | newawk ‘{i=1; print ($ si )++; print $i ,i}’ > out1 echo ‘3 4 1’ > out2 # két quả đúng if ! Cmp –s out1 out2 # nếu kq so sánh khác nhau then echo ‘BAD: test failed’ Fi Mọt lỗi có thể cần nhiều thao tác kiểm chứng hoặc phải kiểm tra toàn bộ các lợp mới , hoặc có thể thêm vào những đoạn Ct bảo vệ để có thể bắt đc những lỗi trong CT 42 Bug-Driven Testing (4) Kiểm chứng hướng lỗi : Bug-driven testing Tìm thấy 1 bug => Ngay lập tức tạo 1 test để bắt lỗi Đơn giản hóa việc kiểm chứng lùi (5) Fault injection Chủ động ( tạm thời ) cài các bugs!!! Rồi quyết định nếu tìm thấy chúng Kiểm chứng bản thân kiểm chứng !!! 43 Ai test cái gì - Who Tests What Programmers White-box testing Pro: Người triển khai nắm rõ mọi luồng dữ liệu Con: Bị ảnh hưởng bởi cách thức code đc thiết kê/viết Quality Assurance (QA) engineers Black-box testing Pro: Không có khái niệm về implementation Con: Không muốn test mọi logical paths Customers Field testing Pros: Có các cách sử dụng CT bất ngờ;dễ gây lỗi Cons: Không đủ trường hợp ; khách hàng không thích tham gia vào quá trình test ; 44 Testing Techniques Black-Box: Testing chỉ dựa trên việc phân tích các yêu cầu - requirements (unit/component specification, user documentation, v.v.). Còn được gọi là functional testing. White-Box: Testing dựa trên việc phân tích các logic bên trong - internal logic (design, code, v.v.). ( Nhưng kết quả mong đợi vẫn đến từ requirements.) Còn đc gọi là structural testing. 45 Levels or Phases of Testing Unit: testing các mẫu công việc nhỏ nhất của LTV để có thể lập kế hoạch và theo dõi hợp lý ( vd : function, procedure, module, object class, .) Component: testing 1 tập hợp các units tạo thành 1 thành phần ( vd : program, package, task, interacting object classes, ) Product: testing các thành phần tạo thành 1 sản phẩm ( subsystem, application, ) System: testing toàn bộ hệ thống Testing thường : Bắt đầu = functional (black-box) tests, Rồi thêm = structural (white-box) tests, và Tiến hành từ unit level đến system level với 1 hoặc một vài bước tích hợp 46 Tại sao không "test everything"? Chi phí cho 'exhaustive' testing: 20 x 4 x 3 x 10 x 2 x 100 = 480,000 tests Nếu 1 giây cho 1 test, 8000 phút , 133 giờ , 17.7 ngày (not counting finger trouble, faults or retest) nếu 10 secs = 34 wks, 1 min = 4 yrs, 10 min = 40 yrs 47 Bao nhiêu testing là đủ ? - Không bao giờ đủ ! - Khi bạn thực hiện những test mà bạn đã lên kế hoạch - Khi khách hàng/người sử dụng thấy thỏa mãn - Khi bạn đã chứng minh đc rằng hệ thống hoạt động đúng , chính xác - Khi bạn tin tưởng rằng HT hoạt động tốt Phụ thuộc vào risks for your system Càng ít thời gian , càng nhiều để ..  Thời gian để test luôn có giới hạn  Dùng RISK để xác định : - Cái gì phải test trước - Cái gì phải test nhiều Mỗi phần tử cần test kỹ như thế nào ? Tức là đâu là trọng tâm Cái gì khong cần test ( thời điểm này ) 48 Nguyên tắc quan trọng nhất Most important principle Ưu tiên tests Để , Khi bạn kết thúc testing, Bạn đã thực hiện việc test tốt nhất trong quãng thời gian có thể . 49 The testing paradox Mục đích của testing: để tìm ra lỗi Tìm thấy lỗi làm mất ( hủy hoại ) tự tin - confidence => Mục đích của testing: hủy hoại sự tự tin Nhưng mục đích của testing: Xây dựng niềm tin, tự tin => Cách tốt nhất để xây dựng niềm tin là : Cố gắng hủy hoại nó 50 Summary External testing taxonomy Boundary testing Statement testing Path testing Stress testing Internal testing techniques Checking invariants Verifying conservation properties Checking function return values Changing code temporarily Leaving testing code intact 51 Summary (cont.) General testing strategies Testing incrementally Regression testing Scaffolds and stubs Automation Comparing independent implementations Bug-driven testing Fault injection Test the code , the tests – and the specification ! Kiểm chứng code, kiểm chứng việc kiểm chứng – và kiểm chứng cả đặc tả ! 52

Các file đính kèm theo tài liệu này:

  • pptbai_giang_ky_thuat_lap_trinh_chuong_6_testing_vu_duc_vuong.ppt