/java-cucumber

A port of Specflow's Calculator example to Cucumber-JVM in order to solve BeeCrowd statements.

Primary LanguageJavaGNU Affero General Public License v3.0AGPL-3.0

Gherkin By Example (java-cucumber)

Github Actions Quality Gate Status

This is a solution to some BeeCrowd problems using Gherkin specifications.

Problem Statements

Problem statements can be found at:

Solutions

Bee 1001 example solutions written in Java and other programming languages can be found here: https://www.beecrowd.com.br/judge/pt/faqs/about/examples.

If you are learning about computer programming, read solutions only after you have written your own solution.

If you are learning about program specification, first read problem statements and then read features files.

If you are learning about program testing, first read feature files and then read Java code with testing steps.

The solution process presented here adopts a behaviour-driven development style. The code also adopts a domain-driven style using Java language. The original problem statement is first modelled using Gherkin language.

Two levels of modelling are adopted: system level and domain level, each level has its own Gherkin specification.

For instance, a domain-oriented solution is presented here: https://github.com/gherkin-by-example/java-cucumber/blob/main/src/main/java/br/masmangan/beecrowd/bee1001 This solution adopts one boundary class (Main.java) and an auxiliary class (Greeting.java).

At the system level the behaviour is described as a text-oriented input and output. This behaviour verifies that the solution can be accepted by BeeCrowd Online Judge.

At the domain level the behaviour description adopts a more conceptual style, independent of a system interface. This second level adds a separation of concerns between boundary and model.

Gherkin specification and solution are a port from Specflow guide.

Testing code against specifications

git clone https://github.com/gherkin-by-example/java-cucumber.git
cd java-cucumber
mvn test