1. Trang chủ
  2. » Giáo án - Bài giảng

kiểm tra phần mềm nguyễn văn hiệp chương01 tổng quát ve kiểm thu phần mềm sinhvienzone com

11 51 0

Đang tải... (xem toàn văn)

Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống

THÔNG TIN TÀI LIỆU

Thông tin cơ bản

Định dạng
Số trang 11
Dung lượng 315,15 KB

Nội dung

Chương Tổng quát kiểm thử phần mềm 1.1 Qui trình phát triển phần mềm RUP P hases C o r e W o r k flo w s I n ce p tion Elaboration Construction Tr a n s ition Requirements om An iteration i n th e elaboration p h as e Analysis C Design ne Implementation Zo Test iter #1 iter #2 iter #n iter #n+1 iter #n+2 iter #m iter #m +1 I t e r a t io n s Vi en Preliminary Iteration(s) nh Chu kỳ phần mềm ₫ược tính từ lúc có yêu cầu (mới nâng cấp) ₫ến lúc phần mềm ₫áp ứng ₫úng yêu cầu ₫ược phân phối Si Trong chu kỳ, người ta tiến hành nhiều công ₫oạn : khởi ₫ộng, chi tiết hóa, thực chuyển giao Mỗi công ₫oạn thường ₫ược thực theo chế lặp nhiều lần ₫ể kết ngày hoàn hảo Trong bước lặp, thường thực nhiều workflows ₫ồng thời (₫ể tận dụng nguồn nhân lực hiệu nhất) : nắm bắt yêu cầu, phân tích chức năng, thiết kế, thực kiểm thử Sau lần lặp thực công việc ₫ó, ta phải tạo kết (artifacts), kết bước/công việc liệu ₫ầu SinhVienZone.com https://fb.com/sinhvienzonevn vào bước/công việc khác Nếu thông tin không tốt ảnh hưởng nghiêm trọng ₫ến kết bước/hoạt ₫ộng sau ₫ó Một số vấn ₫ề thường gặp phát triển phần mềm : tính tốn khơng ₫úng, hiệu chỉnh sai liệu ƒ trộn liệu không ₫úng ƒ Tìm kiếm liệu sai yêu cầu ƒ Xử lý sai mối quan hệ liệu ƒ Coding/hiện thực sai qui luật nghiệp vụ ƒ Hiệu suất phần mềm thấp ƒ Kết hiệu suất phần mềm không tin cậy ƒ Hỗ trợ chưa ₫ủ nhu cầu nghiệp vụ ƒ Giao tiếp với hệ thống khác chưa ₫úng hay chưa ₫ủ ƒ Kiểm soát an ninh phần mềm chưa ₫ủ en Zo ne C om ƒ 1.2 Vài ₫ịnh nghĩa kiểm thử phần mềm Kiểm thử phần mềm qui trình chứng minh phần mềm khơng có lỗi ƒ Mục ₫ích kiểm thử phần mềm phần mềm thực ₫úng chức mong muốn Si nh Vi ƒ ƒ Kiểm thử phần mềm qui trình thiết lập tin tưởng việc phần mềm hay hệ thống thực ₫ược ₫iều mà hỗ trợ ƒ Kiểm thử phần mềm qui trình thi hành phần mềm với ý ₫ịnh tìm kiếm lỗi ƒ Kiểm thử phần mềm ₫ược xem qui trình cố gắng tìm kiếm lỗi phần mềm theo tinh thần "hủy diệt" Các mục tiêu kiểm thử phần mềm : SinhVienZone.com https://fb.com/sinhvienzonevn Phát nhiều lỗi tốt thời gian kiểm thử xác ₫ịnh trước ƒ Chứng minh sản phẩm phần mềm phù hợp với ₫ặc tả yêu cầu ƒ Xác thực chất lượng kiểm thử phần mềm ₫ã dùng chi phí nỗ lực tối thiểu ƒ Tạo testcase chất lượng cao, thực kiểm thử hiệu tạo báo cáo vấn ₫ề ₫úng hữu dụng om ƒ C Kiểm thử phần mềm thành phần lĩnh vực rộng hơn, ₫ó Verification & Validation (V &V), ta tạm dịch Thanh kiểm tra Kiểm ₫ịnh phần mềm Zo ne Thanh kiểm tra phần mềm qui trình xác ₫ịnh xem sản phẩm công ₫oạn qui trình phát triền phần mềm có thoả mãn yêu cầu ₫ặt công ₫oạn trước không (Ta có ₫ang xây dựng ₫úng ₫ắn sản phẩm khơng ?) Vi en Thanh kiểm tra phần mềm thường hoạt ₫ộng kỹ thuật dùng kiến thức artifacts, yêu cầu, ₫ặc tả rời rạc phần mềm nh Các hoạt ₫ộng Thanh kiểm tra phần mềm bao gồm kiểm thử (testing) xem lại (reviews) Si Kiểm ₫ịnh phần mềm qui trình ₫ánh giá phần mềm cuối chu kỳ phát triển ₫ể ₫ảm bảo lòng sử dụng khách hàng (Ta có xây dựng phần mềm ₫úng theo yêu cầu khách hàng ?) Các hoạt ₫ộng kiểm ₫ịnh ₫ược dùng ₫ể ₫ánh giá xem tính chất ₫ược thực phần mềm có thỏa mãn yêu cầu khách hàng theo dõi với yêu cầu khách hàng không ? Kiểm ₫ịnh phần mềm thường phụ thuộc vào kiến thức lĩnh vực mà phần mềm xử lý SinhVienZone.com https://fb.com/sinhvienzonevn om C ne en Zo 1.3 Kiểm thử : worker qui trình Component Engineer Integration Tester System Tester nh Vi Test Engineer Si chịu trach nhi m v ̀ Test Model chịu trach nhi m v ̀ chịu trach nhi m v ̀ Test Test Plan Test case Test Test Procedure Evaluation Component Test defect Kỹ sư kiểm thử : ƒ SinhVienZone.com người chuyên IT, chịu trách nhiệm nhiều hoạt ₫ộng kỹ thuật liên quan ₫ến kiểm thử https://fb.com/sinhvienzonevn ƒ ₫ịnh nghĩa testcase, viết ₫ặc tả thủ tục kiểm thử ƒ phân tích kết quả, báo cáo kết cho người phát triển quản lý biết ƒ Người quản lý kiểm thử : Thiết lập chiến lược qui trình kiểm thử, tương tác với người quản lý hoạt ₫ộng khác project, giúp ₫ỡ kỹ sư kiểm thử thực công việc họ Plan test Design test Evaluate test Zo ne Test Engineer C om ƒ Implement Test Si Component Engineer Perform System Test Vi nh System Tester Perform Integration Test en Integration tester Tự ₫ộng số hoạt ₫ộng kiểm thử Kiểm thử phần mềm tốn nhiều chi phí nhân công, thời gian Trong số dự án, kiểm thử phần mềm tiêu hao 50% tổng giá phát triển phần mềm Nếu cần ứng dụng an toàn hơn, chi phí kiểm thử cao Do ₫ó mục tiêu kiểm thử tự ₫ộng hóa nhiều có thể, nhờ ₫ó mà giảm thiểu chi phí nhiều, tối thiểu hóa lỗi người gây ra, ₫ặc biệt giúp việc kiểm thử hồi qui dễ dàng nhanh chóng SinhVienZone.com https://fb.com/sinhvienzonevn Tự ₫ộng hóa việc kiểm thử dùng phần mềm ₫iều khiển việc thi hành kiểm thử, so sánh kết có ₫ược với kết kỳ vọng, thiết lập ₫iều kiện ₫ầu vào, kiểm soát kiểm thử chức báo cáo kết Thí dụ tiện ích phục vụ tự ₫ộng kiểm thử : Stress Test, Selenium, TestComplete, IBM Rational Functional Tester nh Vi en Zo ne C om 1.4 Các mức ₫ộ kiểm thử phần mềm Kiểm thử ₫ơn vị (Unit Testing) : kiểm thử thực chi tiết ₫ơn vị nhỏ (hàm, class, ) có hoạt ₫ộng ₫úng không ? ƒ Kiểm thử module (Module Testing) : kiểm thử dịch vụ module có phù hợp với ₫ặc tả module ₫ó khơng ? ƒ Kiểm thử tích hợp (Integration Testing) : kiểm thử xem phân hệ phần mềm có ₫ảm bảo với ₫ặc tả thiết kế phân hệ ₫ó khơng ? ƒ Kiểm thử hệ thống (System Testing) : kiểm thử yêu cầu không chức phần mềm hiệu suất, bảo mật, làm việc môi trường căng thẳng, Si ƒ SinhVienZone.com https://fb.com/sinhvienzonevn ƒ Kiểm thử ₫ộ chấp nhận người dùng (Acceptance Testing) : kiểm tra xem người dùng có chấp thuận sử dụng phần mềm khơng ? ƒ Kiểm thử hồi qui : ₫ược làm có hiệu chỉnh, nâng cấp phần mềm với mục ₫ích xem phần mềm có ₫ảm bảo thực ₫úng chức trước hiệu chỉnh không ? om 1.5 Testcase ne C Mỗi testcase chứa thông tin cần thiết ₫ể kiểm thử thành phần phần mềm theo mục tiêu xác ₫ịnh Thường testcase gồm thông tin {tập liệu ₫ầu vào, trạng thái thành phần phầm mềm, tập kết kỳ vọng} Zo Tập liệu ₫ầu vào (Input): gồm giá trị liệu cần thiết ₫ể thành phần phầm mềm dùng xử lý en Tập kết kỳ vọng : kết mong muốn sau thành phần phần mềm xử lý liệu nhập Vi Trạng thái thành phần phần mềm : ₫ược tạo giá trị prefix postfix Si nh Tập testcase : tập hợp testcase mà ta có ý ₫ịnh dùng ₫ể kiểm thử thành phần phần mềm ₫ể minh chứng TPPM có ₫úng hành vi mong muốn Các phương pháp thiết kế testcase Bất kỳ sản phẩm kỹ thuật (phần mềm ngoại lệ) ₫ều ₫ược kiểm thử cách : ƒ Kiểm thử hộp ₫en (Black box testing) : theo góc nhìn sử dụng SinhVienZone.com Khơng cần kiến thức chi tiết thiết kế thực bên https://fb.com/sinhvienzonevn Kiểm thử hộp trắng (White box testing) : theo góc nhìn thực cần kiến thức chi tiết thiết kế thực bên Kiểm thử dựa vào phủ lệnh, phủ nhánh, phủ ₫iều kiện con, en Zo ne C om ƒ Kiểm thử dựa yêu cầu ₫ặc tả sử dụng TPPM Kiểu kiểm thử Vi Unit Testing nh Integration Testing Kỹ thuật kiểm thử ₫ược dùng White Box, Black Box Black Box, White Box Black Box System Testing Black Box Accceptance Testing Black Box Si Functional Testing 1.6 Các nguyên tắc kiểm thử Thông tin thiết yếu testcase kết hay liệu xuất kỳ vọng Nếu kết kỳ vọng testcase không ₫ược ₫ịnh nghĩa rõ ràng, người ta giải thích kết sai (plausible) thành kết ₫úng tượng “the eye seeing what it wants to see.” => test case phải chứa thành phần thiết yếu : SinhVienZone.com https://fb.com/sinhvienzonevn ƒ ₫ặc tả ₫iều kiện liệu nhập ƒ ₫ặc tả xác kết ₫úng chương trình tương ứng với liệu nhập Việc kiểm thử ₫òi hỏi tính ₫ộc lập : lập trình viên nên tránh việc kiểm thử TPPM viết Các issues tâm lý : Chương trình chứa lỗi lập trình viên hiểu sai ₫ặc tả/phát biểu vấn ₫ề ƒ Tổ chức lập trình khơng nên kiểm thử chương trình tổ chức viết ƒ Thanh tra cách xuyên suốt kết kiểm thử ne C om ƒ Zo Phải thiết kế ₫ủ test case cho trường hợp : liệu ₫ầu vào hợp lệ liệu ₫ầu vào không hợp lệ chờ ₫ợi en Xem xét chương trình xem khơng thực ₫iều mong muốn, xem có làm ₫iều khơng mong muốn ? Vi Tránh testcase "throwaway" chương trình thật "throwaway" Si nh Không nên lập kế hoạch nỗ lực kiểm thử dựa giả ₫ịnh ngầm phần mềm khơng có lỗi Xác xuất xuất nhiều lỗi section phần mềm tỉ lệ thuận với số lỗi ₫ã phát ₫ược section ₫ó SinhVienZone.com https://fb.com/sinhvienzonevn om C Kiểm thử tác vụ thách thức ₫òi hỏi sáng tạo trí ne tuệ Zo Kiểm thử phần mềm nên bắt ₫ầu từ thành phần nhỏ ₫ơn giản ₫ến thành phần ngày lớn Kiểm thử theo kiểu vét cạn Vi en Nên hoạch ₫ịnh qui trình kiểm thử trước bắt ₫ầu thực kiểm thử Ta kiểm thử phần mềm ₫ầy ₫ủ, nghĩa ₫ã vét cạn hoạt ₫ộng kiểm thử cần thiết Si ƒ nh 1.7 Các ý tưởng khơng ₫úng kiểm thử ƒ Ta tìm tất lỗi kỹ sư kiểm thử làm tốt cơng việc ƒ Tập testcase tốt phải chứa nhiều testcase ₫ể bao phủ nhiều tình ƒ Testcase tốt ln testcase có ₫ộ phức tạp cao ƒ Tự ₫ộng kiểm thử thay kỹ sư kiểm thử ₫ể kiểm thử phần mềm cách tốt ₫ẹp ƒ Kiểm thử phần mềm ₫ơn giản dễ dàng Ai làm, không cần phải qua huấn luyện SinhVienZone.com https://fb.com/sinhvienzonevn 1.8 Các hạn chế việc kiểm thử Ta ₫ặc tả phần mềm ₫ều ₫úng 100% ƒ Ta hệ thống hay tool kiểm thử ₫úng ƒ Khơng có tool kiểm thử thích hợp cho phần mềm ƒ Kỹ sư kiểm thử không họ hiểu ₫ầy ₫ủ sản phẩm phần mềm ƒ Ta khơng có ₫ủ tài nguyên ₫ể thực hiệm kiểm thử ₫ầy ₫ủ phần mềm ƒ Ta không ta ₫ạt ₫ủ 100% hoạt ₫ộng kiểm thử phần mềm ne C om ƒ Zo 1.9 Kết chương Vi en Chương ₫ã ơn lại qui trình phát triển phần mềm ₫ược dùng phổ biến nay, ₫ó qui trình RUP (Rational Unified Process), từ ₫ó giới thiệu lý cần phải kiểm thử phần mềm, thuật ngữ hoạt ₫ộng kiểm thử phần mềm Si nh Chương ₫ã giới thiệu vai trò worker qui trình kiểm thử phần mềm, mức ₫ộ kiểm thử phần mềm khác nhau, nguyên tắc kiểm thử phần mềm Chương ₫ã giới thiệu số ý tưởng không ₫úng ₫ắn kiểm thử phần mềm, hạn chế hoạt ₫ộng kiểm thử phần mềm SinhVienZone.com https://fb.com/sinhvienzonevn ... ₫ịnh nghĩa kiểm thử phần mềm Kiểm thử phần mềm qui trình chứng minh phần mềm khơng có lỗi ƒ Mục ₫ích kiểm thử phần mềm phần mềm thực ₫úng chức mong muốn Si nh Vi ƒ ƒ Kiểm thử phần mềm qui trình... phải kiểm thử phần mềm, thu t ngữ hoạt ₫ộng kiểm thử phần mềm Si nh Chương ₫ã giới thiệu vai trò worker qui trình kiểm thử phần mềm, mức ₫ộ kiểm thử phần mềm khác nhau, nguyên tắc kiểm thử phần mềm. .. hơn, ₫ó Verification & Validation (V &V), ta tạm dịch Thanh kiểm tra Kiểm ₫ịnh phần mềm Zo ne Thanh kiểm tra phần mềm qui trình xác ₫ịnh xem sản phẩm công ₫oạn qui trình phát triền phần mềm có

Ngày đăng: 30/01/2020, 22:48

TỪ KHÓA LIÊN QUAN