Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/accenture/bdd-for-all
Flexible and easy to use library to enable your behavorial driven development (BDD) teams to easily collaborate while promoting automation, transparency and reporting.
https://github.com/accenture/bdd-for-all
agile-development api bdd ci-cd cucumber ddd integration-testing microservices reactive restful soap tdd test-automation test-automation-framework test-driven-development testing
Last synced: 3 months ago
JSON representation
Flexible and easy to use library to enable your behavorial driven development (BDD) teams to easily collaborate while promoting automation, transparency and reporting.
- Host: GitHub
- URL: https://github.com/accenture/bdd-for-all
- Owner: Accenture
- License: other
- Created: 2019-02-01T13:20:45.000Z (almost 6 years ago)
- Default Branch: develop
- Last Pushed: 2023-06-14T22:25:51.000Z (over 1 year ago)
- Last Synced: 2024-10-11T03:02:31.232Z (3 months ago)
- Topics: agile-development, api, bdd, ci-cd, cucumber, ddd, integration-testing, microservices, reactive, restful, soap, tdd, test-automation, test-automation-framework, test-driven-development, testing
- Language: Java
- Homepage:
- Size: 22 MB
- Stars: 51
- Watchers: 14
- Forks: 22
- Open Issues: 7
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
**Quick Links:** [User Guide](docs/USERGUIDE.md) | [Running](docs/RUNNING.md) | [Grammar](docs/GRAMMAR.md)
[![Builds](https://github.com/Accenture/bdd-for-all/actions/workflows/maven.yml/badge.svg)](https://github.com/Accenture/bdd-for-all/actions/workflows/maven.yml) [![Maven Central](https://maven-badges.herokuapp.com/maven-central/com.accenture.testing.bdd/bdd-for-all/badge.svg)](https://maven-badges.herokuapp.com/maven-central/com.accenture.testing.bdd/bdd-for-all)
**Latest builds can be found on [Sonatype](https://oss.sonatype.org/#nexus-search;quick~bdd-for-all)**
![Logo](docs/samples/bdd-white-logo.png)
No longer do your business, development and testing teams need to translate each others requirements and reports into something else to do their job. This natural language, [behavior-driven development (BDD)](https://en.wikipedia.org/wiki/Behavior-driven_development) library exists to simplify the documenting of requirements and the testing of your API's.
Built on Cucumber and Rest Assured, this library provides a [standard grammar](docs/GRAMMAR.md) (based on Gherkin) that all teams within your organization can use to relay requirements and test your applications.
*Example*
```gherkin
Given I am a JSON API consumer
And I am executing test "RSJ2"
When I request GET "/json/users"
Then I should get a status code of 200
And the response value of "users[0].email" should equal "[email protected]"
And the response value of "users[0].address.city" should not equal "Boston"
```Although there are libraries like Karate and others that provide similar functionality, they are focused mainly on technical users, which means your Product/Solution Owners and SME's are still writing their own docs.
This library was born out of this frustration.
### Why BDD For All?
Requirements, always being interpreted from one document format (user story, technical docs, test cases, etc...) to another, create an additional overhead. Even worse, things often get lost or misinterpreted in translation. We don't have time for that in one or two week sprints.
This library provides a lot of help out of the box to fix this...
* Simplifies and streamlines your Test Driven Development (TDD) flows.
* Simple [integration with build tools](docs/RUNNING.md#running) (Maven, Gradle, & SBT) as well as your DevOps pipelines (Jenkins, Bamboo, CircleCI, etc...).
* Test against any API's [regardless of language or platform](docs/RUNNING.md#running-stand-alone).
* Standard, well tested [step definitions](docs/GRAMMAR.md) that are easy to read/write for the entire business.
* Create complex flows with [request chaining](docs/CHAINING.md) (e.g. search for and then edit record).
* Data generation, supporting over 40 locales out of the box
* Run within [your project](docs/RUNNING.md#running) or as a [command line](docs/RUNNING.md#running-stand-alone) program
* Option to log all requests as [cURLs](docs/OTHERFEATURES.md#curl-logging) to import into your favorite tools (postman, soapUI and more)
* Supports complex [Groovy GPath](docs/GPATH.md) expressions for those cases that require additional complexity
* Easy to use with any test framework ([JUnit](docs/RUNNING.md#running), TestNG, etc...) and works as a standalone library.
* Tests count towards your [code coverage](docs/OTHERFEATURES.md#jacoco-code-coverage), reducing the need for unit tests.
* Simple [intuitive reporting](docs/REPORTING.md) out of the box.
* [Expressions](docs/OTHERFEATURES.md#running-select-tests-aka-tagging) that allow you easily choose what tests to run (e.g. smoke, regression, etc...).## How's it Work?
In most environments, contributors - which include Product Owners, Subject Matter Experts, Architects, Solution Owner/Architects, Tech/Team Leads, and more - create [scenarios](docs/SCENARIOS.md) which are added to [feature files](docs/FEATURES.md). In most cases these are added to existing project repositories (or newly created ones).
The developer then reviews the requirements (or acceptance criteria) and creates functionality to support, while running those scnearios as as tests with every change to confirm that there's been no regressions and that the feature is functionally complete.
![The BDD + TDD Workflow](docs/samples/bdd+tdd.png "BDD + TDD Workflow")
### Samples
The [test](src/test/resources/features/) directory has a variety of sample feature files that show how to use all the features of the library.
## Using
For the definitive guide, checkout the [User Guide](docs/USERGUIDE.md).