JC Session
- BDD -
Juraci Vieira
Nicholas Pufal
Vamos começar...
TDD?
Feature files (ou "especificação das
funcionalidades em linguagem natural")?
Critérios de aceitação?
Coisas óbvias são realmente óbvias?
Quantos pontos
há nesta estrela?
Com exemplos:
Dado que quero uma estrela de 8 pontos
Quando peço para o app gerar a estrela
Então temos a estrela à esquerda como resultado
Dado que quero uma estrela de 12 pontos
Quando peço para o app gerar a estrela
Então temos a estrela à esquerda como resultado
O senso comum nos engana
● O simples pode ser complexo
● Exemplos auxiliam muito na compreensão
● Exemplos como forma de iniciar uma
conversa
Precisamos de exemplos concretos para
compreender com clareza um domínio
Linha do tempo
1996
Kent Beck
(Primeiras ideias
TDD)
2001 2003 2007 2008
Manifesto Ágil
2011
Kent Beck, Martin
Fowler e outros
Dan North
JBehave
(Primeiras ideias
BDD)
RSpec
David Chelimsky,
Dan North, Aslak
Hellesoy e outros
RBehave
Dan North
Cucumber,
Gherkin
parser/standard
Aslak Hellesoy
Specification by
example
Gojko Adzic
1. Desenvolvimento
2. Testes
3. Ambas opções anteriores
Pergunta: TDD se enquadra em qual das
opções abaixo?
TDD é uma técnica de desenvolvimento
utilizada para entregar código de alta
qualidade
● Testes de regressão de baixo nível
● Design emergente (revisão e evolução
constantes do código)
TDD != Unit Testing
● Unit é um termo vago e confuso
● Faz com que os desenvolvedores tenham a
ideia de proporção 1:1
● Unit Tests são altamente dependentes da
estrutura interna
Não pense em termos de unidade e sim em
facetas de comportamento
"TDD era uma idéia fabulosa embrulhada em um
nome que fazia com que as pessoas pensassem a
partir de uma perspectiva equivocada de testes." ~
ASTELS, DAVE
"Eu decidi que deve ser possı́vel apresentar TDD
de uma forma que vá direto às suas coisas boas e
evite todas as suas armadilhas." ~ NORTH, DAN
BDD portanto foi uma evolução natural do TDD
trazendo consigo novas terminologias
● Behavior - Tests
● Expectations - Assertions
● Specification-centric - Test-centric
E como ocorre a comunicacão nos
projetos?
Livros extremamente recomendados:
Links interessantes
● A new look at Test Driven Development - Dave
Astels
● Introducing BDD - Dan North
● RSpec and Behavior-Driven Development - Dave
Astels & Steven Baker
● Stubbing Is Not Enough - Gregory Moeck
● BDD: Busting the myths - Gojko Adzic
Perguntas?
Feedbacks?

ThoughtWorks JC Session - BDD

  • 1.
    JC Session - BDD- Juraci Vieira Nicholas Pufal
  • 2.
    Vamos começar... TDD? Feature files(ou "especificação das funcionalidades em linguagem natural")? Critérios de aceitação?
  • 3.
    Coisas óbvias sãorealmente óbvias? Quantos pontos há nesta estrela?
  • 4.
    Com exemplos: Dado quequero uma estrela de 8 pontos Quando peço para o app gerar a estrela Então temos a estrela à esquerda como resultado Dado que quero uma estrela de 12 pontos Quando peço para o app gerar a estrela Então temos a estrela à esquerda como resultado
  • 5.
    O senso comumnos engana ● O simples pode ser complexo ● Exemplos auxiliam muito na compreensão ● Exemplos como forma de iniciar uma conversa
  • 6.
    Precisamos de exemplosconcretos para compreender com clareza um domínio
  • 7.
    Linha do tempo 1996 KentBeck (Primeiras ideias TDD) 2001 2003 2007 2008 Manifesto Ágil 2011 Kent Beck, Martin Fowler e outros Dan North JBehave (Primeiras ideias BDD) RSpec David Chelimsky, Dan North, Aslak Hellesoy e outros RBehave Dan North Cucumber, Gherkin parser/standard Aslak Hellesoy Specification by example Gojko Adzic
  • 8.
    1. Desenvolvimento 2. Testes 3.Ambas opções anteriores Pergunta: TDD se enquadra em qual das opções abaixo?
  • 9.
    TDD é umatécnica de desenvolvimento utilizada para entregar código de alta qualidade ● Testes de regressão de baixo nível ● Design emergente (revisão e evolução constantes do código)
  • 10.
    TDD != UnitTesting ● Unit é um termo vago e confuso ● Faz com que os desenvolvedores tenham a ideia de proporção 1:1 ● Unit Tests são altamente dependentes da estrutura interna
  • 11.
    Não pense emtermos de unidade e sim em facetas de comportamento
  • 12.
    "TDD era umaidéia fabulosa embrulhada em um nome que fazia com que as pessoas pensassem a partir de uma perspectiva equivocada de testes." ~ ASTELS, DAVE
  • 13.
    "Eu decidi quedeve ser possı́vel apresentar TDD de uma forma que vá direto às suas coisas boas e evite todas as suas armadilhas." ~ NORTH, DAN
  • 14.
    BDD portanto foiuma evolução natural do TDD trazendo consigo novas terminologias ● Behavior - Tests ● Expectations - Assertions ● Specification-centric - Test-centric
  • 17.
    E como ocorrea comunicacão nos projetos?
  • 22.
  • 23.
    Links interessantes ● Anew look at Test Driven Development - Dave Astels ● Introducing BDD - Dan North ● RSpec and Behavior-Driven Development - Dave Astels & Steven Baker ● Stubbing Is Not Enough - Gregory Moeck ● BDD: Busting the myths - Gojko Adzic
  • 24.