-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #30 from UdL-EPS-SoftArch/location-scenarios
Location Features
- Loading branch information
Showing
8 changed files
with
374 additions
and
5 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
102 changes: 102 additions & 0 deletions
102
src/test/java/cat/udl/eps/softarch/demo/steps/CreateLocationStepsDefs.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,102 @@ | ||
package cat.udl.eps.softarch.demo.steps; | ||
|
||
import cat.udl.eps.softarch.demo.domain.Location; | ||
import cat.udl.eps.softarch.demo.repository.LocationRepository; | ||
import io.cucumber.java.en.And; | ||
import io.cucumber.java.en.When; | ||
import org.junit.Assert; | ||
import org.springframework.beans.factory.annotation.Autowired; | ||
import org.springframework.http.HttpStatus; | ||
import org.springframework.http.MediaType; | ||
import org.springframework.http.ResponseEntity; | ||
import org.springframework.web.bind.annotation.PostMapping; | ||
import org.springframework.web.bind.annotation.RequestBody; | ||
import org.springframework.web.server.ResponseStatusException; | ||
import org.springframework.web.servlet.support.ServletUriComponentsBuilder; | ||
|
||
import java.net.URI; | ||
import java.nio.charset.StandardCharsets; | ||
import java.util.Arrays; | ||
import java.util.List; | ||
import java.util.Map; | ||
|
||
import static org.assertj.core.api.Assertions.assertThat; | ||
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.post; | ||
import static org.springframework.test.web.servlet.result.MockMvcResultHandlers.print; | ||
|
||
|
||
public class CreateLocationStepsDefs { | ||
|
||
@Autowired | ||
private StepDefs stepDefs; | ||
|
||
@Autowired | ||
private LocationRepository locationRepository; | ||
|
||
public static String newResourceUri; | ||
|
||
@When("There is already a Location with the following details:$") | ||
public void thereIsAlreadyALocationWithTheFollowingDetails(Map<String, String> locationDetails) throws Throwable{ | ||
Location location = new Location(); | ||
location.setAddress(locationDetails.get("address")); | ||
location.setProvince(locationDetails.get("province")); | ||
location.setCity(locationDetails.get("city")); | ||
location.setPostalCode(Integer.parseInt(locationDetails.get("postalCode"))); | ||
locationRepository.save(location); | ||
} | ||
@When("I create a new Location with the following details:$") | ||
public void iCreateANewLocationWithTheFollowingDetails(Map<String, String> locationDetails) throws Throwable { | ||
Location existingLocation = locationRepository.findLocationByAddressAndProvinceAndCityAndPostalCode( | ||
locationDetails.get("address"), | ||
locationDetails.get("province"), | ||
locationDetails.get("city"), | ||
Integer.parseInt(locationDetails.get("postalCode")) | ||
); | ||
|
||
if (existingLocation == null) { | ||
|
||
Location location = new Location(); | ||
location.setAddress(locationDetails.get("address")); | ||
location.setProvince(locationDetails.get("province")); | ||
location.setCity(locationDetails.get("city")); | ||
location.setPostalCode(Integer.parseInt(locationDetails.get("postalCode"))); | ||
|
||
// Verify and assign latitude and longitude if exists | ||
if (locationDetails.containsKey("longitude") && locationDetails.get("longitude") != null) { | ||
location.setLongitude(Float.parseFloat(locationDetails.get("longitude"))); | ||
} | ||
|
||
|
||
if (locationDetails.containsKey("latitude") && locationDetails.get("latitude") != null) { | ||
location.setLatitude(Float.parseFloat(locationDetails.get("latitude"))); | ||
} | ||
|
||
stepDefs.result = stepDefs.mockMvc.perform( | ||
post("/locations") | ||
.contentType(MediaType.APPLICATION_JSON) | ||
.content(stepDefs.mapper.writeValueAsString(location)) | ||
.characterEncoding(StandardCharsets.UTF_8) | ||
.accept(MediaType.APPLICATION_JSON) | ||
.with(AuthenticationStepDefs.authenticate())) | ||
.andDo(print()); | ||
newResourceUri = stepDefs.result.andReturn().getResponse().getHeader("Location"); | ||
|
||
} else { | ||
assertThat(existingLocation).isNotNull(); | ||
} | ||
} | ||
|
||
|
||
|
||
@And("There is (\\d+) Location created$") | ||
public void thereIsLocationCreated(int locationCreatedNum) { | ||
Assert.assertEquals(locationCreatedNum, locationRepository.count()); | ||
} | ||
|
||
@And("There is only (\\d+) Location with the details:$") | ||
public void thereIsOnlyLocationWithTheDeatils(int locationCreatedNum, Map<String, String> locationDetails) { | ||
Assert.assertEquals(locationCreatedNum, locationRepository.count()); | ||
} | ||
|
||
|
||
} |
63 changes: 63 additions & 0 deletions
63
src/test/java/cat/udl/eps/softarch/demo/steps/DeleteLocationStepsDefs.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,63 @@ | ||
package cat.udl.eps.softarch.demo.steps; | ||
|
||
|
||
import cat.udl.eps.softarch.demo.domain.Location; | ||
import cat.udl.eps.softarch.demo.repository.LocationRepository; | ||
import io.cucumber.java.en.And; | ||
import io.cucumber.java.en.When; | ||
import org.junit.Assert; | ||
import org.springframework.beans.factory.annotation.Autowired; | ||
import org.springframework.http.HttpStatus; | ||
import org.springframework.http.MediaType; | ||
import org.springframework.http.ResponseEntity; | ||
import org.springframework.web.bind.annotation.PostMapping; | ||
import org.springframework.web.bind.annotation.RequestBody; | ||
import org.springframework.web.server.ResponseStatusException; | ||
import org.springframework.web.servlet.support.ServletUriComponentsBuilder; | ||
|
||
import java.net.URI; | ||
import java.nio.charset.StandardCharsets; | ||
import java.util.Arrays; | ||
import java.util.List; | ||
import java.util.Map; | ||
|
||
import static org.assertj.core.api.Assertions.assertThat; | ||
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.*; | ||
import static org.springframework.test.web.servlet.result.MockMvcResultHandlers.print; | ||
|
||
|
||
public class DeleteLocationStepsDefs { | ||
|
||
@Autowired | ||
private StepDefs stepDefs; | ||
|
||
@Autowired | ||
private LocationRepository locationRepository; | ||
|
||
public static String newResourceUri; | ||
@When("I delete the location with the details:$") | ||
public void iDeleteTheLocationWithTheDetails(Map<String, String> locationDetails) throws Throwable{ | ||
Location existingLocation = locationRepository.findLocationByAddressAndProvinceAndCityAndPostalCode( | ||
locationDetails.get("address"), | ||
locationDetails.get("province"), | ||
locationDetails.get("city"), | ||
Integer.parseInt(locationDetails.get("postalCode")) | ||
); | ||
|
||
stepDefs.result = stepDefs.mockMvc.perform( | ||
delete("/locations/{id}", (existingLocation != null) ? existingLocation.getId() : "999") | ||
.contentType(MediaType.APPLICATION_JSON) | ||
.content(stepDefs.mapper.writeValueAsString(existingLocation)) | ||
.characterEncoding(StandardCharsets.UTF_8) | ||
.accept(MediaType.APPLICATION_JSON) | ||
.with(AuthenticationStepDefs.authenticate())) | ||
.andDo(print()); | ||
} | ||
|
||
@And("There is (\\d+) Location with the details:$") | ||
public void thereIsOnlyLocationWithTheDeatils(int locationNum, Map<String, String> locationDetails) { | ||
Assert.assertEquals(locationNum, locationRepository.count()); | ||
} | ||
|
||
|
||
} |
58 changes: 58 additions & 0 deletions
58
src/test/java/cat/udl/eps/softarch/demo/steps/GetLocationStepsDefs.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,58 @@ | ||
package cat.udl.eps.softarch.demo.steps; | ||
|
||
|
||
import cat.udl.eps.softarch.demo.domain.Location; | ||
import cat.udl.eps.softarch.demo.repository.LocationRepository; | ||
import io.cucumber.java.en.And; | ||
import io.cucumber.java.en.When; | ||
import org.junit.Assert; | ||
import org.springframework.beans.factory.annotation.Autowired; | ||
import org.springframework.http.HttpStatus; | ||
import org.springframework.http.MediaType; | ||
import org.springframework.http.ResponseEntity; | ||
import org.springframework.web.bind.annotation.PostMapping; | ||
import org.springframework.web.bind.annotation.RequestBody; | ||
import org.springframework.web.server.ResponseStatusException; | ||
import org.springframework.web.servlet.support.ServletUriComponentsBuilder; | ||
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get; | ||
|
||
import java.net.URI; | ||
import java.nio.charset.StandardCharsets; | ||
import java.util.Arrays; | ||
import java.util.List; | ||
import java.util.Map; | ||
|
||
import static org.assertj.core.api.Assertions.assertThat; | ||
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.post; | ||
import static org.springframework.test.web.servlet.result.MockMvcResultHandlers.print; | ||
|
||
|
||
public class GetLocationStepsDefs { | ||
|
||
@Autowired | ||
private StepDefs stepDefs; | ||
|
||
@Autowired | ||
private LocationRepository locationRepository; | ||
|
||
public static String newResourceUri; | ||
@When("I retrieve the location with the details:$") | ||
public void iRetrieveTheLocationWithTheDetails(Map<String, String> locationDetails) throws Throwable{ | ||
Location existingLocation = locationRepository.findLocationByAddressAndProvinceAndCityAndPostalCode( | ||
locationDetails.get("address"), | ||
locationDetails.get("province"), | ||
locationDetails.get("city"), | ||
Integer.parseInt(locationDetails.get("postalCode")) | ||
); | ||
|
||
stepDefs.result = stepDefs.mockMvc.perform( | ||
get("/locations/{id}", (existingLocation != null) ? existingLocation.getId() : "999") | ||
.contentType(MediaType.APPLICATION_JSON) | ||
.content(stepDefs.mapper.writeValueAsString(existingLocation)) | ||
.characterEncoding(StandardCharsets.UTF_8) | ||
.accept(MediaType.APPLICATION_JSON) | ||
.with(AuthenticationStepDefs.authenticate())) | ||
.andDo(print()); | ||
} | ||
|
||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,72 @@ | ||
Feature: Create Location | ||
In order to efficiently manage locations | ||
I want to be able to create a new Location record in the system | ||
|
||
Background: | ||
Given There is a registered user with username "username" and password "password" and email "user@domain.com" | ||
|
||
Scenario: Create a new Location with valid address, latitude, longitude, province, city, and postal code | ||
Given I can login with username "username" and password "password" | ||
When I create a new Location with the following details: | ||
| address | Major Street 3 | | ||
| latitude | 40.7128 | | ||
| longitude | -74.0060 | | ||
| province | Lleida | | ||
| city | Seròs | | ||
| postalCode | 25183 | | ||
Then The response code is 201 | ||
And There is 1 Location created | ||
|
||
Scenario: Create a Location with an existing address, city, province, and postal code | ||
Given I can login with username "username" and password "password" | ||
And There is already a Location with the following details: | ||
| address | Major Street 3 | | ||
| province | Lleida | | ||
| city | Seròs | | ||
| postalCode | 25183 | | ||
When I create a new Location with the following details: | ||
| address | Major Street 3 | | ||
| latitude | 41.6167 | | ||
| longitude | 0.6222 | | ||
| province | Lleida | | ||
| city | Seròs | | ||
| postalCode | 25183 | | ||
Then The response code is 200 | ||
And There is only 1 Location with the details: | ||
| address | Major Street 3 | | ||
| province | Lleida | | ||
| city | Seròs | | ||
| postalCode | 25183 | | ||
|
||
Scenario: Attempt to create a Location with address blank and latitude null | ||
Given I can login with username "username" and password "password" | ||
When I create a new Location with the following details: | ||
| address | | | ||
| longitude | -74.0060 | | ||
| province | Lleida | | ||
| city | Seròs | | ||
| postalCode | 25183 | | ||
Then The response code is 400 | ||
And There is 0 Location created | ||
|
||
Scenario: Attempt to create a Location with longitude null and latitude null | ||
Given I can login with username "username" and password "password" | ||
When I create a new Location with the following details: | ||
| address | Major Street 3 | | ||
| province | Lleida | | ||
| city | Seròs | | ||
| postalCode | 25183 | | ||
Then The response code is 201 | ||
And There is 1 Location created | ||
|
||
Scenario: Attempt to create a Location without being logged in | ||
Given I'm not logged in | ||
When I create a new Location with the following details: | ||
| address | Major Street 3 | | ||
| latitude | 40.7128 | | ||
| longitude | -74.0060 | | ||
| province | Lleida | | ||
| city | Seròs | | ||
| postalCode | 25183 | | ||
Then The response code is 401 | ||
And There is 0 Location created |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
Feature: Delete Location | ||
In order to delete an existing Location | ||
As a user with appropriate permissions | ||
I want to be able to delete the Location details of a shelter | ||
|
||
Background: | ||
Given There is a registered user with username "username" and password "password" and email "user@email.com" | ||
And There is already a Location with the following details: | ||
| address | Major Street 3 | | ||
| province | Lleida | | ||
| city | Seròs | | ||
| postalCode | 25183 | | ||
|
||
|
||
Scenario: Delete an existing Location details | ||
Given I can login with username "username" and password "password" | ||
When I delete the location with the details: | ||
| address | Major Street 3 | | ||
| province | Lleida | | ||
| city | Seròs | | ||
| postalCode | 25183 | | ||
Then The response code is 200 | ||
And There is 0 Location with the details: | ||
| address | Major Street 3 | | ||
| province | Lleida | | ||
| city | Seròs | | ||
| postalCode | 25183 | | ||
|
||
Scenario: Delete Location when I am not logged in | ||
Given I'm not logged in | ||
When I delete the location with the details: | ||
| address | Major Street 3 | | ||
| province | Lleida | | ||
| city | Seròs | | ||
| postalCode | 25183 | | ||
Then The response code is 401 | ||
And There is 1 Location with the details: | ||
| address | Major Street 3 | | ||
| province | Lleida | | ||
| city | Seròs | | ||
| postalCode | 25183 | |
Oops, something went wrong.