Kiểm thử phần mềm

GS John Vu05/06/2026 12:00
Kiểm thử phần mềm

Kiểm thử là việc thực hiện một chương trình để tìm ra khiếm khuyết.

Trường hợp kiểm thử tốt là trường hợp có xác suất cao phát hiện ra khiếm khuyết. Tuy nhiên, nghiên cứu công nghiệp thấy rằng ngay cả với trường hợp kiểm thử tốt nhất, người phát triển chỉ có thể bắt được quãng 70% khiếm khuyết và 30% kia vẫn còn sau khi phần mềm được đưa ra cho người dùng. Vì giới hạn của kiểm thử, người ta khuyến cáo rằng người phát triển loại bỏ càng nhiều khiếm khuyết nhất có thể được bằng các phương pháp khác như kiểm điểm và giám định phần mềm trước pha kiểm thử để cải tiến chất lượng của sản phẩm phần mềm.

Có nhiều lí do cho phần mềm có khiếm khuyết. Lí do thông thường nhất là yêu cầu phần mềm không được xác định tốt và thường xuyên thay đổi. Những thay đổi này làm cho người phát triển phải thay đổi điều họ đang làm và nó tạo ra khiếm khuyết. Đó là lí do tại sao Kĩ nghệ yêu cầu (RE) là kĩ năng quan trọng vì nó hội tụ vào nhận diện bất kì mơ hồ nào hay thiếu thông tin trong pha yêu cầu. Nó buộc người phát triển phải nhìn vào toàn bộ yêu cầu để xác định “Thuộc tính kiểm thử được”. Với mọi yêu cầu, người phát triển phải có khả năng viết ra trường hợp kiểm thử. Nếu họ không thể kiểm thử được nó thì hoặc yêu cầu là mơ hồ hoặc người phát triển KHÔNG hiểu yêu cầu. Trong cả hai trường hợp, thảo luận với người dùng để làm sáng tỏ yêu cầu là cần thiết. Đó là lí do tại sao kiểm thử phải được lập kế hoạch ngay sau pha yêu cầu. Tuy nhiên, thiếu kĩ năng kĩ nghệ yêu cầu, nhiều người phát triển KHÔNG lập kế hoạch kiểm thử chừng nào họ còn chưa hoàn thành viết mã. Điều này là quá trễ và đó là sai lầm lớn. Đó là lí do tại sao phần lớn phần mềm có quá nhiều khiếm khuyết và quá tốn kém.

Một sai lầm khác là chiến lược kiểm thử KHÔNG được xác định rõ. Phần lớn những người kiểm thử đều hội tụ vào chức năng kiểm thử chứ KHÔNG vào tích hợp hay bản dựng. Họ tin chừng nào họ kiểm thử xong mọi yêu cầu thì mọi thứ sẽ tốt. Họ KHÔNG được đào tạo về “tư duy hệ thống” để hiểu sự vững chãi của phần mềm bằng việc tập trung vào các phần cốt yếu của hệ thống như năng lực và hiệu năng. Nhiều lần, mọi chức năng làm việc độc lập tốt (qua kiểm thử chức năng) nhưng khi bạn gắn chúng lại với nhau, hệ thống KHÔNG làm việc chút nào hay thực hiện rất chậm (Thất bại kiểm thử tích hợp hay kiểm thử hiệu năng). Những kiểu khiếm khuyết này là khó và yêu cầu nhiều thời gian và nỗ lực để sửa chữa.

Sai lầm thông thường khác là tài nguyên kiểm thử KHÔNG thích hợp. Hoặc người quản lí dự án phân công quá ít thời gian cho kiểm thử hoặc người kiểm thử được đưa tới cho dự án lúc quá muộn. Nếu nhóm kiểm thử KHÔNG hiểu hệ thống rõ thì họ không thể làm tốt việc tìm khiếm khuyết. Nhiều người quản lí dự án KHÔNG phân biệt rõ ràng hoạt động kiểm thử và hoạt động phát triển. Vì kiểm thử thường bị coi như hoạt động cuối cùng, nếu dự án bị trễ, kiểm thử thường bị bỏ để đáp ứng hạn chót đã lập lịch. Tất nhiên, nhiều phần mềm có khiếm khuyết và người dùng rất bực.

Sai lầm thông thường khác là về tri thức và kĩ năng của người kiểm thử. Nhiều người kiểm thử KHÔNG phân biệt được giữa kế hoạch kiểm thử (mục tiêu, cách tiếp cận, tài nguyên được cần tới, v.v.) và thủ tục kiểm thử (cái vào đặc thù, cái ra dự kiến, chỉ đạo cho người kiểm thử v.v.). Nhiều người lập trình cho các trường hợp kiểm thử thay vì kiểm điểm kế hoạch kiểm thử về sự chính xác, thủ tục kiểm thử về tính đầy đủ, và phân tích hiệu quả sai phương thức để nhận diện cái vào gây ra lỗi làm dữ liệu kiểm thử. Ngay cả khi họ kiểm thử, họ KHÔNG thực hiện phân tích bao quát để nhận diện những đường điều khiển nào đã được đi qua bởi dữ liệu kiểm  thử và đường nào chưa. Phần lớn mọi người KHÔNG thẩm định tính hiệu quả kiểm thử để xác định dữ liệu kiểm thử đã phơi ra khiếm khuyết trong phần mềm tốt đến đâu. Không có đào tạo thích hợp, nhiều người KHÔNG áp dụng một cách nhất quán kiểm thử rà lại để đảm bảo rằng những thay đổi chương quả trình không tác động vào việc vận hành đúng của hệ. Họ KHÔNG biết tỉ lệ phát hiện lỗi có thể được phân tích thế nào để hỗ trợ cho quyết định đưa ra sản phẩm.

Trong chuyến đi của tôi tới vài nước châu Á năm ngoái, tôi thấy rằng nhiều đại học đã KHÔNG có môn học về kiểm thử phần mềm. Kiểm thử được dạy như một phần của các lớp lập trình. Nhiều sinh viên KHÔNG hiểu kiểm thử đơn vị, kiểm thử tích hợp, kiểm thử hệ hống, kiểm thử alpha, kiểm thử beta, kiểm thử rà lại và kiểm thử chấp nhận. Với họ mọi thứ chỉ là “kiểm thử to” để cho chắc rằng phần mềm thực hiện và KHÔNG chết. Chừng nào quan điểm này còn chưa thay đổi và đào tạo thích hợp còn chưa có tại chỗ, chất lượng phần mềm sẽ KHÔNG được cải tiến.

English version

Software Testing

Testing is the execution of a program to find defects. A good test case is one that has a high probability of detecting defect. However, industry studies found that even with the best test case, developers can only catch about 70% of the defects and the other 30% still remain after the software is released to users. Because the limit of testing, it is recommended that developers remove as many defects as possible by other methods such as software reviews and inspections before testing phase to improve the quality of the software products.

There are many reasons for software to have defects. The most common is software requirements are not well defined and often change. These changes cause developers to change what they are doing and it creates defects. That is why Requirements Engineering (RE) is an important skill because it focuses on identify any ambiguous or missing information during the requirements phase. It forces developers to look at the entire requirements to determine “Testability attributes”. For every requirement, developers must be able to write a test case. If they cannot test it then either the requirement is ambiguous or developers do NOT understand the requirement. In either case, a discussion with users to clarify the requirement is necessary. That is why testing must be planned immediately after the requirements phase. However, lacking of the requirements engineering skill, many developers do NOT plan testing until they complete coding. This is too late and it is a big mistake. That is why most software have too many defects and too costly.

Another common mistake is the Test strategy is NOT well defined. Most developers focus on testing functions but NOT on integration or build. They believe as long as they test all requirements than everything will be good. They are NOT trained in “System Thinking” to understand the robustness of software by concentrate on critical portions of the system such as capacity and performance. Many times, all functions independently work well (Passing functions test) but when you put them together, the system does NOT work anymore or perform very slow (Failing integration test or Performance test). These types of defect are difficult and require a lot of time and efforts to fix.

Another common mistake is the Test resources are NOT adequate. Either project manager assigns too little time for testing or test people are not brought onto project until late. If the test group does NOT understand the system well than they cannot do good job in finding defects. Many project managers do NOT clearly distinct testing activity and developing activity. Since testing is often regarded as the last activity, if a project is late, test is often eliminated to meet the scheduled deadline. Of course, many software have defects and users are very angry.

Another common mistake is on the knowledge and skill of testers. Many testers do NOT make distinction between test plan (objectives, approach, resources required, etc.) and test procedure (specific inputs, the expected outputs, directions to the tester, etc.). Many would program test cases rather than review test plan for adequacy, test procedures for completeness, and failure mode effects analysis to identify probable error-causing inputs as test data. Even when they test, they do NOT perform coverage analysis identify which control paths have been exercised by the test data and which have not. Most do NOT assess test effectiveness to determine how well the test data have exposed defects contained in the software. Without adequate training, many do NOT consistently apply regression testing to ensure that program changes have not impacted correct system functioning. They do NOT know how error discovery rate can be analyzed to support a rational product release decision.

During my trip to several Asian countries last year. I found that many universities did NOT have courses on software testing. Testing was taught as part of programming language classes. Many students did NOT understand Unit testing, Integration testing, System testing, alpha testing, beta testing, Regression testing, and Acceptance testing. To them everything was just a “big test” to make sure that software executed and did NOT crash. Unless this view is changing and appropriate training is in place, software quality will NOT be improved.

 


Gửi bình luận
(0) Bình luận
1

Trước khi tốt nghiệp

"Một số bạn sinh viên bảo em rằng không có việc làm có sẵn cho sinh viên tốt nghiệp đại học như em nhưng thầy giáo của em lại nói rằng có nhiều. Em KHÔNG biết tin ai, đôi khi em tự hỏi mình liệu em có chọn đúng lĩnh vực học tập hay không."
2

Tài liệu kiểm thử

Một độc giả gửi cho tôi một email sau khi đọc bài “Người kiểm thử mới cần gì?” Người đó viết “Trong nghề của tôi như người kiểm thử, tôi chưa bao giờ thấy bất kì tài liệu kiểm thử nào. Người kiểm thử bao giờ cũng bận rộn, không có thời gian cho bất kì cái gì khác. Người kiểm thử có cần làm tài liệu không? Tài liệu kiểm thử có quan trọng không? Xin làm ơn giải thích.”
3

Làm việc hay không làm việc

Tuần trước tôi nhận được một email: “Dường như là thầy đang khuyến khích sinh viên đi làm trong khi vẫn đang học đại học nhưng bố mẹ em bảo em rằng em phải tập trung vào học tập vì họ có thể chăm lo cho em. Đi làm sẽ làm phân tán học tập của em và em KHÔNG nên làm hai điều đồng thời thì sẽ không thành công trong cái nào. Thầy nghĩ thế nào?”
4

Lập mục đích

Bạn có biết thuyền trưởng dẫn hướng con thuyền của mình trên đại dương thế nào không?
5

Nghề nghiệp và việc làm

"Em hiểu rằng giáo dục đại học là quan trọng nhưng em vẫn bị lẫn lộn về chọn lựa của em khi kết thúc giáo dục bậc đại học rồi đi làm cùng việc làm như mọi người có sáu tháng đào tạo lập trình..."

Việc làm tốt nhất ở Mỹ

Hôm nay tạp chí Money công bố danh sách 100 việc làm tốt nhất ở Mĩ và trong số đó việc làm công nghệ thông tin (CNTT) được xếp hạng rất cao.

Cuộc chiến về tài năng

Các công ty ở Thung lũng Silicon (San Jose) đang cạnh tranh về những kỹ sư phần mềm có kỹ năng với lương cao đáng kể và nhiều thưởng lớn.

Giáo dục và toàn cầu hoá

Trong năm mươi năm qua, các nước đã phát triển chi phối kinh tế thế giới, đóng góp quãng hai phần ba GDP toàn cầu nhưng ngày nay nó tụt xuống còn một nửa.

Bài học từ khoán ngoài

Khi tôi ở Trung Quốc tháng trước, tôi thấy điều gì đó mà tôi chưa bao giờ trông chờ: Việc đóng cửa một số nơi chế tạo ở Thượng Hải và Shenzheng.

Thị trường việc làm ngày nay

Theo tin tức mới nhất, phần lớn các công ti đều tin tưởng về phục hồi kinh tế và bắt đầu thuê người.

Một số sự kiện về cách tiếp cận Agile

Một sinh viên hỏi tôi: “Nếu Agile là cách tiếp cận tốt để phát triển phần mềm thì tại sao chúng ta phải học cách tiếp cận khác?”

Hệ thống giáo dục mới

Tôi để ba tuần giảng dạy ở Trung Quốc.

Phần mềm di động

Phát triển ứng dụng di động là qui trình qua đó phần mềm được phát triển cho điện thoại di động hay thiết bị cầm tay tương tự.

"Để hiểu một người": Khi “nhìn thấy” một người cũng là một hành động yêu thương

Có một câu hỏi tưởng như đơn giản nhưng càng nghĩ càng thấy khó trả lời: bạn thực sự hiểu bao nhiêu người trong đời mình? Không phải biết tên, biết nghề nghiệp, biết vài sở thích, mà là hiểu theo nghĩa nhìn thấy được thế giới nội tâm của họ, cách họ diễn giải những gì xảy đến với cuộc đời mình. 

Công nghệ thông tin ở Hàn Quốc

Blog GS John VU - GS John Vu - 28/06/2026 12:00
Trong tất cả các nước tôi đã viếng thăm, Hàn Quốc là nước gây ấn tượng nhất và là nước thành công nhất trong cải tiến hệ thống công nghệ và giáo dục của mình.

3 dấu hiệu cho thấy sếp của bạn có EQ thấp

Kỹ năng - Vân Anh - 28/06/2026 11:00
Làm việc dưới trướng một sếp EQ thấp không chỉ khiến môi trường trở nên ngột ngạt mà còn bào mòn tinh thần, khiến nhiều người giỏi cũng phải tính chuyện rời đi.

Nhìn chồng cũ cưng chiều vợ mới, tôi cay đắng nhận ra đã đánh mất… báu vật

Suy ngẫm - Giang Bùi - 28/06/2026 10:00
Tôi tiếc nuối vì đã không trân trọng người chồng điềm đạm, tử tế. Bản thân hối hận vô cùng nhưng đã quá muộn màng...

Giới trẻ chán K-Drama, kéo phim Trung lên Top khiến màn ảnh Hàn lo ngại

Phong cách sống - Yên Yên - 28/06/2026 09:00
VHO - Không phải người trung niên hoài niệm phim kiếm hiệp, không phải nhóm khán giả ngách, chính thế hệ teen Hàn Quốc đang kéo phim Trung Quốc lên Top 10 Netflix.

Hãy thưởng cho mình những khoảnh khắc “không làm gì” trong thế giới nghiện tốc độ

Từ sách - Phim - TĐ - 28/06/2026 08:00
Chúng ta đang sống trong một thế giới nơi “bận rộn” được xem là huy hiệu danh dự. Lịch trình của ta kín mít, hộp thư đến luôn đầy ắp, và ngay cả việc nghỉ ngơi cũng bị xem như thứ gì đó phải “xứng đáng mới được hưởng.

Rủi ro chính ở Mỹ

Blog GS John VU - GS John Vu - 27/06/2026 12:00
Mặc dầu việc ghi danh của sinh viên đại học vào tính toán và công nghệ thông tin ở Mĩ bắt đầu tăng lên sau một thập kỉ suy giảm nhưng nó KHÔNG đủ. Theo Cơ quan dự án nghiên cứu chuyên sâu quốc phòng của Lầu năm góc Mĩ U.S Pentagon’s Defense Advanced Research Projects Agency (DARPA), thiếu hụt hiện thời về công nhân công nghệ có phẩm chất đặt ra rủi ro nghiêm trọng cho Mĩ.

Cái chết trong tự nhiên mở đường cho sự sống mới như thế nào?

Suy ngẫm - Phạm Hường - 27/06/2026 10:00
Trong tự nhiên, cái chết không phải là điểm kết thúc. Xác thực vật, động vật và các cấu trúc sinh học còn sót lại tiếp tục thúc đẩy hoặc cản trở quá trình phục hồi của sự sống.

Việt Nam có một "đại bác học" là danh nhân văn hóa được UNESCO vinh danh, người duy nhất được lấy tên đặt cho 8 trường chuyên

Phong cách sống - Nhật Linh - 27/06/2026 09:00
Nhân vật này là một trong những học giả uyên bác bậc nhất trong lịch sử Việt Nam, biểu tượng của tinh thần học tập suốt đời và khát vọng cống hiến cho đất nước.

"Để hiểu một người": Khi “nhìn thấy” một người cũng là một hành động yêu thương

Từ sách - Phim - TĐ - 27/06/2026 08:00
Có một câu hỏi tưởng như đơn giản nhưng càng nghĩ càng thấy khó trả lời: bạn thực sự hiểu bao nhiêu người trong đời mình? Không phải biết tên, biết nghề nghiệp, biết vài sở thích, mà là hiểu theo nghĩa nhìn thấy được thế giới nội tâm của họ, cách họ diễn giải những gì xảy đến với cuộc đời mình. 

Trước khi tốt nghiệp

Blog GS John VU - GS John Vu - 26/06/2026 12:00
"Một số bạn sinh viên bảo em rằng không có việc làm có sẵn cho sinh viên tốt nghiệp đại học như em nhưng thầy giáo của em lại nói rằng có nhiều. Em KHÔNG biết tin ai, đôi khi em tự hỏi mình liệu em có chọn đúng lĩnh vực học tập hay không."

Google chính thức cho đổi tên địa chỉ Gmail cho tất cả người Việt Nam

Kỹ năng - Quốc Vinh - 26/06/2026 11:00
Tính năng đổi tên người dùng gmail đã ra mắt từ tháng 3 nhưng người dùng Việt Nam chỉ mới được cập nhật gần đây.

14 cụm từ lóng thiết yếu về bản chất con người

Suy ngẫm - PV - 26/06/2026 10:00
14 cụm từ lóng thiết yếu về bản chất con người, rất cần thiết để hòa nhập vào xã hội. Hiểu được một nửa trong số đó cho thấy trí tuệ cảm xúc cao, trong khi hiểu được tất cả chứng tỏ bạn là người vô cùng sắc sảo.

Nam sinh quỳ lạy mẹ nuôi sau khi thi đại học

Truyền cảm hứng - Hạ Di - 26/06/2026 09:00
Sau khi hoàn thành kỳ thi tuyển sinh đại học, một nam sinh 18 tuổi ở Trung Quốc đã quỳ xuống trước mẹ nuôi và dập đầu 3 lần để bày tỏ lòng biết ơn.

Trạm dừng sinh tử - Khi phẩm giá là thứ cuối cùng còn lại

Từ sách - Phim - An Yên - 26/06/2026 08:00
Một ông lão vô gia cư hấp hối dưới gầm cầu. Không nhà, không giấy tờ, không người thân. Nhưng trong những ngày cuối cùng của cuộc đời, ông lại để lại cho người đọc một bài học sâu sắc về phẩm giá, lòng trắc ẩn và ý nghĩa của việc được nhìn nhận như một con người.
HẠT GIỐNG TÂM HỒN
2019 Bản quyền thuộc về hatgiongtamhon.com.vn. Phát triển bởi ONECMS