aspose file tools*
The moose likes Design and the fly likes BDD in the SE process Big Moose Saloon
  Search | Java FAQ | Recent Topics | Flagged Topics | Hot Topics | Zero Replies
Register / Login


Win a copy of Soft Skills this week in the Jobs Discussion forum!
JavaRanch » Java Forums » Engineering » Design
Bookmark "BDD in the SE process" Watch "BDD in the SE process" New topic
Author

BDD in the SE process

marcos robinson
Greenhorn

Joined: Nov 20, 2012
Posts: 5
Hi there,
How do you see BDD fitting in to Software Engineering processes?
Is it a process on its own? Does it crosscut parts (or activities) in the process?
Is one process better suited to BDD than another?
Thanks!
John Smart
Author
Ranch Hand

Joined: Aug 06, 2013
Posts: 43
    
    5
BDD can fit into the SE process at several levels. It is not a process on its own, but rather is a practice that fits into your existing SE process.

When used fully, it works best with Agile practices such as Scrum as it is built on fostering/encouraging ongoing conversation and collaboration between customers, BAs, developers and testers. BDD is not about defining all of the acceptance criteria upfront, but rather discovering them incrementally in collaboration with the client. However, even more predictive ("waterfall"-style) processes can benefit from the automation, communication and feedback aspects of BDD if the specifications are not expected to change too much. BDD used at the coding level can even be considered as an easier way to practice TDD, and can be practiced in almost any SE process.
Burk Hufnagel
Ranch Hand

Joined: Oct 01, 2001
Posts: 814
    
    3
John Smart wrote:BDD is not about defining all of the acceptance criteria upfront, but rather discovering them incrementally in collaboration with the client. However, even more predictive ("waterfall"-style) processes can benefit from the automation, communication and feedback aspects of BDD if the specifications are not expected to change too much.

Good point. I think that most anything that encourages direct and clear communication between the client, developers, and testers, is a very good thing - no matter what development process you're using. In addition, the idea of executable specifications means that you're not just getting agreement on behavior, you're also creating documentation that doesn't go out of date (unless you stop running your tests) so it can be trusted and can be used to bring new team members up to speed quickly.

John Smart wrote:BDD used at the coding level can even be considered as an easier way to practice TDD, and can be practiced in almost any SE process.

Using BDD at the class level is a new idea for me, and one that makes me happy to have been involved this week. Thank you, John!

Burk


SCJP, SCJD, SCEA 5 "Any sufficiently analyzed magic is indistinguishable from science!" Agatha Heterodyne (Girl Genius)
 
I agree. Here's the link: http://aspose.com/file-tools
 
subject: BDD in the SE process