October 2018

This script is based on the install script from André Schenkels (https://github.com/aschenkels-ictstudio/openerp-install-scripts) but goes a bit further and has been improved. This script will also give you the ability to define an xmlrpc_port in the .conf file that is generated under /etc/ This script can be safely used in a multi-odoo code base server because the default Odoo port is changed BEFORE the Odoo is started.

Installation procedure

1. Download the script:
sudo wget https://raw.githubusercontent.com/Yenthe666/InstallScript/12.0/odoo_install.sh
2. Modify the parameters as you wish.
There are a few things you can configure, this is the most used list:
OE_USER will be the username for the system user.
INSTALL_WKHTMLTOPDF set to False if you do not want to install Wkhtmltopdf, if you want to install it you should set it to True.
OE_PORT is the port where Odoo should run on, for example 8069.
OE_VERSION is the Odoo version to install, for example 12.0 for Odoo V12.
IS_ENTERPRISE will install the Enterprise version on top of 12.0 if you set it to True, set it to False if you want the community version of Odoo 12.
OE_SUPERADMIN is the master password for this Odoo installation.

3. Make the script executable

sudo chmod +x odoo_install.sh
4. Execute the script:
sudo ./odoo_install.sh

Tất cả các phần mềm có những yêu cầu và mục đích sử dụng của nó. Tuy nhiên, phần mềm mà không có tài liệu yêu cầu, tài liệu yêu cầu không đầy đủ, không chính xác hoặc là tài liệu đã lỗi thời... là một thực tế mà không may hầu hết chúng ta gặp phải, đó hẳn là điều mà chúng ta không hề mong muốn. Và trên thực tế thì điều này rất hay xảy ra. Nó không những gây khó khăn trong công việc mà còn không thể đánh giá và lập kế hoạch test một cách chính xác, ảnh hưởng đến chất lượng sản phẩm phần mềm.
Trong bài viết này sẽ thảo luận về vấn đề Làm thế nào để thực hiện kiểm thử phần mềm khi mà không có bất cứ tài liệu yêu cầu nào. Không SRS, không FRD và làm thế nào tester có thể thực hiện công việc của mình một cách hiệu quả.
Làm thể nào để kiểm thử phần mềm mà không có bất kỳ yêu cầu nào?
Hãy cùng thảo luận những khó khăn mà tester phải đối mặt khi thực hiện kiểm thử phần mềm mà không hề có bất kỳ tài liệu đặc tả yêu cầu nào.
  1. Việc thiết kế Test cases hoặc Test Scenarios trở nên khó khăn vì bạn không hề có bất kỳ tài liệu nào để tham khảo.
  2. Khi bạn có tài liệu yêu cầu cụ thể, bạn sẽ biết được phần mềm hoạt động như thế nào khi chúng được hoàn thành nhưng ở đây bạn chỉ có thể tiếp cận ở mức tối thiểu mà thôi.
  3. Ngoài ra tài liệu yêu cầu cũng có thể dễ dàng gây ra hiểu lầm hoặc thay đổi thường xuyên dẫn đến việc hệ thống không ổn định và khó khăn trong việc kiểm thử.
Để làm việc với những dự án như vậy, bạn cần có sự hiểu biết tốt, giao tiếp hiệu quả bằng lời nói cũng như bằng văn bản và có một kế hoạch thích hợp. Có một vài điều quan trọng cần biết trước khi bắt đầu giai đoạn kiểm thử, chẳng hạn như:
  1. Xác định kỹ thuật kiểm thử sẽ sử dụng trong quá trình kiểm thử hệ thống (kiểm thử chức năng, kiểm thử hồi quy, kiểm thử tải...)
  2. Sử dụng version cũ của phần mềm như một tài liệu tham khảo để kiểm thử phiên bản tương lai của sản phẩm phần mềm.
  3. Những tài liệu mà developer tham khảo cho mục đích code thì Tester cũng có thể tham khảo để có ý tưởng phần mềm sẽ hoạt động thế nào.
  4. Những rủi ro liên quan đến các sản phẩm phần mềm.
Một khi đã phân tích tất cả các điểm trên, sẽ dễ dàng hơn cho chúng ta lập kế hoạch phù hợp và thực hiện kiểm thử. Bây giờ chúng ta hãy xem một số điểm quan trọng trong khi kiểm thử sản phẩm phần mềm như vậy:
  1. Đọc các tài liệu mà dev phát triển sản phẩm dựa trên tài liệu ấy và chia sẻ test cases của bạn với họ. Bằng cách này, bạn sẽ biết dev đang phát triển phần mềm như thế nào và bạn có thể thiết kế test cases của bạn dựa trên đó. Ngoài ra, bằng cách chia sẻ các trường hợp thử nghiệm của bạn với họ, bạn được đảm bảo rằng bạn hiểu các chức năng và sẽ test nó một cách đúng đắn.
  2. Trong trường hợp của bất kỳ sự mơ hồ nào, hãy làm cho nó rõ ràng càng sớm càng tốt. Liên quan đến tất cả các team như là testers, developers, business analysts và clients. Hãy chắc chắn rằng sau khi buổi họp tất cả các đội bóng đang ở trên mức độ hiểu biết cùng và sau đó tiến hành với quá trình này.
  3. Lập tài liệu về những gì bạn đã test và work flow cho phần mềm, nên sử dụng sơ đồ sẽ giúp bạn hiểu rõ hơn về hệ thống.
  4. Chuẩn bị một danh sách các mục In-Scope, Out-of-Scope và chia sẻ với tất cả các thành viên trong team và được manager của bạn phê duyệt. Bạn có thể cập nhật danh sách bất cứ lúc nào sau này sau khi thảo luận với các thành viên trong team.
  5. Đôi khi, người dùng cuối (tại phía khách hàng) có thể thử nghiệm các sản phẩm ở giai đoạn sớm hơn, nên nếu có thể, hãy lập ra những test case từ cách sử dụng hệ thống của người dùng biết những mong muốn và lợi ích của các phần mềm của họ.
  6. Thực hiện Exploratory Testing nhiều lần, vì bạn không có bất cứ yêu cầu cụ thể nào, bạn có thể thường xuyên kiểm tra ngẫu nhiên và bất cứ điều gì bạn cảm thấy là không đúng, bạn có thể thảo luận với khách hàng và làm cho nó chính xác hơn bằng cách gửi nó cho team developer.
  7. Hãy suy nghĩ từ quan điểm của tất cả người sử dụng và làm cho phần mềm hữu ích hơn. Đề xuất ý kiến và giải pháp của bạn. Có nhiều cách sử dụng khác nhau từ phía người dùng, nếu bạn có thể suy nghĩ từ quan điểm của họ sau đó phần mềm sẽ trở nên tương thích và linh hoạt hơn.
  8. Chia toàn bộ hệ thống thành các module nhỏ và hiểu chúng một cách chi tiết. Bằng cách này bạn sẽ test của mỗi một phần của việc tạo ra phần mềm tối đa vùng phủ sóng thử nghiệm. Nó là dễ dàng hơn để kiểm thử một module nhỏ hơn là kiểm thử toàn bộ hệ thống cùng một lúc.
  9. Tự động hoá các test case những chức năng đã được cố định để tiết kiệm thời gian và nguồn lực. Trong những giai đoạn đầu của dự án khi mà yêu cầu liên tục thay đổi, bước này có thể thấy không cần thiết, nhưng sau một thời gian khi các yêu cầu hoặc chức năng được cố định, bạn có thể tạo test case tự động. Ví dụ, một màn hình đăng nhập. Bạn biết chắc chắn những thông tin đầu vào có trên màn hình như Username, password, Captcha... vv, do đó bạn có thể viết các test case cơ bản liên quan đến màn hình này và tự động hóa chúng.
Kết luận:
Khi chúng ta làm việc với một dự án mà không có yêu cầu, kế hoạch cụ thể, sẽ có những thách thức mà chúng ta vừa thảo luận, nhưng có nhiều cách để xử lý chúng. Giao tiếp tốt với khách hàng và developer, lấy ý kiến phản hồi của họ thường xuyên để biết mong muốn của họ là gì. Khi bạn biết cần phải test gì và test như thế nào, bạn có thể tự tạo tài liệu yêu cầu và có thể tham khảo hoặc cập nhật suốt quá trình kiểm thử.

Đây là bài viết được lấy ra từ link sau: http://www.testingexcellence.com/transitioning-waterfall-agile-testing/
Khi một công ty quyết định chuyển từ kiểm thử theo mô hình thác nước sang kiểm thử theo mô hình agile, điều gì là quan trọng nhất mà ta phải tập trung quan tâm để test theo mô hình agile được hiệu quả?
Điều gì tạo nên sự khác biệt của kiểm thử theo mô hình agile và mô hình thác nước? Một người tester cần biết và thực hiện các công việc quan trọng nào?

Kiểm thử trong suốt quá trình phát triển

Điều đầu tiên ta cần hiểu rằng trong mô hình phát triển agile, kiểm thử được thực hiện trong suốt vòng lặp nghĩa là kiểm thử phần mềm diễn ra liên tục trong suốt quá trình phát triển sản phẩm.
Trong mô hình thác nước truyền thống, kiểm thử rất tốn effort và là phần cuối cùng để kết thúc việc phát triển, trong khi theo mô hình Agile, kiểm thử là một phần nhỏ nhưng lặp lại thường xuyên và xảy ra trong suốt quá trình phát triển phần mềm.
waterfall-model.png
Agile-Development-diagram_03.png
Kiểm thử trong suốt quá trình phát triển cũng đồng nghĩa với việc phần mềm luôn được đặt trong điều kiện có thể release, do đó nó có thể được bàn giao sản phẩm bất cứ lúc nào.
Trong mô hình thác nước, chúng ta làm việc theo từng giai đoạn, cụ thể là giai đoạn thiết kế, giai đoạn code và giai đoạn kiểm thử. Phát triển theo agile ta sẽ không còn chia giai đoạn kiểm thử ra riêng biệt như vậy nữa. Các developer cũng sẽ có vai trò quan trọng hơn khi tham gia vào việc kiểm thử, viết unit test tự động để validate code.

Sự tham gia của developer trong kiểm thử

Với unit test tự động, việc kiểm thử có thể được hoàn thành như một phần trong việc xây dựng, đảm bảo rằng tất cả các feature được thực hiện chính xác mỗi khi build. Từ độ bao phủ tốt của unit test, developer sẽ cảm thấy tự tin hơn để refractor code.
Kiểm thử trong agile cũng sẽ bắt đầu sớm. Tức là QA sẽ phải tham gia ngay từ giai đoạn design, hiểu các feature và story và bắt đầu chuẩn bị viết tescase.

Cross Functional Teams (Nhóm liên chức năng)

understanding-roles-on-an-agile-project-7-728.jpg
Chuyển sang Agile nghĩa là các hoạt động của team trong project sẽ có chức năng như nhau. Việc cùng tham gia kiểm thử này không gây cản trở gì cho việc kiểm thử của tester. Các developer sẽ hỗ trợ bằng các test framework, các business analysts hỗ trợ bằng cách chỉnh lại các story cho chuẩn xác.
Mỗi thành viên trong team làm việc theo story cho tới khi toàn bộ story được thực hiện xong, điều đó có nghĩa là vừa code vừa kiểm thử. Các designer, developer và tester làm việc song song cùng nhau để đạt được mục tiêu chung và họ cần biết điều gì cần thiết phải làm để hoàn thành công việc (không có ai giao việc cho họ).
Làm việc theo đội là điểm đáng chú ý nhất khi chuyển từ mô hình kiểm thử thác nước sang mô hình agile. Các công ty có thể quyết định thay đổi để chuyển sang mô hình kiểm thử agile nhưng mỗi cá nhân trong team cần phải hỗ trỡ lẫn nhau cùng thực hiện thì sự thay đổi mới có thể thành công.

Mục tiêu ngăn ngừa lỗi hơn là phát hiện lỗi

a-brief-introduction-to-agile-duong-trong-tan-201406-65-638.jpg
Nhìn lên hình trên ta có thể nhận thấy ngay, lỗi được phát hiện càng muộn chi phí càng tăng cao. Với sự tham gia ngay từ lúc bắt đầu của tester trong dự án, họ có thể hỗ trợ trong việc xác định các kịch bản chính để kiểm thử một story. Các acceptance criteria (tiêu chí chấp nhận) sẽ thường xuyên được tạo bởi cả Product Owner, developer và tester.
Điều này đảm bảo rằng bất cứ điều gì đang được xây dựng thì tất cả các bên liên quan đều có thể kiểm thử và hiểu rõ ràng. Ngoài ra, càng nhiều người đang tham gia vào việc xác định các tiêu chí chấp nhận và "Định nghĩa thế nào là hoàn thành", lỗi có thể được sửa chữa sớm hơn và sản phẩm cuối cùng đảm bảo đúng các yêu cầu.
Mọi người đều có liên quan và chịu trách nhiệm về chất lượng của sản phẩm.

Ít tài liệu hơn, tăng tính cộng tác

Trong mô hình phát triển Agile, người ta chú trọng nhiều vào đối thoại và hợp tác để làm rõ yêu cầu hơn là dựa trên đặc tả và tài liệu như mô hình phát triển truyền thống .

Trong mô hình phát triển agile, mặc dù các yêu cầu có thể được làm sáng tỏ ở một mức độ nhất định, nó vẫn có thể có các yêu cầu không rõ ràng và không đầy đủ, dẫn đến các thành viên trong nhóm có sự hiểu biết khác nhau về yêu cầu.Điều đó có ý nghĩa như thế nào cho một Agile Tester? Một vấn đề chung cho các tester khi họ chuyển sang mô hình phát triển Agile là họ không biết chính xác những gì họ cần phải kiểm thử. Họ không có spec chi tiết để kiểm tra đối chiếu, vậy làm thế nào họ có thể có thể kiểm tra nó? Bạn không cần phải có tài liệu chi tiết để bắt đầu kiểm thử. Sẽ có rất nhiều trường hợp, tester phải tự xem xét và dùng cảm nhận chung để xác nhận sản phẩm. Việc có kiến thức rộng, có kinh nghiệm trở nên hết sức quan trọng. Tester cần có sự tự tin về kiến thức của mình nhiều hơn để làm việc hiệu quả.

Trong quá trình thực hiện công việc kiểm thử, chúng ta gặp phải vô số các khái niệm kiểm thử khác nhau. Các khái niệm này có thể đã quen thuộc với nhiều người, nhưng cũng có rất nhiều khái niệm mà chúng ta lạ lẫm và chưa từng nghe thấy. Xuất phát từ việc hiểu được rằng "Những điều chúng ta biết chỉ là giọt nước, những điều chúng ta chưa biết là cả đại dương", bài viết này sẽ đưa đến cho bạn đọc 100+ khái niệm kiểm thử phần mềm khác nhau mà các Tester cần biết. Đây là một danh sách tổng hợp bao gồm định nghĩa và giới thiệu ở mức tổng quan về hơn 100 khái niệm testing. Qua bài viết này, hi vọng bạn đọc sẽ có hiểu biết rõ ràng hơn về các khái niệm test cũng như nắm được các thông tin cơ bản nhất về các loại test mà mình đang quan tâm.
product-testing21.jpg
1. Acceptance Testing: Khách hàng thực hiện (hoặc ủy quyền cho một nhóm thứ ba thực hiện). Mục đích của Acceptance Test là để chứng minh PM thỏa mãn tất cả yêu cầu của khách hàng và khách hàng chấp nhận sản phẩm.
2. Accessibility Testing: Là một loại kiểm thử dành cho các hệ thống được thiết kế cho người khuyết tật (khiếm thính, khiếm thị, thiểu năng tâm thần...), xác định khả năng tiếp cận và sử dụng của họ với ứng dụng, ví dụ như các thiết lập Accessibility của smart phone: Text-to-Speech, "Magnification gestures"... Người khuyết tật thường sử dụng những tính năng hỗ trợ họ sử dụng các phần mềm. Loại test này có thể được thực hiện theo 2 cách là Manual và Automated.
bMWRkhB.jpg
3. Active Testing: Loại kiểm thử bao gồm việc đưa ra dữ liệu test và phân tích kết quả thực hiện. Nó thường được tiến hành bởi đội tester. Trong quá trình active testing, tester sẽ hình dung để dựng một mô hình của phần mềm để test, cái này sẽ được phát triển và làm hoàn thiện hơn các tương tác của nó với những phần mềm đang chạy.
4. Agile Testing: Kiểm thử Agile là việc kiểm thử phần mềm được thực hiện theo một số quy định của bản tuyên ngôn (manifesto) Agile, xem việc phát triển phần mềm như là khách hàng của việc kiểm thử.
Kiểm thử Agile thực hiện kiểm thử theo quan điểm của khách hàng càng sớm càng tốt, thử nghiệm sớm và thường xuyên ngay khi code vừa xong và đủ ổn định để test từ level unit test.
5. Age Testing: Loại kiểm thử đánh giá khả năng hoạt động của hệ thống trong tương lai. Quá trình đánh giá được thực hiện bởi đội tester. Age Testing đo đạc sự hao hụt về performance của hệ thống khi hệ thống PM bị cũ đi.
6. Ad-hoc Testing: Việc thực hiện test mà không có plan, không có tài liệu, tester cố gắng phá vỡ hệ thống bằng cách thử ngẫu nhiên các chức năng của hệ thống. Việc này được thực hiện bởi đội tester.
adhoc-testing.png
7. Alpha Testing: Loại kiểm thử phần mềm hoặc hệ thống được tiến hành bởi người dùng cuối nhưng thực hiện ngay tại chỗ của đội developer.
8. Assertion Testing: Là việc xác minh xem các điều kiện có đáp ứng được các yêu cầu về logic hoặc business của sản phẩm hay không. Nó đảm bảo cho việc test và các mục tiêu test luôn liên quan đúng và rõ ràng.
9. API Testing:
  • API (Application Programming Interface): cho phép kết nối và trao đổi dữ liệu giữa hai hệ thống phần mềm riêng biệt. Một hệ thống phần mềm có thể nhúng các API bao gồm các hàm/thủ tục con (functions/sub-routines) mà có thể chạy bởi một hệ thống phần mềm khác.
  • Kiểm thử API khác hoàn toàn với kiểm thử GUI và các thành phần chủ yếu khác trong tầng business logic của kiến trúc phần mềm. Loại kiểm thử này không tập trung vào phần giao diện và thao tác giao diện của một ứng dụng.
    Thay vì sử dụng các đầu vào (bàn phím) và đầu ra tiêu chuẩn, trong kiểm thử API, bạn có thể sử dụng một phần mềm để gửi các yêu cầu đến API, nhận đầu ra và ghi lại phản hồi của hệ thống.
10. All-pairs Testing: All pair testing (Kiểm thử tất cả các cặp) hay còn gọi là pairwise testing, là một phương pháp test được thực hiện để kiểm thử các phần mềm sử dụng phương pháp tổ hợp. Đó là một phương pháp để kiểm tra tất cả các kết hợp rời rạc có thể có của các thông số liên quan, phương pháp test ít nhất sao cho chất lượng tốt nhất.
11. Automated Testing: Kiểm thử tự động sử dụng công cụ (tool) để kiểm soát môi trường thiết lập, thực hiện kiểm tra và báo cáo kết quả. Nó được thực hiện bởi máy tính và được sử dụng trong nội bộ team test.
automatedbenefitssmall.jpg
12. Basis Path Testing: Thuộc phương pháp kiểm thử hộp trắng (White box test) là kĩ thuật kiểm thử mà phần mềm được chia thành các lộ trình, đảm bảo các lộ trình độc lập qua một module mã sẽ được kiểm thử đầy đủ. Thực hiện bởi developer.
13. Backward Compatibility Testing: Kiểm tra sự tương thích ngược: là việc kiểm tra xem các sản phẩm của ứng dụng cũ có tiếp tục làm việc tốt trên phiên bản mới của ứng dụng đó hay không.
14. Benchmark Testing: Là việc xác định perfomance hiện tại của hệ thống và thực hiện các thay đổi để cải thiện perfomance của sản phẩm cho tốt hơn. Như việc refactor code, tinh chỉnh cơ sở dữ liệu để người dùng có thể trải nghiệm những cải tiến hiệu suất.
Được thực hiện bởi đội dev hoặc Database admin (DBAs).
15. Beta Testing: Là giai đoạn test cuối cùng trước khi bàn giao ứng dụng, ứng dụng hoặc phần mềm được phân bổ như một phiên bản thử nghiệm (sử dụng thử) để người dùng kiểm tra ứng dụng tại nơi làm việc của họ. Người sử dụng sẽ quan sát phần mềm, trong trường hợp nếu có bất kỳ lỗi xảy ra thì nó được báo cáo đến người phát triển.
16. Big Bang Integration Testing: Khi mà tất cả mọi thứ sẵn sàng thì kĩ thuật kiểm tra này thực hiện để tích hợp các module độc lập của chương trình.
slide_7.jpg
17. Binary Portability Testing: Kĩ thuật test tính di động của phần mềm bằng cách chạy phần mềm trên các nền tảng và môi trường khác nhau. Nó được sử dụng cho cấu tạo của Application Binary Interface (ABI). Binary Portability testing nên được tiến hành trên các loại khác nhau của platform, như Windows(x86, X86-64), Linux, Mac OS, Java, Solaris, and Android. Nếu ứng dụng có tính di động cao thì người dùng có thể chạy ứng dụng trên bất kì nền tảng (platform) nào. Do đó để test Binary portability thì tức là khi xây dựng 1 phần mềm thì cần test việc nó thực thi được ứng dụng đó trên nhiều hệ điều hành khác nhau, nếu nó là website thì cần chạy được trên nhiều trình duyệt khác nhau để kiểm tra tính di động của nó. Được thực hiện bởi nhóm test.
18. Boundary Value Testing: Kĩ thuật kiểm thử phần mềm trong đó test case được thiết kế để bao gồm những giá trị giới hạn tiêu biểu. Được thực hiện bởi đội test.
19. Bottom Up Integration Testing: Trong kiểm thử tích hợp từ dưới lên, mô-đun ở mức thấp nhất được phát triển đầu tiên và các mô-đun khác đi theo hướng chương trình chính được tích hợp và kiểm thử cùng một lúc. Thực hiện bởi nhóm kiểm thử.
20. Branch Testing: Kỹ thuật kiểm thử, trong đó tất cả các nhánh trong mã nguồn của chương trình sẽ được kiểm tra ít nhất một lần. Thực hiện bởi các developer.
21. Breadth Testing: Là việc kiểm tra bằng các test suit thực hiện đầy đủ các chức năng của một sản phẩm nhưng không kiểm tra từng tính năng chi tiết.
Người thực hiện: Các đội kiểm thử.
22. Black box Testing: Một phương pháp kiểm thử phần mềm xác minh các chức năng của một ứng dụng mà không có kiến thức cụ thể về mã / cấu trúc bên trong của ứng dụng. Các kiểm thử được dựa trên yêu cầu và chức năng. Thực hiện bởi team QA.
Black-Box-Testing-Invensis.jpg
23. Code-driven Testing: Kỹ thuật kiểm thử sử dụng framework để kiểm thử (như xUnit) cho phép thực hiện các kiểm thử đơn vị (unit test) để xác định xem các phần khác nhau của mã đang hoạt động như mong đợi trong những tình huống khác nhau. Thực hiện bởi developers.
24. Compatibility Testing: Kỹ thuật kiểm thử xác nhận làm thế nào một phần mềm thực hiện tốt trong một phần cứng / phần mềm / hệ điều hành/ môi trường hệ thống / môi trường mạng. Thực hiện bởi các nhóm kiểm thử.
25. Comparison Testing: Kỹ thuật kiểm thử so sánh điểm mạnh và điểm yếu của sản phẩm với các phiên bản trước đó hoặc các sản phẩm tương tự khác. Thực hiện bởi nhân viên kiểm thử, các nhà phát triển, quản lý sản phẩm hoặc chủ sở hữu sản phẩm.
26. Component Testing: Kỹ thuật kiểm thử tương tự với kiểm thử đơn vị, nhưng với một mức độ kiểm thử tích hợp cao hơn được thực hiện kiểm thử các ứng dụng thay vì chỉ trực tiếp kiểm thử một phương thức cụ thể. Thực hiện bởi đội kiểm thử hoặc đội phát triển.
700px-NYMU_reloxilator_component_testing.png
27. Configuration Testing: Kỹ thuật kiểm thử quyết định cấu hình tối thiểu và tối ưu của phần cứng và phần mềm, hiệu quả của việc thêm hoặc sửa đổi các nguồn tài nguyên như bộ nhớ, ổ đĩa và CPU.
Thực hiện bởi các kỹ sư kiểm thử hiệu năng.
28. Condition Coverage Testing: Loại kĩ thuật kiểm thử phần mềm mà mỗi điều kiện được gán 2 giá trị đúng và sai ít nhất 1 lần.
Thực hiện bởi các nhóm kiểm thử tự động.
29. Compliance Testing: Loại kiểm thử mà kiểm tra xem hệ thống đã được xây dựng phù hợp với các tiêu chuẩn, thủ tục và hướng dẫn hay không. Người thực hiện: Các công ty bên ngoài, các công ty cung cấp thương hiệu "chứng nhận tuân thủ OGC ".
30. Concurrency Testing: Kiểm thử đa người dùng hướng tới việc xác định ảnh hưởng của việc tiếp cận cùng một mã ứng dụng, mô-đun hoặc cơ sở dữ liệu. Thực hiện bởi các kỹ sư hiệu năng.
31. Conformance Testing: Quá trình kiểm thử một sản phẩm hoặc hệ thống phù hợp với đặc điểm kỹ thuật của spec. Thực hiện bởi các đội kiểm thử.
32. Context Driven Testing: Một kỹ thuật kiểm tra Agile, khuyến khích các tester tự lựa chọn test techniques, test deliverable, test documentation và test objectives, theo chủ trương đánh giá liên tục và sáng tạo các cơ hội kiểm thử của những thông tin tiềm năng, các giá trị của thông tin để tổ chức kiểm thử tại một thời điểm cụ thể. Người thực hiện: Các đội kiểm thử Agile.
What-do-we-need-to-know-about-Context-Driven-Testing.jpg
33. Conversion Testing: Được thực hiện khi chuyển đổi dữ liệu từ hệ thống hiện có sang hệ thống mới thay thế. Kiểm thử các chương trình hoặc các thủ tục được sử dụng để chuyển đổi dữ liệu từ hệ thống hiện có để sử dụng trong các hệ thống thay thế. Người thực hiện: Đội ngũ QA.
34. Decision Coverage Testing: Loại hình kiểm thử phần mềm mà mỗi quyết định được thực hiện ít nhất một lần đảm bảo rằng tất cả các code được thực hiện. Mỗi quyết định được thực hiện bằng cách đặt vào 2 giá trị đúng và sai. Thực hiện bởi dev hoặc các nhóm kiểm thử tự động hóa.
35. Destructive Testing: Loại kiểm thử trong đó các kiểm thử được tiến hành với các dữ liệu kiểm thử thất bại , để hiểu về hiệu suất ,hành vi quan trọng của một mẫu kiểm thử theo tải trọng khác nhau. Thực hiện bởi đội ngũ QA.
36. Dependency Testing: Loại kiểm thử trong đó xem xét các yêu cầu của một ứng dụng cho các phần mềm tiền đề, trạng thái ban đầu và cấu hình để duy trì chức năng thích hợp. Thực hiện bởi các đội kiểm thử.
37. Dynamic testing: Kiểm thử liên quan đến việc thực thi các thành phần hoặc toàn bộ hệ thống phần mềm. Thường được thực hiện bởi đội test.
AAEAAQAAAAAAAAbtAAAAJDVmYzFlYmU2LTdmY2YtNGY5My1hNjRjLTFkOTg1OTRmYjI5NA.png
38. Domain testing: Là loại kiểm thử kiểm tra những thông tin mà người dùng sử dụng để nhập vào trên các vùng dữ liệu, kiểm tra các kết quả nhận được và xem xét chúng có đúng không. Thường được thực hiện bởi đội phát triển phần mềm và team test automation.
39. Error handling testing: Loại kiểm thử phần mềm xác định trách nhiệm của hệ thống xử lý các giao dịch có lỗi một cách thích hợp. Thường được thực hiện bởi đội test.
40. End - to- end testing: Tương tự với system testing, liên quan đến việc kiểm thử trong môi trường tương tự với môi trường sử dụng thật, ví dụ tương tác với DB, sử dụng giao tiếp mạng, hoặc tương tác với các phần cứng, ứng dụng, hoặc hệ thống nếu phù hợp.
Được thực hiện bởi đội QA.
HS.43-End-to-End-v1.jpg
41. Endurance testing: Loại test để check việc thiếu bộ nhớ hoặc các vấn đề có thể xảy ra khi ứng dụng được thực hiện trong thời gian dài. Thường được thực hiện bởi đội hiệu năng.
42. Exploratory testing: Kỹ thuật kiểm thử hộp đen thực hiện mà không cần plan và tài liệu.
Thường được thực hiện bởi tester manual.
43. Equivalence Partitioning testing: Kỹ thuật kiểm thử phần mềm chia dữ liệu đầu vào thành các phân vùng nhỏ hơn.
Thường được đội QA sử dụng.
44. Fault injection testing: Là kỹ thuật mà tester tập trung vào phương pháp mà hệ thống xử lý ngoại lệ thông qua việc truyền mã độc vào hệ thống. Được thực hiện bởi đội QA.
45. Formal verification testing: Kiểm định hình thức theo kiểu chứng minh định lý (Theorem Proving), kiểm tra logic hệ thống xem có phù hợp với spec không. Thường được thực hiện bởi đội QA.
46. Functional testing: Loại kiểm thử hộp đen dựa trên test case và spec. Được thực hiện bởi đội kiểm thử.
functional-testing.jpg
47. Fuzz testing: Kỹ thuật kiểm thử phần mềm dùng các dữ liệu input invalid, không mong muốn hoặc random - nó là trường hợp đặc biệt của mutation testing. Fuzz testing được thực hiện bởi đội test.
48. Gorilla testing: Là kỹ thuật mà tester thực hiện test lại phần đã test một vài lần trước đó để đảm bảo tính chắc chắn của hệ thống
Được thực hiện bởi tester hoặc developer.
49. Gray box testing: Là sự kết hợp của kiểm thử hộp đen và kiểm thử hộp trắng. Test phần mềm dựa trên spec nhưng lại sử dụng cả các kiến thức bên trong về hoạt động của code.
Được thực hiển bởi dev và test.
50. Glass box testing: Nó khá giống với kiểm thử hộp trắng. Nó cũng sử dụng kiến thức về xử lý code bên trong để test.
Được đội dev thực hiện là chủ yếu.
51. GUI software testing: Test giao diện người dùng của sản phẩm để đảm bảo đáp ứng được các yêu cầu. Thường được thực hiện bởi đội test.
52. Globalization testing: Phương pháp kiểm thử kiểm tra các chức năng thích hợp của sản phẩm trong điều kiện thiết lập culture / locale sử dụng tất cả các loại đầu vào quốc tế có thể.
Nó được thực hiện bởi đội test.
53. Hybrid integration testing: Kết hợp 2 kỹ thuật kiểm thử tích hợp từ trên xuống và tích hợp từ dưới lên để tận dụng những ưu điểm của cả 2 kỹ thuật đó.
Thường được thực hiện bởi đội test.
54. Intergration testing: Integration Testing là công việc kiểm thử tích hợp 1 nhóm các module riêng lẻ với nhau. Thường được thực hiện bởi nhóm kiểm thử.
unit-testing-7-638.jpg
55. Interface Testing: Kiểm thử giao diện là việc kiểm tra các yếu tố liên quan đến giao diện người dùng. Được thực hiển bởi tester hoặc nhóm phát triển.
56. Install/ Uninstall Testing:
  • Kiểm thử cài đặt: Được thực hiện để xác minh liệu rằng các phần mềm đã được cài đặt với tất cả các thành phần cần thiết và các ứng dụng đang làm việc như mong đợi.
  • Kiểm thử gỡ bỏ cài đặt: Được thực hiện để xác minh liệu rằng tất cả các thành phần của ứng dụng có bị loại bỏ trong quá trình hay không. Tất cả các tập tin liên quan đến ứng dụng cùng cấu trúc thư mục của nó phải được gỡ bỏ sau khi quá trình gỡ bỏ thành công.
  • Được thực hiện bởi các kỹ sư kiểm thử phần mềm.
57. Internationalization Testing: Quá trình đảm bảo chắc chắn các chức năng của sản phẩm không bị phá vỡ và tất cả các thông điệp được đưa ra ngoài chính xác khi được sử dụng trong các ngôn ngữ và miền địa phương khác nhau. Được thực hiện bởi đội kiểm thử.
58. Inter-system Testing: Kỹ thuật kiểm thử tập trung vào kiểm thử các ứng dụng nhằm đảm bảo các kết nối giữa chức năng ứng dụng luôn chính xác. Thường được thực hiện bởi các nhóm kiểm thử.
59. Keyword driven testing: Keyword Driven Testing (hay còn gọi là as table-driven testing hoặc action word based testing) là một kỹ thuật lập trình sử dụng các tập tin dữ liệu không chỉ chứa các dữ liệu kiểm thử và kết quả mong đợi, mà còn chứa các từ khóa liên quan đến ứng dụng đang được kiểm thử. Thực hiện bởi nhóm kiểm thử thủ công và tự động.
Keyword-Driven-Test-Automation-Framework.jpg
60. Load Testing: Load testing là một quá trình thêm nhu cầu vào một hệ thống hoặc thiết bị và đo lường phản ứng của nó. Load testing được thực hiện để xác định ứng xử của hệ thống trong các điều kiện tải bình thường và cao hơn điều kiện tải dự kiến. Được thực hiện bởi các kỹ sư hiệu năng.
61. Localization Testing: Localization testing là quá trình kiểm thử nhằm mục đích kiểm tra các phiên bản địa phương hóa của sản phẩm đặc trưng cho một nền văn hóa hoặc một địa phương cụ thể. Được thực hiện bởi tester.
Bạn đọc có thể tham khảo thêm để biết sự khác biệt giữa Globalization và Localization Testing tại link sau: http://www.guru99.com/globalization-vs-localization-testing.html
globalization_testing.png
62. Loop Testing:
  • Kỹ thuật kiểm thử hộp trắng tạo ra một chu trình vòng lặp.
  • Kiểm tra vòng lặp hoàn toàn tập trung vào tính hiệu lực của các cấu trúc vòng lặp. Nó là một trong những phần kiểm soát kiểm tra cơ cấu (kiểm tra đường dẫn, kiểm tra xác nhận dữ liệu, kiểm tra điều kiện).
  • Được thực hiện bởi các kỹ sư phát triển.
63. Manual Scripted Testing: Kỹ thuật kiểm thử trong đó các TCs được thiết kể và xem xét bởi nhóm kiểm thử trước khi thực hiện chúng. Được hoàn thành bởi nhóm kiểm thử thủ công.
64. Manual Support Testing: Kiểm thử hỗ trợ thủ công là loại kiểm thử các chức năng hỗ trợ bằng tay. Nó đạt hiệu quả nhất trong giai đoạn cài đặt sản phẩm. Được thực hiện bởi nhóm kiểm thử.
65. Model based Testing: MBT là thế hệ tự động của quy trình kiểm thử phần mềm sử dụng mô hình hành vi và yêu cầu hệ thống. Được thực hiện bởi nhóm kiểm thử.
66. Mutation Testing: Kiểm thử hoán chuyển là phương pháp kiểm thử cấu trúc phần mềm nhằm mục đích đánh giá/cải thiện tính đầy đủ của điều kiện test và ước tính số lượng lỗi có thể phát sinh với hệ thống trong quá trình test. Được thực hiện bởi tester và developer.
67. Modularity driven testing: Kiểm thử mô đun là một framework kiểm thử tự động trong đó các mô đun nhỏ, độc lập của kịch bản tự động hóa được phát triển cho ứng dụng dưới quá trình kiểm thử. Được thực hiện bởi Tester.
68. Non-functional Testing: Kiểm thử phi chức năng đề cập đến các khía cạnh của phần mềm có thể không liên quan đến một chức năng cụ thể hoặc hành động người dùng, chẳng hạn như khả năng mở rộng và hiệu suất khác, hành vi dưới những hạn chế hoặc bảo mật nhất định. Có thể được thực hiện bởi các kỹ sư hiệu năng hoặc đội test.
f2.png
69. Negative Testing: Để đảm bảo hệ thống chạy trơn tru và ổn định, chúng ta chỉ test những trường hợp bình thường và hợp lệ là chưa đủ. Vì vậy, để đảm bảo hệ thống chạy có thể xử lý được những trường hợp ngoại lệ ta cần test thêm những ngữ cảnh không hợp lệ. Việc test những ngữ cảnh không hợp lệ gọi là negative testing. Được thực hiện bởi nhóm kiểm thử thủ công hoặc tự động.
70. Operational Testing: Kiểm thử chấp nhận hoạt động (OAT) là một kỹ thuật kiểm thử được tiến hành nhằm xác nhận sự sẵn sàng hoạt động (trước khi release) của sản phẩm hoặc ứng dụng dưới quá trình test. Kỹ thuật này chủ yếu dựa trên sự sẵn sàng hoạt động của hệ thống sao cho gần giống với môi trường production. Được thực hiện bởi Tester.
71. Orthogonal Array Testing: Kiểm thử mảng trực giao là một loại kiểm thử hộp đen - kiểm tra các trường hợp tối ưu hóa kỹ thuật được sử dụng khi hệ thống được thử nghiệm có các dữ liệu đầu vào khổng lồ.
72. Pair testing: Kiểm thử theo cặp là cách tiếp cận một quá trình kiểm thử thiết kế bởi có hai tester kiểm tra được điều tương tự tại cùng một thời gian và địa điểm, liên tục trao đổi ý tưởng. Loại kiểm thử này có thể được kết hợp bởi Tester - Developer hoặc Tester - Business Analyst hoặc 2 testers.
73. Passive Testing: Kiểm tra kỹ thuật: bao gồm trong việc theo dõi kết quả của một hệ thống đang chạy mà không tác động vào hệ thống. Được thực hiện bởi tester.
74. Performance Testing: Kiểm thử hiệu năng là một phương tiện để đảm bảo chất lượng (QA), được thực hiện để xác định hệ thống thực hiện một khối lượng công việc cụ thể nhanh thế nào. Có thể dùng để xác nhận và xác minh những thuộc tính chất lượng khác của hệ thống như là khả năng mở rộng, độ tin cậy và sử dụng tài nguyên.
agile-graph-5.png
75. Parallel Testing: Kiểm thử song song là kiểm tra khả năng tương thích của hệ thống mới được phát triển với hệ thống cũ. Thực hiện bởi Tester.
76. Path Testing: Kiểm tra đường dẫn là một phương pháp kiểm tra cấu trúc liên quan đến việc sử dụng mã nguồn của một chương trình để tìm ra tất cả các đường dẫn thực thi tốt. Thực hiện bởi developer.
77. Penetration Testing: Kiểm thử thâm nhập là một loại kiểm tra an ninh dùng để kiểm tra các khu vực không an toàn của hệ thống hoặc ứng dụng. Phương pháp mà đánh giá sự an toàn của một hệ thống máy tính hoặc mạng bằng cách mô phỏng một cuộc tấn công từ một nguồn độc hại. Tạo ra bởi công ty kiểm thử thâm nhập chuyên ngành.
78. Qualification Testing: Là loại kiểm thử với mục đích kiểm tra lại các thông số kỹ thuật của phiên bản trước, thường được thực hiện bởi dev cho người tiêu dùng, để chứng minh rằng các phần mềm đáp ứng yêu cầu quy định của nó.
79. Ramp Testing: Loại thử nghiệm bao gồm việc nâng cao một tín hiệu đầu vào liên tục cho đến khi hệ thống bị phá vỡ. Có thể được thực hiện bởi tester hoặc dev.
80. Regression Testing: Kiểm thử hồi quy là loại kiểm thử phần mềm tìm cách để phát hiện ra các lỗi phần mềm sau khi thay đổi chương trình (ví dụ như sửa lỗi hoặc chức năng mới) đã được thực hiện, bởi việc kiểm tra lại chương trình.
Regression-Testing-in-Agile-Scenario.png
81. Recovery Testing: Kiểm thử phục hồi: là một loại kiểm thử phi chức năng, kiểm tra kỹ thuật để đánh giá một hệ thống phục hồi như thế nào từ sự cố, lỗi phần cứng, hoặc các vấn đề nghiêm trọng khác.
82. Requirements Testing: Kiểm tra các yêu cầu: xác nhận rằng yêu cầu này là chính xác, đầy đủ, rõ ràng, và hợp lý; phù hợp và cho phép thiết kế một bộ các test case cần và đủ của những yêu cầu. Được thực hiện bởi đội ngũ QA.
83. Security Testing: tester phải rà soát, tìm những lỗ hổng của hệ thống mà từ những lỗ hổng đó hacker có thể xâm nhập, phá hỏng hoặc làm sai lệch hệ thống → yêu cầu của loại test này đòi hỏi tester phải có 1 kiến thức nhất định về Security.
84. Sanity Testing: Sanity testing là kiểu test dựa trên việc đánh giá ước lượng tính phù hợp của yêu cầu hoặc sự tính toán một cách nhanh chóng. Ví dụ như trong lĩnh vực toán học, khi lấy 3 nhân cho 9, ta phải kiểm tra rằng tổng các chữ số của kết quả phải chia hết cho 3 hoặc 9. Được thực hiện bởi tester.
AAEAAQAAAAAAAAZRAAAAJGY1OTAxZDNlLWNkN2EtNGNkOS1hNTcyLWZkNWNiNmNkMDJlYQ.png
85. Scenario Testing: Một kịch bản thử nghiệm là một kịch bản được trình bày từ quan điểm người dùng cuối và dựa trên kịch bản này, các thử nghiệm được tiến hành.Trong thử nghiệm kịch bản, tester đặt mình vào người dùng cuối và tìm ra các kịch bản thực tế.
86. Statement Testing: Là loại kiểm thử hộp trắng đáp ứng các tiêu chí mỗi câu lệnh trong một chương trình được thực hiện ít nhất một lần trong chương trình kiểm thử. Thường được thực hiện bởi dev.
87. Scalability Testing: Kiểm tra khả năng mở rộng là kiểm tra hiệu suất hoạt động điều tra khả năng của một hệ thống để phát triển bằng cách tăng khối lượng công việc cho mỗi người dùng, hoặc số lượng người dùng đồng thời, hoặc kích thước của một cơ sở dữ liệu. Là một loại kiểm thử phi chức năng, là loại nhỏ trong kiểm thử hiệu suất.
88. Static Testing: Là một cách gọi của quá trình review code và các tài liệu của dự án. Đây là hình thức test mà không cần chạy thử phần mềm. Phương pháp này sử dụng giấy, bút để kiểm tra lần lượt từng logic, ngay sau khi lập trình xong. Chủ yếu kiểm tra tính đúng đắn của các dòn code, thuật toán và các tài liệu đặc tả. Thực hiện bởi Developer, Code Reviewer, Business Analysts.
89. Stability Testing: Là kỹ thuật test nhằm xác minh sự ổn định của phần mềm qua việc kiểm tra khả năng chạy liên tục của ứng dụng trong hoặc hơn khoảng thời gian có thể chấp nhận được. Kiểm tra xem tại giới hạn nào thì ứng dụng bị crash. Là một phần của performance test, cũng thường được gọi là Load testing hoặc Endurance testing (test khả năng chịu đựng). Thực hiện bởi performance tester/ engineer.
90. Smoke Testing: Là kiểu test mở đầu cho quá trình test, được thực hiện ngay khi code được build trên môi trường test. Kiểu này cơ bản giống như kiểu Adhoc testing: kiểm tra xem phần mềm có sẵn sàng cho việc test chưa, có đủ môi trường cho việc test chưa? Kiểm tra đại khái các thành phần cơ bản của hệ thống phần mềm để xem rằng các chức năng chính có bị bất thường hay không? Sau khi test smoke, các tester sẽ thực hiện test khả năng thực hiện của các chức năng. Thực hiện bởi tester.
91. Stress Testing: Stress testing là một hình thức kiểm thử được sử dụng để xác định tính ổn định của một hệ thống phần mềm. Là kiểu test kiểm tra thời gian đáp lại người dùng với số lượng người dùng bất kỳ trong nhiều ngữ cảnh khác nhau của cùng một ứng dụng tại cùng một thời điểm. Nó liên quan đến những kiểm thử vượt quá khả năng bình thường của hệ thống, thường để xác định các điểm phá vỡ của hệ thống, để quan sát các kết quả khi vượt qua ngưỡng giới hạn.Thực hiện bởi các kỹ sư hệ thống, Testers.
StressTesting.png
92. Storage Testing: Là loại test nhằm xác minh chương trình qua việc kiểm tra các file dữ liệu có được lưu trữ trong các thư mục chính xác hay không? Kiểm tra xử lý của ứng dụng trong trường hợp thiếu không gian bộ nhớ thì có bị chấm dứt bất ngờ hay không? Ngoài ra còn xác định việc ứng dụng sử dụng bộ nhớ có nhiều hơn so với ước tính hay không, có khả năng gây đầy bộ nhớ và làm tăng thời gian chết hay không? Thực hiện bởi Tester.
93. Structural Testing: Là một tên gọi khác của white box testing. Hay thường được gọi là clear box testing, hoặc cũng được biết đến như glass box testing. Được thực hiện bởi developers đã tạo ra code nhằm kiểm tra tính đúng đắn của các dòng code và đảm bảo các xử lý của từng hàm, từng chức năng riêng lẻ được thực hiện đúng theo yêu cầu.
94. System Testing: Là quá trình thử nghiệm một hệ thống phần cứng và phần mềm tích hợp với nhau một cách hoàn chỉnh để xác minh rằng hệ thống đáp ứng được các yêu cầu về chức năng và kỹ thuật.Thời điểm thực hiện: Sau khi tester hoàn thành công việc test ứng dụng ở môi trường test (chỉ test với dữ liệu test, không test trên dữ liệu thật) thì ứng dụng phải được test trên môi trường thật. Vì trong môi trường test, một vài trường hợp không thể test được hoặc phải dùng thao tác giả. Khi ứng dụng chạy trên môi trường thật, cơ sở dữ liệu khác nhau, một số thao tác có thể không làm việc như mong đợi.
Người thực hiện: Testers. Môi trường: cả môi trường phát triển và môi trường thật.
95. System integration Testing: Là quá trình kiểm tra tương tác giữa các hệ thống khác nhau khi cùng được cài đặt và chạy trên cùng một môi trường. Được thực hiện sau khi thực hiện System test. Nó xác minh sự thi hành đúng của các thành phần của phần mềm cũng như giao diện thích hợp giữa các thành phần. Thực hiện bởi Tester.
96. Top Down Integration Testing: Là kỹ thuật test dựa trên việc xây dựng cấu trúc chương trình. Trong đó các module của phần mềm được tích hợp bằng cách di chuyển theo chiều hướng xuống theo trình tự kiểm soát cấp bậc, bắt đầu từ module chính tới các module phụ. Khi tích hợp từ trên xuống thì khung tổng thể của hệ thống được phát triển trước, các chức năng thành phần gắn vào sau.(trái ngược với Bottom up integration: Tích hợp các thành phần có cấu trúc bên dưới trước như: dịch vụ chung, mạng, truy cập cơ sở dữ liệu, sau đó gắn thêm các thành phần chức năng). Được thực hiện bởi các tester.
97. Thread Testing: Thread Testing là một kỹ thuật test phần mềm được sử dụng trong giai đoạn test integration sớm để kiểm tra khả năng hoạt động của các chức năng chính. Loại kỹ thuật này rất hữu ích khi test ứng dụng có sử dụng kiến trúc client server. Được thực hiện bởi các tester.
Thread-Testing.png
98. Unit Testing: Là kiểu test kiểm tra code xem liệu chức năng nó đang thực hiện có đúng cách hay không theo như yêu cầu. Được thực hiện bởi developers.
99. Upgrade Testing: Được thực hiện khi có phiên bản mới có những tính năng mới được tạo ra dựa trên một phiên bản cũ. Đây là kỹ thuật test nhằm xác minh rằng phiên bản mới được nâng cấp, hoạt động đúng và không thách thức người dùng trong việc học cách sử dụng. Được thực hiện bởi các tester.
100. User Interface Testing: Là việc kiểm tra ứng dụng thông qua giao diện đồ họa (GUI) để kiểm tra giao diện của ứng dụng có đáp ứng được yêu cầu về thiết kế cũng như các hoạt động của từng thành phần trên giao diện đó (Click button, link...). Được thực hiện bởi các tester.
101. Usability Testing: Là kỹ thuật test xác minh ứng dụng có khả năng ứng dụng cao và dễ sử dụng: người sử dụng có thể học để thao tác, input dữ liệu, giải thích kết quả của hệ thống hoặc các thành phần một cách dễ dàng. Giao diện thân thiện với người dùng: màu sắc, font chữ, size chữ, ngữ pháp câu chữ… Người thực hiện: end user.
102. Volume Testing: Volume testing đề cập tới việc kiểm thử phần mềm ứng dụng với một lượng dữ liệu nhất định. Số lượng này có thể là kích thước cơ sở dữ liệu hoặc nó cũng có thể là kích thước của 1 tập tin giao tiếp là đối tượng của volume testing (định nghĩa trong các thuật ngữ chung). Thực hiện bởi performance engineer/tester.
103. Vulnerability Testing: Là một loại test bảo mật, có mục đích để ngăn chặn vấn đề có thể ảnh hưởng đến tính toàn vẹn ứng dụng và ổn định. Được thực hiện bởi tester thông thường hoặc một đơn vị test chuyên biệt.
104. White box Testing: Là kỹ thuật test dựa trên kiến thức về logic bên trong mã nguồn của một ứng dụng và bao gồm các loại test như coverage of code statements, branches, paths, conditions ( độ phủ của các dòng lệnh, test nhánh, test đường dẫn, test điều kiện).Thực hiện bởi Developers.
white_box_testing.jpg
105. Workflow Testing: Workflow là một kịch bản mô phỏng tiến trình hoạt động của chức năng nào đó hay nghiệp vụ nào đó được dự kiến sử dụng bởi người dùng cuối. Nó bao gồm nhiều bước thực hiện để đạt được kết quả mong muốn của chức năng đó. Test theo workflow là quá trình đảm bảo mỗi tiến trình làm việc phản ánh chính xác các business process. Loại test này phù hợp cho các ứng dụng workflow-based applications. Được thực hiện bởi Tester.
Trên đây là danh sách giới thiệu 100 khái niệm test dành cho các Tester. Trong số các loại test này, có thể có loại test mà bạn đã biết, cũng có thể có loại test bạn đã từng nghe nhưng chưa biết tên, và cũng có những loại test bạn chưa từng biết đến. Bài viết chỉ dừng lại ở việc giới thiệu khái niệm và mục đích của các loại test này, hi vọng nó sẽ là một cẩm nang hữu ích cho việc tra cứu đối với những ai đang thực hiện công việc test cũng như những ai có định hướng đi lên con đường tester chuyên nghiệp.
Bài viết khảo từ tài liệu dưới đây: http://www.guru99.com/types-of-software-testing.html

MKRdezign

Contact Form

Name

Email *

Message *

Powered by Blogger.
Javascript DisablePlease Enable Javascript To See All Widget