Topicos Recents

Problemas com o nightwatch
Geral1 
Ajuda com Curso
Geral5 
Como você mapearia este elemento?
Geral12 
Questionário sobre testes automatizados em aplicativos móveis
Geral4 
A arte de desenvolver testes  Cucumber + Capybara
Artigos e Tutoriais44 
Como abrir todos os link de uma página
Geral2 
QA Analyst/Project Lead (Florianópolis/Remote)
Vagas1 
QA Engineer  (Pinheiro)
Vagas1 
Teste de Stress
Geral5 
Tester que não programa, leia isso por favor.
Artigos e Tutoriais6 
Executar tags em features diferentes no Cucumber
Geral1 
QA, trate sua automação como software
Artigos e Tutoriais5 
[Survey]  Testes automatizados em aplicativos móveis
Geral6 
Cucumber para javascript Duvida
Artigos e Tutoriais2 
Vagas QA PL e Sr  São Paulo
Vagas1 
Episode 010  The Automate or Die Special  The Evil Tester Show
Feed de Blogs e Posts2 
Ruby In Tests
Artigos e Tutoriais7 
Livros
Geral19 
Anexar printscreen ao Allure Report
Geral28 
Vaga para Analistas de Testes Pleno.
Vagas1
What is Boundary Value Analysis? Software Testing Technique explained with real world examples.

TLDR; Boundary Value Analysis is a simple technique and with additional exploration can add value in the real world.
Boundary Value Analysis (BVA) is one of the most basic test techniques that we learn.
Often taught at the same time as Equivalence Partitioning.
In this post I explain the technique and use it it find a bug in Chrome and Firefox.
Boundary Value Analysis Technique
BVA if often applied to input fields or anywhere that ranges of input are used where there is some maximum and minimum validation.
e.g. if I have an input field which accepts values from 10 to 100 then 10 would be the minimum, 100 would be the maximum.
I can model that as. a Set of Ordered sets:
{ x <= 9}{10 > 100}{101 to infinity}
Above is a model containing 3 sets, the first set
 all the values less than 10
The second set:
 values from 10 to 100 inclusive
The third set
 values greater than 100
The values on the boundaries between the sets are (9,10) and (100,101) and they are the basic values that BVA would give me when applied as a technique.
Another way to consider this is as 1,0 and +1 for the valid boundary maximum and minimum range values.
The maximum and minimum values are 10 and 100 which gives me:
 10 1 = 9
 10 + 0 = 10
 10 + 1 = 11 (optional extension)
 100 1 = 99 (optional extension)
 100 + 0 = 100
 100 + 1 = 101
The additional values within the same equivalence class are optional and are an extension i.e. 11 (+1 on the minimum range value) and 99 (1 on the maximum range value).
Traditional Boundary Value Analysis Demonstrated
Real World Application of Boundary Value Analysis
In the real world we use Boundary Value Analysis as a starting point, but we also have to consider:
 input validation
 server side validation
 use of the value by later processing
 formatting and representation of values
 assumptions in the BVA model
 implementation
When I was looking at the sample application in the Chrome I discovered that some of my assumptions were incorrect.
Not all nonnumeric characters were excluded, I could type “e”, “”, “+”, and “.”
This led me to explore other representations of my valid boundery values, which might have caused an error in a downstream system:
 “10.0”
 “2e1” (which is 2 exponential 1, i.e. 2 * 10^1 = 20)
 “100.0000000000000001” which is invalid, but reported as valid in Chrome and Firefox
This is demonstrated in the following video where the exploration around BVA found a defect in Chrome and Firefox.
Boundary Value Analysis is a Heuristic
Boundary Value Analysis is technique driven from the Heuristics:

errors happen at the edges

watch out for off by one errors
The technique concentrates on the off by one errors.
The heuristic of errors at edges is much more generic and applies to any model involving bordering.
I created a video explaining the heuristic nature of boundary value analysis on Patreon.
https://www.patreon.com/posts/24196729
The page I used to demonstrate the technique has been uploaded here
https://eviltester.com/2019/01/whatisboundaryvalueanalysis.html