Ir al contenido principal

Spring Boot - Testing

Frameworks

Spring-boot-starter-test

  • Always start with the starter 
  • Integrate the above frameworks

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>

JUnit

  • For unit testing
Hamcrest


  • Matching and assertion

Mockito
  • Mock objects and verify

Spring Test

  • Testing tools & integration testing support


Creating a Test

First in src/test/java create the following class for test the Controller

package com.ericsson.project;

import org.junit.Test;

public class AppTest 
{
   @Test
    public void testApp()
    {


    }
}

  • Add the following code in testApp()
HomeController hc = new HomeController();
    String result = hc.home();
    assertEquals(result"Das boot");

Creating a Mockito Test

Mockito helps to inject dependencies
  • Create another test
  • Inject the controller
@InjectMocks
private ShipwreckController swc;
  • Inject the repository
@Mock
private ShipwreckRepository swr;

    • Initialize all the mock objects 
    @Before(value = "")
    public void nit(){
    MockitoAnnotations.initMocks(this);
    }
    • Create test method

    @Test
    public void testhipwreckGet(){
    Shipwreck sw = new Shipwreck();
    sw.setId(1L);
    when(swr.findOne(1l)).thenReturn(sw);
    Shipwreck sw2 = swc.get(1l);
    assertEquals(1l, sw2.getId().longValue());
    }

    • All Mockito Test




    package com.ericsson.project;

    import static org.junit.Assert.*;
    import static org.mockito.Mockito.*;

    import org.junit.Before;
    import org.junit.Test;
    import org.mockito.InjectMocks;
    import org.mockito.Mock;
    import org.mockito.MockitoAnnotations;

    import com.ericsson.project.controller.ShipwreckController;
    import com.ericsson.project.model.Shipwreck;
    import com.ericsson.project.repository.ShipwreckRepository;

    public class ShimpwreckControllerTest {

    @InjectMocks
    private ShipwreckController swc;
    @Mock
    private ShipwreckRepository swr;
    @Before
    public void nit(){
    MockitoAnnotations.initMocks(this);
    }
    @Test
    public void testhipwreckGet(){
    Shipwreck sw = new Shipwreck();
    sw.setId(1L);
    when(swr.findOne(1l)).thenReturn(sw);
    Shipwreck sw2 = swc.get(1l);
    assertEquals(1l, sw2.getId().longValue());
    }
    }


    • Using Hamcrest
    Has another syntax to create the matching

    assertThat(sw2.getId(), is(1l));  




    Create Integration Test

    To convert JUnit test in Integration Test

    • Annotate the tests with @RunWith( SpringJUnit4ClassRunner.class )
    • Add @SpringApplicationConfiguration( App.class ) 
    • Create the test method


    package com.ericsson.project;

    import java.util.List;

    import org.junit.Test;
    import org.junit.runner.RunWith;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.boot.test.SpringApplicationConfiguration;
    import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;

    import com.ericsson.project.model.Shipwreck;
    import com.ericsson.project.repository.ShipwreckRepository;

    import static org.hamcrest.MatcherAssert.assertThat;
    import static org.hamcrest.Matchers.*;

    @RunWith( SpringJUnit4ClassRunner.class )
    @SpringApplicationConfiguration( App.class ) 
    public class ShipwreckIntegrationTest {

    @Autowired
    private ShipwreckRepository swr;
    @Test
    public void Test(){
    List<Shipwreck> wrecks = swr.findAll();
    assertThatwrecks.size(), isgreaterThanOrEqualTo(0)));
    }
    }



    Create Web Integration Test

    Web Integration Test == calling Rest API 

    • Add the annotation  @WebIntegrationTest
    • Define the URL


    @RunWith( SpringJUnit4ClassRunner.class )
    @SpringApplicationConfiguration( App.class )
    @org.springframework.boot.test.WebIntegrationTest
    public class WebIntegrationTest {

    @Test
    public void testService() throws IOException{

    RestTemplate rt = new TestRestTemplate();
    ResponseEntity<String> response = rt.getForEntity("http://localhost:8080/api/v1/shipwrecks", String.class);

    assertThat(response.getStatusCode(), equalTo(HttpStatus.OK));

    ObjectMapper om = new ObjectMapper();
    JsonNode responseJson = om.readTree(response.getBody());

    assertThat(responseJson.isMissingNode(), is(false));
    assertThat(responseJson.toString(), equalTo("[]"));

    }
    }









    Comentarios

    Entradas populares de este blog

    Android - Basic Steps (Service)

    Service Run in the main thread of the hosting application Android can kill the Service if need the resources Purpose Supporting inter-application method execution Performing background processing Start a Service Call Context.startService(Intent intent)\ To call from a Fragment use getActivity().getApplicationContext().startService( intentService); Executing the service After call startService(...)  In the Service is executed the method onStartCommand(...) If the method returns the constant START_NOT_STICKY then Android will not restart the service automatically if the the process is killedp Foreground To execute the service foreground call the method startForeground() Use this if the user is aware of the process Bind to a Service Call the method Context.bindService( Intent service ServiceConnection con int flags ) Send Toast from the Service On the method onStartCommand receive the message   ...

    Android - Basic Steps (Location & Maps)

    Location Is composed by Latitude Longitude Time-stamp Accuracy Altitude Speed Bearing LocationProvider Types: Network  Wifi access points Cell phone towers GPS Passive Piggyback on the readings requested by other application Permissions Network  android.permission.ACCESS_COARSE_LOCATION android.permission.ACCESS_FINE_LOCATION GPS android.permission.ACCESS_FINE_LOCATION Passive Provider android.permission.ACCESS_FINE_LOCATION LocationManager System service for accessing location data getSystemService( Context.LOCATION_SERVICE ) Functions Determine the last known user location Register for location update Register to receive intents when the device nears or move away from a given geographic area LocationListener Defines callbacks methods that are called when Location or LocationProvider status change. Methods onLocationChanged(...) onProviderDisabled(...) onProviderEnabled(...) onStatusChan...

    IIS - Permisions

    IIS Permissions To enable the Active Directory connection in the IIS, follow the next steps: Go to IIS Go to Application Pool Select your App Pool Select Advanced Settings in the right side In the section Process Model Select in Identity value the property " NetworkService " You don´t need to restart your application