BAEL-451 (#1610)
* BAEL-451 rest api test with JBehave * reformat pom * exclude live test from normal mvn test
This commit is contained in:
parent
1e8bcdccb2
commit
60332bb563
|
@ -1,164 +1,171 @@
|
||||||
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
<artifactId>rest-testing</artifactId>
|
<artifactId>rest-testing</artifactId>
|
||||||
<version>0.1-SNAPSHOT</version>
|
<version>0.1-SNAPSHOT</version>
|
||||||
|
|
||||||
<name>rest-testing</name>
|
<name>rest-testing</name>
|
||||||
|
|
||||||
<dependencies>
|
<dependencies>
|
||||||
|
|
||||||
<!-- utils -->
|
<!-- utils -->
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.google.guava</groupId>
|
<groupId>com.google.guava</groupId>
|
||||||
<artifactId>guava</artifactId>
|
<artifactId>guava</artifactId>
|
||||||
<version>${guava.version}</version>
|
<version>${guava.version}</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>commons-io</groupId>
|
<groupId>commons-io</groupId>
|
||||||
<artifactId>commons-io</artifactId>
|
<artifactId>commons-io</artifactId>
|
||||||
<version>${commons-io.version}</version>
|
<version>${commons-io.version}</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.apache.commons</groupId>
|
<groupId>org.apache.commons</groupId>
|
||||||
<artifactId>commons-lang3</artifactId>
|
<artifactId>commons-lang3</artifactId>
|
||||||
<version>${commons-lang3.version}</version>
|
<version>${commons-lang3.version}</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<!-- http client -->
|
<!-- http client -->
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.apache.httpcomponents</groupId>
|
<groupId>org.apache.httpcomponents</groupId>
|
||||||
<artifactId>httpclient</artifactId>
|
<artifactId>httpclient</artifactId>
|
||||||
<version>${httpclient.version}</version>
|
<version>${httpclient.version}</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.apache.httpcomponents</groupId>
|
<groupId>org.apache.httpcomponents</groupId>
|
||||||
<artifactId>httpcore</artifactId>
|
<artifactId>httpcore</artifactId>
|
||||||
<version>${httpcore.version}</version>
|
<version>${httpcore.version}</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<!-- marshalling -->
|
<!-- marshalling -->
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.fasterxml.jackson.core</groupId>
|
<groupId>com.fasterxml.jackson.core</groupId>
|
||||||
<artifactId>jackson-databind</artifactId>
|
<artifactId>jackson-databind</artifactId>
|
||||||
<version>${jackson.version}</version>
|
<version>${jackson.version}</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<!-- logging -->
|
<!-- logging -->
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.slf4j</groupId>
|
<groupId>org.slf4j</groupId>
|
||||||
<artifactId>slf4j-api</artifactId>
|
<artifactId>slf4j-api</artifactId>
|
||||||
<version>${org.slf4j.version}</version>
|
<version>${org.slf4j.version}</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>ch.qos.logback</groupId>
|
<groupId>ch.qos.logback</groupId>
|
||||||
<artifactId>logback-classic</artifactId>
|
<artifactId>logback-classic</artifactId>
|
||||||
<version>${logback.version}</version>
|
<version>${logback.version}</version>
|
||||||
<!-- <scope>runtime</scope> -->
|
<!-- <scope>runtime</scope> -->
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.slf4j</groupId>
|
<groupId>org.slf4j</groupId>
|
||||||
<artifactId>jcl-over-slf4j</artifactId>
|
<artifactId>jcl-over-slf4j</artifactId>
|
||||||
<version>${org.slf4j.version}</version>
|
<version>${org.slf4j.version}</version>
|
||||||
<scope>runtime</scope>
|
<scope>runtime</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency> <!-- needed to bridge to slf4j for projects that use the log4j APIs directly -->
|
<dependency> <!-- needed to bridge to slf4j for projects that use the log4j APIs directly -->
|
||||||
<groupId>org.slf4j</groupId>
|
<groupId>org.slf4j</groupId>
|
||||||
<artifactId>log4j-over-slf4j</artifactId>
|
<artifactId>log4j-over-slf4j</artifactId>
|
||||||
<version>${org.slf4j.version}</version>
|
<version>${org.slf4j.version}</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<!-- test scoped -->
|
<!-- test scoped -->
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>junit</groupId>
|
<groupId>junit</groupId>
|
||||||
<artifactId>junit</artifactId>
|
<artifactId>junit</artifactId>
|
||||||
<version>${junit.version}</version>
|
<version>${junit.version}</version>
|
||||||
<scope>test</scope>
|
<scope>test</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.hamcrest</groupId>
|
<groupId>org.hamcrest</groupId>
|
||||||
<artifactId>hamcrest-core</artifactId>
|
<artifactId>hamcrest-core</artifactId>
|
||||||
<version>${org.hamcrest.version}</version>
|
<version>${org.hamcrest.version}</version>
|
||||||
<scope>test</scope>
|
<scope>test</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.hamcrest</groupId>
|
<groupId>org.hamcrest</groupId>
|
||||||
<artifactId>hamcrest-library</artifactId>
|
<artifactId>hamcrest-library</artifactId>
|
||||||
<version>${org.hamcrest.version}</version>
|
<version>${org.hamcrest.version}</version>
|
||||||
<scope>test</scope>
|
<scope>test</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.mockito</groupId>
|
<groupId>org.mockito</groupId>
|
||||||
<artifactId>mockito-core</artifactId>
|
<artifactId>mockito-core</artifactId>
|
||||||
<version>${mockito.version}</version>
|
<version>${mockito.version}</version>
|
||||||
<scope>test</scope>
|
<scope>test</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.github.tomakehurst</groupId>
|
<groupId>com.github.tomakehurst</groupId>
|
||||||
<artifactId>wiremock</artifactId>
|
<artifactId>wiremock</artifactId>
|
||||||
<version>${wiremock.version}</version>
|
<version>${wiremock.version}</version>
|
||||||
<scope>test</scope>
|
<scope>test</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>info.cukes</groupId>
|
<groupId>info.cukes</groupId>
|
||||||
<artifactId>cucumber-java</artifactId>
|
<artifactId>cucumber-java</artifactId>
|
||||||
<version>${cucumber.version}</version>
|
<version>${cucumber.version}</version>
|
||||||
<scope>test</scope>
|
<scope>test</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>info.cukes</groupId>
|
<groupId>info.cukes</groupId>
|
||||||
<artifactId>cucumber-junit</artifactId>
|
<artifactId>cucumber-junit</artifactId>
|
||||||
<version>${cucumber.version}</version>
|
<version>${cucumber.version}</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
</dependencies>
|
|
||||||
|
|
||||||
<build>
|
<dependency>
|
||||||
<finalName>rest-testing</finalName>
|
<groupId>org.jbehave</groupId>
|
||||||
<resources>
|
<artifactId>jbehave-core</artifactId>
|
||||||
<resource>
|
<version>${jbehave.version}</version>
|
||||||
<directory>src/main/resources</directory>
|
<scope>test</scope>
|
||||||
<filtering>true</filtering>
|
</dependency>
|
||||||
</resource>
|
</dependencies>
|
||||||
</resources>
|
|
||||||
|
|
||||||
<plugins>
|
<build>
|
||||||
|
<finalName>rest-testing</finalName>
|
||||||
|
<resources>
|
||||||
|
<resource>
|
||||||
|
<directory>src/main/resources</directory>
|
||||||
|
<filtering>true</filtering>
|
||||||
|
</resource>
|
||||||
|
</resources>
|
||||||
|
|
||||||
<plugin>
|
<plugins>
|
||||||
<groupId>org.apache.maven.plugins</groupId>
|
|
||||||
<artifactId>maven-compiler-plugin</artifactId>
|
|
||||||
<version>${maven-compiler-plugin.version}</version>
|
|
||||||
<configuration>
|
|
||||||
<source>1.8</source>
|
|
||||||
<target>1.8</target>
|
|
||||||
</configuration>
|
|
||||||
</plugin>
|
|
||||||
|
|
||||||
<plugin>
|
<plugin>
|
||||||
<groupId>org.apache.maven.plugins</groupId>
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
<artifactId>maven-surefire-plugin</artifactId>
|
<artifactId>maven-compiler-plugin</artifactId>
|
||||||
<version>${maven-surefire-plugin.version}</version>
|
<version>${maven-compiler-plugin.version}</version>
|
||||||
<configuration>
|
<configuration>
|
||||||
|
<source>1.8</source>
|
||||||
|
<target>1.8</target>
|
||||||
|
</configuration>
|
||||||
|
</plugin>
|
||||||
|
|
||||||
|
<plugin>
|
||||||
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
|
<artifactId>maven-surefire-plugin</artifactId>
|
||||||
|
<version>${maven-surefire-plugin.version}</version>
|
||||||
|
<configuration>
|
||||||
<excludes>
|
<excludes>
|
||||||
<exclude>**/*IntegrationTest.java</exclude>
|
<exclude>**/*IntegrationTest.java</exclude>
|
||||||
<exclude>**/*LiveTest.java</exclude>
|
<exclude>**/*LiveTest.java</exclude>
|
||||||
</excludes>
|
</excludes>
|
||||||
</configuration>
|
</configuration>
|
||||||
</plugin>
|
</plugin>
|
||||||
|
|
||||||
</plugins>
|
</plugins>
|
||||||
|
|
||||||
</build>
|
</build>
|
||||||
|
|
||||||
<profiles>
|
<profiles>
|
||||||
<profile>
|
<profile>
|
||||||
|
@ -177,10 +184,10 @@
|
||||||
<configuration>
|
<configuration>
|
||||||
<excludes>
|
<excludes>
|
||||||
<exclude>**/*UnitTest.java</exclude>
|
<exclude>**/*UnitTest.java</exclude>
|
||||||
|
<exclude>**/*LiveTest.java</exclude>
|
||||||
</excludes>
|
</excludes>
|
||||||
<includes>
|
<includes>
|
||||||
<include>**/*IntegrationTest.java</include>
|
<include>**/*IntegrationTest.java</include>
|
||||||
<exclude>**/*LiveTest.java</exclude>
|
|
||||||
</includes>
|
</includes>
|
||||||
</configuration>
|
</configuration>
|
||||||
</execution>
|
</execution>
|
||||||
|
@ -195,37 +202,38 @@
|
||||||
</build>
|
</build>
|
||||||
</profile>
|
</profile>
|
||||||
</profiles>
|
</profiles>
|
||||||
|
|
||||||
<properties>
|
|
||||||
<!-- marshalling -->
|
|
||||||
<jackson.version>2.8.5</jackson.version>
|
|
||||||
|
|
||||||
<!-- logging -->
|
<properties>
|
||||||
<org.slf4j.version>1.7.21</org.slf4j.version>
|
<!-- marshalling -->
|
||||||
<logback.version>1.1.7</logback.version>
|
<jackson.version>2.8.5</jackson.version>
|
||||||
|
|
||||||
<!-- util -->
|
<!-- logging -->
|
||||||
<guava.version>19.0</guava.version>
|
<org.slf4j.version>1.7.21</org.slf4j.version>
|
||||||
<commons-lang3.version>3.5</commons-lang3.version>
|
<logback.version>1.1.7</logback.version>
|
||||||
<commons-io.version>2.5</commons-io.version>
|
|
||||||
|
|
||||||
<!-- testing -->
|
<!-- util -->
|
||||||
<org.hamcrest.version>1.3</org.hamcrest.version>
|
<guava.version>19.0</guava.version>
|
||||||
<junit.version>4.12</junit.version>
|
<commons-lang3.version>3.5</commons-lang3.version>
|
||||||
<mockito.version>1.10.19</mockito.version>
|
<commons-io.version>2.5</commons-io.version>
|
||||||
|
|
||||||
|
<!-- testing -->
|
||||||
|
<org.hamcrest.version>1.3</org.hamcrest.version>
|
||||||
|
<junit.version>4.12</junit.version>
|
||||||
|
<mockito.version>1.10.19</mockito.version>
|
||||||
<rest-assured.version>2.9.0</rest-assured.version>
|
<rest-assured.version>2.9.0</rest-assured.version>
|
||||||
<cucumber.version>1.2.5</cucumber.version>
|
<cucumber.version>1.2.5</cucumber.version>
|
||||||
<wiremock.version>2.4.1</wiremock.version>
|
<wiremock.version>2.4.1</wiremock.version>
|
||||||
|
|
||||||
<httpcore.version>4.4.5</httpcore.version>
|
<httpcore.version>4.4.5</httpcore.version>
|
||||||
<httpclient.version>4.5.2</httpclient.version>
|
<httpclient.version>4.5.2</httpclient.version>
|
||||||
|
|
||||||
|
<jbehave.version>4.1</jbehave.version>
|
||||||
|
|
||||||
<!-- maven plugins -->
|
<!-- maven plugins -->
|
||||||
<maven-compiler-plugin.version>3.6.0</maven-compiler-plugin.version>
|
<maven-compiler-plugin.version>3.6.0</maven-compiler-plugin.version>
|
||||||
<maven-war-plugin.version>2.6</maven-war-plugin.version>
|
<maven-war-plugin.version>2.6</maven-war-plugin.version>
|
||||||
<maven-surefire-plugin.version>2.19.1</maven-surefire-plugin.version>
|
<maven-surefire-plugin.version>2.19.1</maven-surefire-plugin.version>
|
||||||
|
|
||||||
</properties>
|
</properties>
|
||||||
|
|
||||||
</project>
|
</project>
|
|
@ -0,0 +1,45 @@
|
||||||
|
package com.baeldung.rest.jbehave;
|
||||||
|
|
||||||
|
import org.jbehave.core.configuration.Configuration;
|
||||||
|
import org.jbehave.core.configuration.MostUsefulConfiguration;
|
||||||
|
import org.jbehave.core.io.LoadFromClasspath;
|
||||||
|
import org.jbehave.core.junit.JUnitStories;
|
||||||
|
import org.jbehave.core.reporters.StoryReporterBuilder;
|
||||||
|
import org.jbehave.core.steps.InjectableStepsFactory;
|
||||||
|
import org.jbehave.core.steps.InstanceStepsFactory;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import static org.jbehave.core.io.CodeLocations.codeLocationFromClass;
|
||||||
|
import static org.jbehave.core.reporters.Format.CONSOLE;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author aiet
|
||||||
|
*/
|
||||||
|
public abstract class AbstractStory extends JUnitStories {
|
||||||
|
|
||||||
|
abstract String storyName();
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Configuration configuration() {
|
||||||
|
return new MostUsefulConfiguration()
|
||||||
|
.useStoryLoader(new LoadFromClasspath(this.getClass()))
|
||||||
|
.useStoryReporterBuilder(new StoryReporterBuilder()
|
||||||
|
.withCodeLocation(codeLocationFromClass(this.getClass()))
|
||||||
|
.withFormats(CONSOLE));
|
||||||
|
}
|
||||||
|
|
||||||
|
abstract Object stepInstance();
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public InjectableStepsFactory stepsFactory() {
|
||||||
|
return new InstanceStepsFactory(configuration(), stepInstance());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected List<String> storyPaths() {
|
||||||
|
return Arrays.asList(storyName());
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,59 @@
|
||||||
|
package com.baeldung.rest.jbehave;
|
||||||
|
|
||||||
|
import org.apache.http.HttpResponse;
|
||||||
|
import org.apache.http.client.methods.HttpGet;
|
||||||
|
import org.apache.http.client.methods.HttpUriRequest;
|
||||||
|
import org.apache.http.impl.client.HttpClientBuilder;
|
||||||
|
import org.jbehave.core.annotations.Given;
|
||||||
|
import org.jbehave.core.annotations.Then;
|
||||||
|
import org.jbehave.core.annotations.When;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
import static org.apache.commons.lang3.RandomStringUtils.randomAlphabetic;
|
||||||
|
import static org.apache.http.HttpStatus.SC_NOT_FOUND;
|
||||||
|
import static org.junit.Assert.assertTrue;
|
||||||
|
|
||||||
|
public class GithubUserNotFoundSteps {
|
||||||
|
|
||||||
|
private String api;
|
||||||
|
private String nonExistentUser;
|
||||||
|
private int githubResponseCode;
|
||||||
|
|
||||||
|
@Given("github user profile api")
|
||||||
|
public void givenGithubUserProfileApi() {
|
||||||
|
api = "https://api.github.com/users/%s";
|
||||||
|
}
|
||||||
|
|
||||||
|
@Given("a random non-existent username")
|
||||||
|
public void givenANonexistentUsername() {
|
||||||
|
nonExistentUser = randomAlphabetic(8);
|
||||||
|
}
|
||||||
|
|
||||||
|
@When("I look for the random user via the api")
|
||||||
|
public void whenILookForTheUserViaTheApi() throws IOException {
|
||||||
|
githubResponseCode = getGithubUserProfile(api, nonExistentUser)
|
||||||
|
.getStatusLine()
|
||||||
|
.getStatusCode();
|
||||||
|
}
|
||||||
|
|
||||||
|
@When("I look for $user via the api")
|
||||||
|
public void whenILookForSomeNonExistentUserViaTheApi(String user) throws IOException {
|
||||||
|
githubResponseCode = getGithubUserProfile(api, user)
|
||||||
|
.getStatusLine()
|
||||||
|
.getStatusCode();
|
||||||
|
}
|
||||||
|
|
||||||
|
static HttpResponse getGithubUserProfile(String api, String username) throws IOException {
|
||||||
|
HttpUriRequest request = new HttpGet(String.format(api, username));
|
||||||
|
return HttpClientBuilder
|
||||||
|
.create()
|
||||||
|
.build()
|
||||||
|
.execute(request);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Then("github respond: 404 not found")
|
||||||
|
public void thenGithubRespond404NotFound() {
|
||||||
|
assertTrue(SC_NOT_FOUND == githubResponseCode);
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,18 @@
|
||||||
|
package com.baeldung.rest.jbehave;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author aiet
|
||||||
|
*/
|
||||||
|
public class GithubUserNotFoundStoryLiveTest extends AbstractStory {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
String storyName() {
|
||||||
|
return "github_user_not_found.story";
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
Object stepInstance() {
|
||||||
|
return new GithubUserNotFoundSteps();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,40 @@
|
||||||
|
package com.baeldung.rest.jbehave;
|
||||||
|
|
||||||
|
import org.apache.http.entity.ContentType;
|
||||||
|
import org.jbehave.core.annotations.Given;
|
||||||
|
import org.jbehave.core.annotations.Then;
|
||||||
|
import org.jbehave.core.annotations.When;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
import static com.baeldung.rest.jbehave.GithubUserNotFoundSteps.getGithubUserProfile;
|
||||||
|
import static org.junit.Assert.assertEquals;
|
||||||
|
|
||||||
|
public class GithubUserResponseMediaTypeSteps {
|
||||||
|
|
||||||
|
private String api;
|
||||||
|
private String validUser;
|
||||||
|
private String mediaType;
|
||||||
|
|
||||||
|
@Given("github user profile api")
|
||||||
|
public void givenGithubUserProfileApi() {
|
||||||
|
api = "https://api.github.com/users/%s";
|
||||||
|
}
|
||||||
|
|
||||||
|
@Given("a valid username")
|
||||||
|
public void givenAValidUsername() {
|
||||||
|
validUser = "eugenp";
|
||||||
|
}
|
||||||
|
|
||||||
|
@When("I look for the user via the api")
|
||||||
|
public void whenILookForTheUserViaTheApi() throws IOException {
|
||||||
|
mediaType = ContentType
|
||||||
|
.getOrDefault(getGithubUserProfile(api, validUser).getEntity())
|
||||||
|
.getMimeType();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Then("github respond data of type json")
|
||||||
|
public void thenGithubRespondDataOfTypeJson() {
|
||||||
|
assertEquals("application/json", mediaType);
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,18 @@
|
||||||
|
package com.baeldung.rest.jbehave;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author aiet
|
||||||
|
*/
|
||||||
|
public class GithubUserResponseMediaTypeStoryLiveTest extends AbstractStory {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
String storyName() {
|
||||||
|
return "github_user_response_mediatype.story";
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
Object stepInstance() {
|
||||||
|
return new GithubUserResponseMediaTypeSteps();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,40 @@
|
||||||
|
package com.baeldung.rest.jbehave;
|
||||||
|
|
||||||
|
import org.apache.http.HttpResponse;
|
||||||
|
import org.apache.http.client.methods.HttpGet;
|
||||||
|
import org.apache.http.client.methods.HttpUriRequest;
|
||||||
|
import org.apache.http.impl.client.HttpClientBuilder;
|
||||||
|
import org.baeldung.rest.GitHubUser;
|
||||||
|
import org.baeldung.rest.RetrieveUtil;
|
||||||
|
import org.hamcrest.Matchers;
|
||||||
|
import org.jbehave.core.annotations.Given;
|
||||||
|
import org.jbehave.core.annotations.Then;
|
||||||
|
import org.jbehave.core.annotations.When;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
import static com.baeldung.rest.jbehave.GithubUserNotFoundSteps.getGithubUserProfile;
|
||||||
|
import static org.hamcrest.MatcherAssert.assertThat;
|
||||||
|
|
||||||
|
public class GithubUserResponsePayloadSteps {
|
||||||
|
|
||||||
|
private String api;
|
||||||
|
private GitHubUser resource;
|
||||||
|
|
||||||
|
@Given("github user profile api")
|
||||||
|
public void givenGithubUserProfileApi() {
|
||||||
|
api = "https://api.github.com/users/%s";
|
||||||
|
}
|
||||||
|
|
||||||
|
@When("I look for $user via the api")
|
||||||
|
public void whenILookForEugenpViaTheApi(String user) throws IOException {
|
||||||
|
HttpResponse httpResponse = getGithubUserProfile(api, user);
|
||||||
|
resource = RetrieveUtil.retrieveResourceFromResponse(httpResponse, GitHubUser.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Then("github's response contains a 'login' payload same as $username")
|
||||||
|
public void thenGithubsResponseContainsAloginPayloadSameAsEugenp(String username) {
|
||||||
|
assertThat(username, Matchers.is(resource.getLogin()));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,18 @@
|
||||||
|
package com.baeldung.rest.jbehave;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author aiet
|
||||||
|
*/
|
||||||
|
public class GithubUserResponsePayloadStoryLiveTest extends AbstractStory {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
String storyName() {
|
||||||
|
return "github_user_response_payload.story";
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
Object stepInstance() {
|
||||||
|
return new GithubUserResponsePayloadSteps();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,34 @@
|
||||||
|
package com.baeldung.rest.jbehave;
|
||||||
|
|
||||||
|
import org.jbehave.core.annotations.Given;
|
||||||
|
import org.jbehave.core.annotations.Then;
|
||||||
|
import org.jbehave.core.annotations.When;
|
||||||
|
|
||||||
|
import java.util.Random;
|
||||||
|
|
||||||
|
import static org.junit.Assert.assertTrue;
|
||||||
|
|
||||||
|
public class IncreaseSteps {
|
||||||
|
private int counter;
|
||||||
|
private int previousValue;
|
||||||
|
|
||||||
|
@Given("a counter")
|
||||||
|
public void aCounter() {
|
||||||
|
}
|
||||||
|
|
||||||
|
@Given("the counter has any integral value")
|
||||||
|
public void counterHasAnyIntegralValue() {
|
||||||
|
counter = new Random().nextInt();
|
||||||
|
previousValue = counter;
|
||||||
|
}
|
||||||
|
|
||||||
|
@When("the user increases the counter")
|
||||||
|
public void increasesTheCounter() {
|
||||||
|
counter++;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Then("the value of the counter must be 1 greater than previous value")
|
||||||
|
public void theValueOfTheCounterMustBe1Greater() {
|
||||||
|
assertTrue(1 == counter - previousValue);
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,38 @@
|
||||||
|
package com.baeldung.rest.jbehave;
|
||||||
|
|
||||||
|
import org.jbehave.core.configuration.Configuration;
|
||||||
|
import org.jbehave.core.configuration.MostUsefulConfiguration;
|
||||||
|
import org.jbehave.core.io.LoadFromClasspath;
|
||||||
|
import org.jbehave.core.junit.JUnitStories;
|
||||||
|
import org.jbehave.core.reporters.StoryReporterBuilder;
|
||||||
|
import org.jbehave.core.steps.InjectableStepsFactory;
|
||||||
|
import org.jbehave.core.steps.InstanceStepsFactory;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import static org.jbehave.core.io.CodeLocations.codeLocationFromClass;
|
||||||
|
import static org.jbehave.core.reporters.Format.CONSOLE;
|
||||||
|
|
||||||
|
public class IncreaseStoryLiveTest extends JUnitStories {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Configuration configuration() {
|
||||||
|
return new MostUsefulConfiguration()
|
||||||
|
.useStoryLoader(new LoadFromClasspath(this.getClass()))
|
||||||
|
.useStoryReporterBuilder(new StoryReporterBuilder()
|
||||||
|
.withCodeLocation(codeLocationFromClass(this.getClass()))
|
||||||
|
.withFormats(CONSOLE));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public InjectableStepsFactory stepsFactory() {
|
||||||
|
return new InstanceStepsFactory(configuration(), new IncreaseSteps());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected List<String> storyPaths() {
|
||||||
|
return Arrays.asList("increase.story");
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,19 @@
|
||||||
|
Meta:
|
||||||
|
|
||||||
|
Narrative:
|
||||||
|
As a user
|
||||||
|
I want to look up a non-existent user's profile on github
|
||||||
|
So that I can be sure that the username can not be found on github
|
||||||
|
|
||||||
|
Scenario: when a user checks a non-existent user on github, github would respond 'not found'
|
||||||
|
|
||||||
|
Given github user profile api
|
||||||
|
And a random non-existent username
|
||||||
|
When I look for the random user via the api
|
||||||
|
Then github respond: 404 not found
|
||||||
|
|
||||||
|
When I look for eugenp1 via the api
|
||||||
|
Then github respond: 404 not found
|
||||||
|
|
||||||
|
When I look for eugenp2 via the api
|
||||||
|
Then github respond: 404 not found
|
|
@ -0,0 +1,13 @@
|
||||||
|
Meta:
|
||||||
|
|
||||||
|
Narrative:
|
||||||
|
As a user
|
||||||
|
I want to look up a valid user's profile on github
|
||||||
|
So that I can know that github responds data of type json
|
||||||
|
|
||||||
|
Scenario: when a user checks a valid user's profile on github, github would respond json data
|
||||||
|
|
||||||
|
Given github user profile api
|
||||||
|
And a valid username
|
||||||
|
When I look for the user via the api
|
||||||
|
Then github respond data of type json
|
|
@ -0,0 +1,12 @@
|
||||||
|
Meta:
|
||||||
|
|
||||||
|
Narrative:
|
||||||
|
As a user
|
||||||
|
I want to look up a valid user's profile on github
|
||||||
|
So that I can know the login payload should be the same as username
|
||||||
|
|
||||||
|
Scenario: when a user checks a valid user's profile on github, github's response json should include a login payload with the same username
|
||||||
|
|
||||||
|
Given github user profile api
|
||||||
|
When I look for eugenp via the api
|
||||||
|
Then github's response contains a 'login' payload same as eugenp
|
|
@ -0,0 +1,15 @@
|
||||||
|
JBehave Story - An increase test
|
||||||
|
|
||||||
|
Meta:
|
||||||
|
|
||||||
|
Narrative:
|
||||||
|
As a user
|
||||||
|
I want to increase a counter
|
||||||
|
So that I can have the counter's value increase by 1
|
||||||
|
|
||||||
|
Scenario: when a user increases a counter, its value is increased by 1
|
||||||
|
|
||||||
|
Given a counter
|
||||||
|
And the counter has any integral value
|
||||||
|
When the user increases the counter
|
||||||
|
Then the value of the counter must be 1 greater than previous value
|
Loading…
Reference in New Issue