SlideShare a Scribd company logo
1 of 25
Kiểm thử và
đảm bảo chất lượng phần mềm
Kiểm thử giá trị biên
1
Nội dung
•Kiểm thử hàm
• Kiểm thử giá trị biên
• Kiểm thử lớp tương đương
• Kiểm thử bảng quyết định
• ...
2
Tổng quan
•Các chương trình có thể coi là một hàm (toán học)
–Các đầu vào chương trình là miền xác định của hàm
–Các đầu ra là miền giá trị của hàm
•Phân tích giá trị biên (boundary value analysis -
BVA) là kỹ thuật kiểm thử hàm phổ biến nhất
•Mục tiêu của kiểm thử hàm là sử dung kiến thức về
hàm để xác định các ca kiểm thử
• Trước kia chủ yếu tập trung vào miền xác định, nhưng nay
đã dựa trên cả miền giá trị của hàm để xác định ca kiểm
thử
3
Phân tích giá trị biên (BVA)
•Phân tích giá trị biên tập trung vào biên của miền
xác định để xây dựng ca kiểm thử
•Lý do là lỗi thường xảy ra ở gần các giá trị biên này
•Chương trình viết bằng ngôn ngữ không có kiểm tra
kiểu mạnh càng cần kiểm thử giá trị biên
• Javascript, php, Visual Basic
4
Đầu vào hợp lệ của chương trình P
•Từ đây chúng ta giả sử có chương trình P nhận hai
biến đầu vào là y1 và y2 thỏa mãn a ≤ y1 ≤ b and c ≤
y2 ≤ d
P(y1, y2) where a <= y1 <= b, c <= y2 <= d
•Chương trình nhận n đầu vào sẽ có không gian đầu
vào n chiều
5
Miền xác định
6
a b
c
d
y2
y1
Chọn giá trị
•Phân tích giá trị biên sẽ chọn các giá trị:
• Giá trị nhỏ nhất
• Ngay trên giá trị nhỏ nhất
• Một giá trị bình thường
• Ngay dưới giá trị lớn nhất
• Giá trị lớn nhất
•Ví dụ:
• a <= y1 <=b thì sẽ chọn a, a+1, a+b/2, b-1, b.
7
Giả thiết khiếm khuyết đơn
•Phân tích giá trị biên dựa trên nguyên lý giả định
khuyếm khuyết đơn:
–“Hỏng hóc xảy ra hiếm khi do hai (hoặc hơn) khiếm
khuyết cùng xảy ra”
•Do đó các ca kiểm thử theo phương pháp này được
tạo bằng việc lấy các giá trị bình thường của các
chiều/biên rồi lần thay mỗi chiều bằng các giá trị
cực trị như trên.
8
Các ca kiểm thử theo phân tích giá
trị biên
9
T = { <y1nom, y2min>, <y1nom, y2min+>, <y1nom, y2nom>, <y1nom, y2max->,
<y1nom, y2max+>, <y1min, y2nom>, < 1nin+, y2nom>, <y1max-, y2nom>,
<y1max, y2nom> }
a b
c
d
y2
y1
.. . ..
..
..
Các ca kiểm thử cho Triangle
Case # a b c Expected Output
1 100 100 1 Isosceles
2 100 100 2 Isosceles
3 100 100 100 Equilateral
4 100 100 199 Isosceles
5 100 100 200 Not a Triangle
6 100 1 100 Isosceles
7 100 2 100 Isosceles
8 100 100 100 Equilateral
9 100 199 100 Isosceles
10 100 200 100 Not a Triangle
11 1 100 100 Isosceles
12 2 100 100 Isosceles
13 100 100 100 Equilateral
14 199 100 100 Isosceles
15 200 100 100 Not a Triangle
10
Tổng quát hóa BVA
•Có hai cách tổng quát hóa :
–Theo số biến, sẽ có (4n +1) ca kiểm thử cho n biến
–Theo loại khoảng của biến
• Phụ thuộc ngôn ngữ lập trình
• Tính rời rạc của biến
• Tính rời rạc không bị chặn (không có cận trên và cận dưới rõ ràng)
• Biến logic
11
Hạn chế của BVA
•BVA hiệu quả với các chương trình có các đầu vào
độc lập nhau và biểu diễn đại lượng vật lý bị chặn
•BVA lấy các ca kiểm thử mà không tính đến chức
năng của hàm, hay ý nghĩa của các biến
12
Kiểm thử biên mạnh
•Kiểm thử biên mạnh (robustness testing) là một mở
rộng đơn giản của BVA
•Ngoài năm giá trị biên bổ sung thêm hai giá trị ngoài
biên:
–Giá trị ngay trên giá trị cực đại (max+) và
–Giá trị ngay dưới giá trị cực tiểu (min-).
•Mục đích chính là xem chương trình có kiểm tra giá
trị hợp lệ của đầu vào không.
13
Các ca kiểm thử biên mạnh cho P
14
a b
c
d
y2
y1
... . …
..
...
.
Kiểm thử trường hợp xấu nhất
•Điều gì xảy ra khi nhiều hơn một biến nhận các giá
trị (gần) cực trị?
•Khi các biến có tương tác với nhau thì cần kiểm tra
các bộ giá trị kết hợp các cực trị này
•Có thể kết hợp với kiểm thử mạnh để có bộ kiểm
thử trường hợp xấu nhất mạnh
15
Các ca kiểm thử trường hợp xấu
nhất cho P
16
a b
c
d
y2
y1
.. . .... . .... . ..
.. . .... . ..
Các ca kiểm thử trường hợp xấu
nhất mạnh cho P
17
a b
c
d
y2
y1
... . …... . …
... . …
... . …
... . …... . …... . …
Kiểm thử giá trị đặc biệt
•Kiểm thử giá trị đặc biệt là phương pháp được thực
hiện nhiều nhất trên thực tế, nó cũng trực quan
nhất, và không có dạng cố định nhất
•Sử dụng kỹ nghệ và kiến thức miền ứng dụng để
phán đoán và đưa ra ca kiểm thử
•Mặc dù mang tính chủ quan cao, đây vẫn là phương
pháp hiệu quả để phát hiện khiếm khuyết của
chương trình
18
Hướng dẫn áp dụng BVA
•Trừ kiểm thử giá trị đặc biệt, kiểm thử giá trị biên là
phương pháp thô sơ nhất
•Cân nhắc các tình huống để chọn phương pháp phù
hợp:
• Các biến có độc lập hay phụ thuộc nhau không
• Có cần các giá trị mạnh hay giá trị thường
• Single fault versus multiple fault assumption
•Có thể áp dụng BVA cho miền giá trị (đầu ra), hay
các biến khác trong chương trình như biến đếm
vòng lặp, biến trung gian, chỉ số mảng, con trỏ,..
19
Bài toán chia hoa hồng
•Một người bán hàng chuyên bán khóa, báng và
nòng súng trường cho một cửa hàng.
•Giá của Khóa = 45, báng = 30, và nòng = 25 đô
•Mỗi người bán hàng phải bán ít nhất một bộ đầy đủ
mỗi tháng (100 đô)
•Người bán giỏi nhất bán được 70 khóa, 80 báng, 90
nòng một tháng
20
Bài toán chia hoa hồng
•Hàng tháng mỗi người bán sẽ gửi báo cáo về cho
cửa hàng với tổng số hàng bán được cho mỗi thị
trấn anh ta đến
•Số thành phố đến được mỗi tháng là từ 1 đến 10.
•Người bán nhận được:
• 10% nếu số tiền bán được <= 1000 đô,
• 15% trên 800 đô tiếp theo, và
• 20% của số tiền vượt quá 1800.
21
Các ca kiểm thử theo khoảng đầu ra
80
90
60
60
70
72
40
22.2
33.3
Báng
Khóa
Nòng
22
Các ca kiểm thử miền giá trị
Case # Locks Stocks Barrels Sales Comm. Comments
1 1 1 1 100 10 min
2 10 10 9 975 97.5 border-
3 10 9 10 970 97 border-
4 9 10 10 955 95.5 border-
5 10 10 10 1000 100 border
6 10 10 11 1025 103.75 border+
7 10 11 10 1030 104.5 border+
8 11 10 10 1045 106.75 border+
23
Các ca kiểm thử giá trị đặc biệt
TT Khóa Báng Nòng Số bán Hoa
hồng
Ghi
chú
1 10 11 9 1005 100.75 border
+
2 18 17 19 1795 219.25 border
+
3 18 19 17 1805 221 border
+
24
Bài tập
•Áp dụng lý thuyết vào các chương trình cho các bài
toán minh họa đã xây dựng
•Viết unit test (ví dụ Junit)
25

More Related Content

Viewers also liked

Сергеева Юлия. Тitan softdigital
Сергеева Юлия. Тitan softdigitalСергеева Юлия. Тitan softdigital
Сергеева Юлия. Тitan softdigitalAKAR-NARSI
 
Ppt makalah sim kiki 2
Ppt makalah sim kiki 2Ppt makalah sim kiki 2
Ppt makalah sim kiki 2kikipratami
 
Recommendation - Jennifer Grannis Phd
Recommendation - Jennifer Grannis PhdRecommendation - Jennifer Grannis Phd
Recommendation - Jennifer Grannis PhdLi Li Muladore
 
פרופיל חברה 6
פרופיל חברה 6פרופיל חברה 6
פרופיל חברה 6Adi Schwartz
 
アウトカムと推奨文について20151104 1
アウトカムと推奨文について20151104 1アウトカムと推奨文について20151104 1
アウトカムと推奨文について20151104 1Hidemichi Yuasa
 
монтаж на винилов сайдинг чирпан - 2014
монтаж на винилов сайдинг   чирпан - 2014монтаж на винилов сайдинг   чирпан - 2014
монтаж на винилов сайдинг чирпан - 2014Dobri Ganchev
 
Инструкция по заполнению заявки на ЭЦП для ЕГАИС
Инструкция по заполнению заявки на ЭЦП для ЕГАИСИнструкция по заполнению заявки на ЭЦП для ЕГАИС
Инструкция по заполнению заявки на ЭЦП для ЕГАИСЭлектронная подпись
 
مشاكل قطاع البناء
مشاكل قطاع البناء مشاكل قطاع البناء
مشاكل قطاع البناء Abdullah Alqhahtani
 
Geografia da Europa - Geografia Física - Climatologia
Geografia da Europa - Geografia Física - ClimatologiaGeografia da Europa - Geografia Física - Climatologia
Geografia da Europa - Geografia Física - ClimatologiaCarlos Ribeiro Medeiros
 
Autoestima Femenina
Autoestima FemeninaAutoestima Femenina
Autoestima FemeninaHJTandil66
 
Las enfermedades que atacan al humano
Las enfermedades que atacan al humanoLas enfermedades que atacan al humano
Las enfermedades que atacan al humanoyolanda gomez
 
تحقیق دین ازروئے قرآن مجید Tehqeeq e-deen
 تحقیق دین ازروئے قرآن مجید  Tehqeeq e-deen تحقیق دین ازروئے قرآن مجید  Tehqeeq e-deen
تحقیق دین ازروئے قرآن مجید Tehqeeq e-deenmuzaffertahir9
 

Viewers also liked (20)

Сергеева Юлия. Тitan softdigital
Сергеева Юлия. Тitan softdigitalСергеева Юлия. Тitan softdigital
Сергеева Юлия. Тitan softdigital
 
Ppt makalah sim kiki 2
Ppt makalah sim kiki 2Ppt makalah sim kiki 2
Ppt makalah sim kiki 2
 
Recommendation - Jennifer Grannis Phd
Recommendation - Jennifer Grannis PhdRecommendation - Jennifer Grannis Phd
Recommendation - Jennifer Grannis Phd
 
Color bath
Color bathColor bath
Color bath
 
פרופיל חברה 6
פרופיל חברה 6פרופיל חברה 6
פרופיל חברה 6
 
Kehityspankkien miljardidiilit - Mahdollisuuksia suomalaisille yrityksille
Kehityspankkien miljardidiilit - Mahdollisuuksia suomalaisille yrityksilleKehityspankkien miljardidiilit - Mahdollisuuksia suomalaisille yrityksille
Kehityspankkien miljardidiilit - Mahdollisuuksia suomalaisille yrityksille
 
アウトカムと推奨文について20151104 1
アウトカムと推奨文について20151104 1アウトカムと推奨文について20151104 1
アウトカムと推奨文について20151104 1
 
Presentasi kelompok kontruktivisme
Presentasi kelompok kontruktivismePresentasi kelompok kontruktivisme
Presentasi kelompok kontruktivisme
 
монтаж на винилов сайдинг чирпан - 2014
монтаж на винилов сайдинг   чирпан - 2014монтаж на винилов сайдинг   чирпан - 2014
монтаж на винилов сайдинг чирпан - 2014
 
Инструкция по заполнению заявки на ЭЦП для ЕГАИС
Инструкция по заполнению заявки на ЭЦП для ЕГАИСИнструкция по заполнению заявки на ЭЦП для ЕГАИС
Инструкция по заполнению заявки на ЭЦП для ЕГАИС
 
Çalıştay Raporu
Çalıştay RaporuÇalıştay Raporu
Çalıştay Raporu
 
مشاكل قطاع البناء
مشاكل قطاع البناء مشاكل قطاع البناء
مشاكل قطاع البناء
 
Geografia da Europa - Geografia Física - Climatologia
Geografia da Europa - Geografia Física - ClimatologiaGeografia da Europa - Geografia Física - Climatologia
Geografia da Europa - Geografia Física - Climatologia
 
Autoestima Femenina
Autoestima FemeninaAutoestima Femenina
Autoestima Femenina
 
lista de precios specialtech Abril 5 de 2013
lista de precios specialtech Abril 5 de 2013lista de precios specialtech Abril 5 de 2013
lista de precios specialtech Abril 5 de 2013
 
Percent proportion bn#1
Percent proportion bn#1Percent proportion bn#1
Percent proportion bn#1
 
Las enfermedades que atacan al humano
Las enfermedades que atacan al humanoLas enfermedades que atacan al humano
Las enfermedades que atacan al humano
 
تحقیق دین ازروئے قرآن مجید Tehqeeq e-deen
 تحقیق دین ازروئے قرآن مجید  Tehqeeq e-deen تحقیق دین ازروئے قرآن مجید  Tehqeeq e-deen
تحقیق دین ازروئے قرآن مجید Tehqeeq e-deen
 
Cultura hindu
Cultura hinduCultura hindu
Cultura hindu
 
Dobles Hasta 20
Dobles Hasta 20Dobles Hasta 20
Dobles Hasta 20
 

Similar to 2.1 boundary-vn

Septeniinternalseminar 20140706softwaretesting-truonganhhoangtalk-final-14070...
Septeniinternalseminar 20140706softwaretesting-truonganhhoangtalk-final-14070...Septeniinternalseminar 20140706softwaretesting-truonganhhoangtalk-final-14070...
Septeniinternalseminar 20140706softwaretesting-truonganhhoangtalk-final-14070...Working in Japan
 
Luận văn thạc sĩ
Luận văn thạc sĩLuận văn thạc sĩ
Luận văn thạc sĩssuser499fca
 
Dai cuong ve phan tich dung cu truong dai hoc y thai binh
Dai cuong ve phan tich dung cu truong dai hoc y thai binhDai cuong ve phan tich dung cu truong dai hoc y thai binh
Dai cuong ve phan tich dung cu truong dai hoc y thai binhNguyen Thanh Tu Collection
 
Phân-tích-biên-tế-KTPTQĐ (1).pptx
Phân-tích-biên-tế-KTPTQĐ (1).pptxPhân-tích-biên-tế-KTPTQĐ (1).pptx
Phân-tích-biên-tế-KTPTQĐ (1).pptxssusere7f973
 
2_Phuong phap du bao toi uu (2).pdf
2_Phuong phap du bao  toi uu (2).pdf2_Phuong phap du bao  toi uu (2).pdf
2_Phuong phap du bao toi uu (2).pdfJane213811
 
Chương 6: Một Số Kỹ Thuật Kiểm Soát Quá Trình Khác (Spc Techniques)
Chương 6: Một Số Kỹ Thuật Kiểm Soát Quá Trình  Khác (Spc Techniques)Chương 6: Một Số Kỹ Thuật Kiểm Soát Quá Trình  Khác (Spc Techniques)
Chương 6: Một Số Kỹ Thuật Kiểm Soát Quá Trình Khác (Spc Techniques)Le Nguyen Truong Giang
 
Chapter 4 kiem dinh thong ke
Chapter 4 kiem dinh thong keChapter 4 kiem dinh thong ke
Chapter 4 kiem dinh thong kepmxuandba
 

Similar to 2.1 boundary-vn (12)

Septeniinternalseminar 20140706softwaretesting-truonganhhoangtalk-final-14070...
Septeniinternalseminar 20140706softwaretesting-truonganhhoangtalk-final-14070...Septeniinternalseminar 20140706softwaretesting-truonganhhoangtalk-final-14070...
Septeniinternalseminar 20140706softwaretesting-truonganhhoangtalk-final-14070...
 
Bai 6 phan tich rui ro
Bai 6 phan tich rui roBai 6 phan tich rui ro
Bai 6 phan tich rui ro
 
Cac kythuatktpm
Cac kythuatktpmCac kythuatktpm
Cac kythuatktpm
 
Cac kythuatktpm
Cac kythuatktpmCac kythuatktpm
Cac kythuatktpm
 
Luận văn thạc sĩ
Luận văn thạc sĩLuận văn thạc sĩ
Luận văn thạc sĩ
 
Slide bai giang_kiem_thu
Slide bai giang_kiem_thuSlide bai giang_kiem_thu
Slide bai giang_kiem_thu
 
HPLC-lớp N O P.ppt
HPLC-lớp N O P.pptHPLC-lớp N O P.ppt
HPLC-lớp N O P.ppt
 
Dai cuong ve phan tich dung cu truong dai hoc y thai binh
Dai cuong ve phan tich dung cu truong dai hoc y thai binhDai cuong ve phan tich dung cu truong dai hoc y thai binh
Dai cuong ve phan tich dung cu truong dai hoc y thai binh
 
Phân-tích-biên-tế-KTPTQĐ (1).pptx
Phân-tích-biên-tế-KTPTQĐ (1).pptxPhân-tích-biên-tế-KTPTQĐ (1).pptx
Phân-tích-biên-tế-KTPTQĐ (1).pptx
 
2_Phuong phap du bao toi uu (2).pdf
2_Phuong phap du bao  toi uu (2).pdf2_Phuong phap du bao  toi uu (2).pdf
2_Phuong phap du bao toi uu (2).pdf
 
Chương 6: Một Số Kỹ Thuật Kiểm Soát Quá Trình Khác (Spc Techniques)
Chương 6: Một Số Kỹ Thuật Kiểm Soát Quá Trình  Khác (Spc Techniques)Chương 6: Một Số Kỹ Thuật Kiểm Soát Quá Trình  Khác (Spc Techniques)
Chương 6: Một Số Kỹ Thuật Kiểm Soát Quá Trình Khác (Spc Techniques)
 
Chapter 4 kiem dinh thong ke
Chapter 4 kiem dinh thong keChapter 4 kiem dinh thong ke
Chapter 4 kiem dinh thong ke
 

2.1 boundary-vn

  • 1. Kiểm thử và đảm bảo chất lượng phần mềm Kiểm thử giá trị biên 1
  • 2. Nội dung •Kiểm thử hàm • Kiểm thử giá trị biên • Kiểm thử lớp tương đương • Kiểm thử bảng quyết định • ... 2
  • 3. Tổng quan •Các chương trình có thể coi là một hàm (toán học) –Các đầu vào chương trình là miền xác định của hàm –Các đầu ra là miền giá trị của hàm •Phân tích giá trị biên (boundary value analysis - BVA) là kỹ thuật kiểm thử hàm phổ biến nhất •Mục tiêu của kiểm thử hàm là sử dung kiến thức về hàm để xác định các ca kiểm thử • Trước kia chủ yếu tập trung vào miền xác định, nhưng nay đã dựa trên cả miền giá trị của hàm để xác định ca kiểm thử 3
  • 4. Phân tích giá trị biên (BVA) •Phân tích giá trị biên tập trung vào biên của miền xác định để xây dựng ca kiểm thử •Lý do là lỗi thường xảy ra ở gần các giá trị biên này •Chương trình viết bằng ngôn ngữ không có kiểm tra kiểu mạnh càng cần kiểm thử giá trị biên • Javascript, php, Visual Basic 4
  • 5. Đầu vào hợp lệ của chương trình P •Từ đây chúng ta giả sử có chương trình P nhận hai biến đầu vào là y1 và y2 thỏa mãn a ≤ y1 ≤ b and c ≤ y2 ≤ d P(y1, y2) where a <= y1 <= b, c <= y2 <= d •Chương trình nhận n đầu vào sẽ có không gian đầu vào n chiều 5
  • 7. Chọn giá trị •Phân tích giá trị biên sẽ chọn các giá trị: • Giá trị nhỏ nhất • Ngay trên giá trị nhỏ nhất • Một giá trị bình thường • Ngay dưới giá trị lớn nhất • Giá trị lớn nhất •Ví dụ: • a <= y1 <=b thì sẽ chọn a, a+1, a+b/2, b-1, b. 7
  • 8. Giả thiết khiếm khuyết đơn •Phân tích giá trị biên dựa trên nguyên lý giả định khuyếm khuyết đơn: –“Hỏng hóc xảy ra hiếm khi do hai (hoặc hơn) khiếm khuyết cùng xảy ra” •Do đó các ca kiểm thử theo phương pháp này được tạo bằng việc lấy các giá trị bình thường của các chiều/biên rồi lần thay mỗi chiều bằng các giá trị cực trị như trên. 8
  • 9. Các ca kiểm thử theo phân tích giá trị biên 9 T = { <y1nom, y2min>, <y1nom, y2min+>, <y1nom, y2nom>, <y1nom, y2max->, <y1nom, y2max+>, <y1min, y2nom>, < 1nin+, y2nom>, <y1max-, y2nom>, <y1max, y2nom> } a b c d y2 y1 .. . .. .. ..
  • 10. Các ca kiểm thử cho Triangle Case # a b c Expected Output 1 100 100 1 Isosceles 2 100 100 2 Isosceles 3 100 100 100 Equilateral 4 100 100 199 Isosceles 5 100 100 200 Not a Triangle 6 100 1 100 Isosceles 7 100 2 100 Isosceles 8 100 100 100 Equilateral 9 100 199 100 Isosceles 10 100 200 100 Not a Triangle 11 1 100 100 Isosceles 12 2 100 100 Isosceles 13 100 100 100 Equilateral 14 199 100 100 Isosceles 15 200 100 100 Not a Triangle 10
  • 11. Tổng quát hóa BVA •Có hai cách tổng quát hóa : –Theo số biến, sẽ có (4n +1) ca kiểm thử cho n biến –Theo loại khoảng của biến • Phụ thuộc ngôn ngữ lập trình • Tính rời rạc của biến • Tính rời rạc không bị chặn (không có cận trên và cận dưới rõ ràng) • Biến logic 11
  • 12. Hạn chế của BVA •BVA hiệu quả với các chương trình có các đầu vào độc lập nhau và biểu diễn đại lượng vật lý bị chặn •BVA lấy các ca kiểm thử mà không tính đến chức năng của hàm, hay ý nghĩa của các biến 12
  • 13. Kiểm thử biên mạnh •Kiểm thử biên mạnh (robustness testing) là một mở rộng đơn giản của BVA •Ngoài năm giá trị biên bổ sung thêm hai giá trị ngoài biên: –Giá trị ngay trên giá trị cực đại (max+) và –Giá trị ngay dưới giá trị cực tiểu (min-). •Mục đích chính là xem chương trình có kiểm tra giá trị hợp lệ của đầu vào không. 13
  • 14. Các ca kiểm thử biên mạnh cho P 14 a b c d y2 y1 ... . … .. ... .
  • 15. Kiểm thử trường hợp xấu nhất •Điều gì xảy ra khi nhiều hơn một biến nhận các giá trị (gần) cực trị? •Khi các biến có tương tác với nhau thì cần kiểm tra các bộ giá trị kết hợp các cực trị này •Có thể kết hợp với kiểm thử mạnh để có bộ kiểm thử trường hợp xấu nhất mạnh 15
  • 16. Các ca kiểm thử trường hợp xấu nhất cho P 16 a b c d y2 y1 .. . .... . .... . .. .. . .... . ..
  • 17. Các ca kiểm thử trường hợp xấu nhất mạnh cho P 17 a b c d y2 y1 ... . …... . … ... . … ... . … ... . …... . …... . …
  • 18. Kiểm thử giá trị đặc biệt •Kiểm thử giá trị đặc biệt là phương pháp được thực hiện nhiều nhất trên thực tế, nó cũng trực quan nhất, và không có dạng cố định nhất •Sử dụng kỹ nghệ và kiến thức miền ứng dụng để phán đoán và đưa ra ca kiểm thử •Mặc dù mang tính chủ quan cao, đây vẫn là phương pháp hiệu quả để phát hiện khiếm khuyết của chương trình 18
  • 19. Hướng dẫn áp dụng BVA •Trừ kiểm thử giá trị đặc biệt, kiểm thử giá trị biên là phương pháp thô sơ nhất •Cân nhắc các tình huống để chọn phương pháp phù hợp: • Các biến có độc lập hay phụ thuộc nhau không • Có cần các giá trị mạnh hay giá trị thường • Single fault versus multiple fault assumption •Có thể áp dụng BVA cho miền giá trị (đầu ra), hay các biến khác trong chương trình như biến đếm vòng lặp, biến trung gian, chỉ số mảng, con trỏ,.. 19
  • 20. Bài toán chia hoa hồng •Một người bán hàng chuyên bán khóa, báng và nòng súng trường cho một cửa hàng. •Giá của Khóa = 45, báng = 30, và nòng = 25 đô •Mỗi người bán hàng phải bán ít nhất một bộ đầy đủ mỗi tháng (100 đô) •Người bán giỏi nhất bán được 70 khóa, 80 báng, 90 nòng một tháng 20
  • 21. Bài toán chia hoa hồng •Hàng tháng mỗi người bán sẽ gửi báo cáo về cho cửa hàng với tổng số hàng bán được cho mỗi thị trấn anh ta đến •Số thành phố đến được mỗi tháng là từ 1 đến 10. •Người bán nhận được: • 10% nếu số tiền bán được <= 1000 đô, • 15% trên 800 đô tiếp theo, và • 20% của số tiền vượt quá 1800. 21
  • 22. Các ca kiểm thử theo khoảng đầu ra 80 90 60 60 70 72 40 22.2 33.3 Báng Khóa Nòng 22
  • 23. Các ca kiểm thử miền giá trị Case # Locks Stocks Barrels Sales Comm. Comments 1 1 1 1 100 10 min 2 10 10 9 975 97.5 border- 3 10 9 10 970 97 border- 4 9 10 10 955 95.5 border- 5 10 10 10 1000 100 border 6 10 10 11 1025 103.75 border+ 7 10 11 10 1030 104.5 border+ 8 11 10 10 1045 106.75 border+ 23
  • 24. Các ca kiểm thử giá trị đặc biệt TT Khóa Báng Nòng Số bán Hoa hồng Ghi chú 1 10 11 9 1005 100.75 border + 2 18 17 19 1795 219.25 border + 3 18 19 17 1805 221 border + 24
  • 25. Bài tập •Áp dụng lý thuyết vào các chương trình cho các bài toán minh họa đã xây dựng •Viết unit test (ví dụ Junit) 25