Skip to content

Commit

Permalink
Refactor mocking
Browse files Browse the repository at this point in the history
Enable mock responses for forceupdate and infobox through profiles, by overriding the controller with the mocked responses. This is easier to maintain and we do not need to create mock/test releases each time.
  • Loading branch information
martinalig committed Dec 18, 2020
1 parent bde9c8b commit 53f805d
Show file tree
Hide file tree
Showing 7 changed files with 241 additions and 95 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,6 @@

package org.dpppt.switzerland.backend.sdk.config.ws.config;

import io.jsonwebtoken.SignatureAlgorithm;
import java.io.ByteArrayInputStream;
import java.io.Reader;
import java.io.StringReader;
Expand All @@ -21,21 +20,16 @@
import java.security.Security;
import java.security.cert.CertificateFactory;
import java.security.spec.PKCS8EncodedKeySpec;
import java.util.Arrays;
import java.util.List;
import java.util.Locale;
import java.util.Map;
import java.util.concurrent.TimeUnit;

import org.bouncycastle.jce.provider.BouncyCastleProvider;
import org.bouncycastle.util.io.pem.PemObject;
import org.bouncycastle.util.io.pem.PemReader;
import org.dpppt.switzerland.backend.sdk.config.ws.controller.GaenConfigController;
import org.dpppt.switzerland.backend.sdk.config.ws.filter.ResponseWrapperFilter;
import org.dpppt.switzerland.backend.sdk.config.ws.interceptor.HeaderInjector;
import org.dpppt.switzerland.backend.sdk.config.ws.model.ConfigResponse;
import org.dpppt.switzerland.backend.sdk.config.ws.model.FaqEntry;
import org.dpppt.switzerland.backend.sdk.config.ws.model.WhatToDoPositiveTestTexts;
import org.dpppt.switzerland.backend.sdk.config.ws.model.WhatToDoPositiveTestTextsCollection;
import org.dpppt.switzerland.backend.sdk.config.ws.poeditor.Messages;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
Expand All @@ -51,6 +45,8 @@
import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

import io.jsonwebtoken.SignatureAlgorithm;

@Configuration
@EnableScheduling
public abstract class WSBaseConfig implements SchedulingConfigurer, WebMvcConfigurer {
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
package org.dpppt.switzerland.backend.sdk.config.ws.config.mock;

import org.dpppt.switzerland.backend.sdk.config.ws.controller.GaenConfigController;
import org.dpppt.switzerland.backend.sdk.config.ws.model.ConfigResponse;
import org.dpppt.switzerland.backend.sdk.config.ws.poeditor.Messages;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Primary;
import org.springframework.context.annotation.Profile;
import org.springframework.http.ResponseEntity;

import ch.ubique.openapi.docannotations.Documentation;

@Configuration
@Profile("mock-forceupdate")
public class MockForceUpdateConfig {


@Bean
@Primary
public GaenConfigController gaenConfigController(Messages messages) {
return new MockInfoBoxController(messages);
}

public class MockInfoBoxController extends GaenConfigController {

public MockInfoBoxController(Messages messages) {
super(messages);
}

@Override
public @Documentation(description = "Read latest configuration and messages, depending on the version of the phone and the app.", responses = "200 => ConfigResponse structure with eventual notifications and epidemic parameters") ResponseEntity<ConfigResponse> getConfig(
@Documentation(description = "Version of the App installed", example = "ios-1.0.7") String appversion,
@Documentation(description = "Version of the OS", example = "ios13.6") String osversion,
@Documentation(description = "Build number of the app", example = "ios-200619.2333.175") String buildnr) {
ResponseEntity<ConfigResponse> response = super.getConfig(appversion, osversion, buildnr);
response.getBody().setForceUpdate(true);;
return response;
}

}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
package org.dpppt.switzerland.backend.sdk.config.ws.config.mock;

import org.dpppt.switzerland.backend.sdk.config.ws.controller.GaenConfigController;
import org.dpppt.switzerland.backend.sdk.config.ws.helper.MockHelper;
import org.dpppt.switzerland.backend.sdk.config.ws.model.ConfigResponse;
import org.dpppt.switzerland.backend.sdk.config.ws.poeditor.Messages;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Primary;
import org.springframework.context.annotation.Profile;
import org.springframework.http.ResponseEntity;

import ch.ubique.openapi.docannotations.Documentation;

@Configuration
@Profile("mock-infobox")
public class MockInfoBoxConfig {


@Bean
@Primary
public GaenConfigController gaenConfigController(Messages messages) {
return new MockInfoBoxController(messages);
}

public class MockInfoBoxController extends GaenConfigController {

public MockInfoBoxController(Messages messages) {
super(messages);
}

@Override
public @Documentation(description = "Read latest configuration and messages, depending on the version of the phone and the app.", responses = "200 => ConfigResponse structure with eventual notifications and epidemic parameters") ResponseEntity<ConfigResponse> getConfig(
@Documentation(description = "Version of the App installed", example = "ios-1.0.7") String appversion,
@Documentation(description = "Version of the OS", example = "ios13.6") String osversion,
@Documentation(description = "Build number of the app", example = "ios-200619.2333.175") String buildnr) {
ResponseEntity<ConfigResponse> response = super.getConfig(appversion, osversion, buildnr);
response.getBody().setInfoBox(MockHelper.mockConfigResponseWithInfoBox(true).getInfoBox());
return response;
}

}
}
Original file line number Diff line number Diff line change
Expand Up @@ -12,15 +12,18 @@

import java.time.Duration;
import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.Locale;
import java.util.Map;
import java.util.Set;

import org.dpppt.switzerland.backend.sdk.config.ws.helper.IOS136InfoBoxHelper;
import org.dpppt.switzerland.backend.sdk.config.ws.helper.MockHelper;
import org.dpppt.switzerland.backend.sdk.config.ws.helper.TestLocationHelper;
import org.dpppt.switzerland.backend.sdk.config.ws.model.*;
import org.dpppt.switzerland.backend.sdk.config.ws.model.ConfigResponse;
import org.dpppt.switzerland.backend.sdk.config.ws.model.FaqEntry;
import org.dpppt.switzerland.backend.sdk.config.ws.model.InfoBox;
import org.dpppt.switzerland.backend.sdk.config.ws.model.InfoBoxCollection;
import org.dpppt.switzerland.backend.sdk.config.ws.model.WhatToDoPositiveTestTexts;
import org.dpppt.switzerland.backend.sdk.config.ws.model.WhatToDoPositiveTestTextsCollection;
import org.dpppt.switzerland.backend.sdk.config.ws.poeditor.Messages;
import org.dpppt.switzerland.backend.sdk.config.ws.semver.Version;
import org.slf4j.Logger;
Expand All @@ -33,6 +36,7 @@
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;

import ch.ubique.openapi.docannotations.Documentation;

/**
Expand Down Expand Up @@ -91,7 +95,7 @@ public class GaenConfigController {

private static final Logger logger = LoggerFactory.getLogger(GaenConfigController.class);

private static Messages messages;
private Messages messages;

public GaenConfigController(Messages messages) {
this.messages = messages;
Expand Down Expand Up @@ -170,7 +174,7 @@ public GaenConfigController(Messages messages) {
@Documentation(description = "Version of the App installed", example = "ios-1.0.7") @RequestParam String appversion,
@Documentation(description = "Version of the OS", example = "ios13.6") @RequestParam String osversion,
@Documentation(description = "Build number of the app", example = "ios-200619.2333.175") @RequestParam String buildnr) {
ConfigResponse body = mockConfigResponseWithInfoBox();
ConfigResponse body = MockHelper.mockConfigResponseWithInfoBox(true);
return ResponseEntity.ok(body);
}

Expand Down Expand Up @@ -394,88 +398,6 @@ private ConfigResponse generalUpdateRelease(boolean isIos) {
return configResponse;
}

private ConfigResponse mockConfigResponseWithInfoBox() {
ConfigResponse configResponse = new ConfigResponse();

InfoBox infoBoxde = new InfoBox();
infoBoxde.setMsg("Hier steht ein Text. Das kann ein Hinweis sein. Je länger umso mehr Platz DE");
infoBoxde.setTitle("Hinweis DE");
infoBoxde.setUrlTitle("Und ein externer Link DE");
infoBoxde.setUrl("https://www.bag.admin.ch/bag/de/home.html");
InfoBox infoBoxfr = new InfoBox();
infoBoxfr.setMsg("Hier steht ein Text. Das kann ein Hinweis sein. Je länger umso mehr Platz FR");
infoBoxfr.setTitle("Hinweis FR");
infoBoxfr.setUrlTitle("Und ein externer Link FR");
infoBoxfr.setUrl("https://www.bag.admin.ch/bag/fr/home.html");
InfoBox infoBoxit = new InfoBox();
infoBoxit.setMsg("Hier steht ein Text. Das kann ein Hinweis sein. Je länger umso mehr Platz IT");
infoBoxit.setTitle("Hinweis IT");
infoBoxit.setUrlTitle("Und ein externer Link IT");
infoBoxit.setUrl("https://www.bag.admin.ch/bag/it/home.html");
InfoBox infoBoxen = new InfoBox();
infoBoxen.setMsg("Hier steht ein Text. Das kann ein Hinweis sein. Je länger umso mehr Platz EN");
infoBoxen.setTitle("Hinweis EN");
infoBoxen.setUrlTitle("Und ein externer Link EN");
infoBoxen.setUrl("https://www.bag.admin.ch/bag/en/home.html");
InfoBox infoBoxpt = new InfoBox();
infoBoxpt.setMsg("Hier steht ein Text. Das kann ein Hinweis sein. Je länger umso mehr Platz PT");
infoBoxpt.setTitle("Hinweis PT");
infoBoxpt.setUrlTitle("Und ein externer Link PT");
infoBoxpt.setUrl("https://www.bag.admin.ch/bag/pt/home.html");
InfoBox infoBoxes = new InfoBox();
infoBoxes.setMsg("Hier steht ein Text. Das kann ein Hinweis sein. Je länger umso mehr Platz ES");
infoBoxes.setTitle("Hinweis ES");
infoBoxes.setUrlTitle("Und ein externer Link ES");
infoBoxes.setUrl("https://www.bag.admin.ch/bag/en/home.html");
InfoBox infoBoxsq = new InfoBox();
infoBoxsq.setMsg("Hier steht ein Text. Das kann ein Hinweis sein. Je länger umso mehr Platz SQ");
infoBoxsq.setTitle("Hinweis SQ");
infoBoxsq.setUrlTitle("Und ein externer Link SQ");
infoBoxsq.setUrl("https://www.bag.admin.ch/bag/en/home.html");
InfoBox infoBoxbs = new InfoBox();
infoBoxbs.setMsg("Hier steht ein Text. Das kann ein Hinweis sein. Je länger umso mehr Platz BS");
infoBoxbs.setTitle("Hinweis BS");
infoBoxbs.setUrlTitle("Und ein externer Link BS");
infoBoxbs.setUrl("https://www.bag.admin.ch/bag/en/home.html");
InfoBox infoBoxhr = new InfoBox();
infoBoxhr.setMsg("Hier steht ein Text. Das kann ein Hinweis sein. Je länger umso mehr Platz HR");
infoBoxhr.setTitle("Hinweis HR");
infoBoxhr.setUrlTitle("Und ein externer Link HR");
infoBoxhr.setUrl("https://www.bag.admin.ch/bag/en/home.html");
InfoBox infoBoxrm = new InfoBox();
infoBoxrm.setMsg("Hier steht ein Text. Das kann ein Hinweis sein. Je länger umso mehr Platz RM");
infoBoxrm.setTitle("Hinweis RM");
infoBoxrm.setUrlTitle("Und ein externer Link RM");
infoBoxrm.setUrl("https://www.bag.admin.ch/bag/en/home.html");
InfoBox infoBoxsr = new InfoBox();
infoBoxsr.setMsg("Hier steht ein Text. Das kann ein Hinweis sein. Je länger umso mehr Platz SR");
infoBoxsr.setTitle("Hinweis SR");
infoBoxsr.setUrlTitle("Und ein externer Link SR");
infoBoxsr.setUrl("https://www.bag.admin.ch/bag/en/home.html");

InfoBoxCollection collection = new InfoBoxCollection();
collection.setDeInfoBox(infoBoxde);
collection.setEnInfoBox(infoBoxen);
collection.setFrInfoBox(infoBoxfr);
collection.setItInfoBox(infoBoxit);
collection.setPtInfoBox(infoBoxpt);
collection.setEsInfoBox(infoBoxes);
collection.setSqInfoBox(infoBoxsq);
collection.setHrInfoBox(infoBoxhr);
collection.setBsInfoBox(infoBoxbs);
collection.setRmInfoBox(infoBoxrm);
collection.setSrInfoBox(infoBoxsr);
configResponse.setInfoBox(collection);

return configResponse;
}

public ConfigResponse mockConfigResponseWithForceUpdate() {
ConfigResponse configResponse = new ConfigResponse();
configResponse.setForceUpdate(true);
return configResponse;
}

private void moveEnterCovidcodeBoxTextToInfoBoxIfNecessary(WhatToDoPositiveTestTexts texts) {
if (texts.getInfoBox() == null) {
texts.setInfoBox(new InfoBox() {
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,123 @@
package org.dpppt.switzerland.backend.sdk.config.ws.helper;

import org.dpppt.switzerland.backend.sdk.config.ws.model.ConfigResponse;
import org.dpppt.switzerland.backend.sdk.config.ws.model.InfoBox;
import org.dpppt.switzerland.backend.sdk.config.ws.model.InfoBoxCollection;
import org.dpppt.switzerland.backend.sdk.config.ws.model.SDKConfig;

public class MockHelper {

public static ConfigResponse mockConfigResponseWithInfoBox(boolean dismissible) {
ConfigResponse configResponse = new ConfigResponse();

InfoBox infoBoxde = new InfoBox();
infoBoxde.setMsg("Hier steht ein Text. Das kann ein Hinweis sein. Je länger umso mehr Platz DE");
infoBoxde.setTitle("Hinweis DE");
infoBoxde.setUrlTitle("Und ein externer Link DE");
infoBoxde.setUrl("https://www.bag.admin.ch/bag/de/home.html");
infoBoxde.setIsDismissible(dismissible);

InfoBox infoBoxfr = new InfoBox();
infoBoxfr.setMsg("Hier steht ein Text. Das kann ein Hinweis sein. Je länger umso mehr Platz FR");
infoBoxfr.setTitle("Hinweis FR");
infoBoxfr.setUrlTitle("Und ein externer Link FR");
infoBoxfr.setUrl("https://www.bag.admin.ch/bag/fr/home.html");
infoBoxfr.setIsDismissible(dismissible);

InfoBox infoBoxit = new InfoBox();
infoBoxit.setMsg("Hier steht ein Text. Das kann ein Hinweis sein. Je länger umso mehr Platz IT");
infoBoxit.setTitle("Hinweis IT");
infoBoxit.setUrlTitle("Und ein externer Link IT");
infoBoxit.setUrl("https://www.bag.admin.ch/bag/it/home.html");
infoBoxit.setIsDismissible(dismissible);

InfoBox infoBoxen = new InfoBox();
infoBoxen.setMsg("Hier steht ein Text. Das kann ein Hinweis sein. Je länger umso mehr Platz EN");
infoBoxen.setTitle("Hinweis EN");
infoBoxen.setUrlTitle("Und ein externer Link EN");
infoBoxen.setUrl("https://www.bag.admin.ch/bag/en/home.html");
infoBoxen.setIsDismissible(dismissible);

InfoBox infoBoxpt = new InfoBox();
infoBoxpt.setMsg("Hier steht ein Text. Das kann ein Hinweis sein. Je länger umso mehr Platz PT");
infoBoxpt.setTitle("Hinweis PT");
infoBoxpt.setUrlTitle("Und ein externer Link PT");
infoBoxpt.setUrl("https://www.bag.admin.ch/bag/pt/home.html");
infoBoxpt.setIsDismissible(dismissible);

InfoBox infoBoxes = new InfoBox();
infoBoxes.setMsg("Hier steht ein Text. Das kann ein Hinweis sein. Je länger umso mehr Platz ES");
infoBoxes.setTitle("Hinweis ES");
infoBoxes.setUrlTitle("Und ein externer Link ES");
infoBoxes.setUrl("https://www.bag.admin.ch/bag/en/home.html");
infoBoxes.setIsDismissible(dismissible);

InfoBox infoBoxsq = new InfoBox();
infoBoxsq.setMsg("Hier steht ein Text. Das kann ein Hinweis sein. Je länger umso mehr Platz SQ");
infoBoxsq.setTitle("Hinweis SQ");
infoBoxsq.setUrlTitle("Und ein externer Link SQ");
infoBoxsq.setUrl("https://www.bag.admin.ch/bag/en/home.html");
infoBoxsq.setIsDismissible(dismissible);

InfoBox infoBoxbs = new InfoBox();
infoBoxbs.setMsg("Hier steht ein Text. Das kann ein Hinweis sein. Je länger umso mehr Platz BS");
infoBoxbs.setTitle("Hinweis BS");
infoBoxbs.setUrlTitle("Und ein externer Link BS");
infoBoxbs.setUrl("https://www.bag.admin.ch/bag/en/home.html");
infoBoxbs.setIsDismissible(dismissible);

InfoBox infoBoxhr = new InfoBox();
infoBoxhr.setMsg("Hier steht ein Text. Das kann ein Hinweis sein. Je länger umso mehr Platz HR");
infoBoxhr.setTitle("Hinweis HR");
infoBoxhr.setUrlTitle("Und ein externer Link HR");
infoBoxhr.setUrl("https://www.bag.admin.ch/bag/en/home.html");
infoBoxhr.setIsDismissible(dismissible);

InfoBox infoBoxrm = new InfoBox();
infoBoxrm.setMsg("Hier steht ein Text. Das kann ein Hinweis sein. Je länger umso mehr Platz RM");
infoBoxrm.setTitle("Hinweis RM");
infoBoxrm.setUrlTitle("Und ein externer Link RM");
infoBoxrm.setUrl("https://www.bag.admin.ch/bag/en/home.html");
infoBoxrm.setIsDismissible(dismissible);

InfoBox infoBoxsr = new InfoBox();
infoBoxsr.setMsg("Hier steht ein Text. Das kann ein Hinweis sein. Je länger umso mehr Platz SR");
infoBoxsr.setTitle("Hinweis SR");
infoBoxsr.setUrlTitle("Und ein externer Link SR");
infoBoxsr.setUrl("https://www.bag.admin.ch/bag/en/home.html");
infoBoxsr.setIsDismissible(dismissible);

InfoBox Infoboxtr = new InfoBox();
Infoboxtr.setMsg("Hier steht ein Text. Das kann ein Hinweis sein. Je länger umso mehr Platz TR");
Infoboxtr.setTitle("Hinweis TR");
Infoboxtr.setUrlTitle("Und ein externer Link TR");
Infoboxtr.setUrl("https://www.bag.admin.ch/bag/en/home.html");
Infoboxtr.setIsDismissible(dismissible);

InfoBox infoBoxti = new InfoBox();
infoBoxti.setMsg("Hier steht ein Text. Das kann ein Hinweis sein. Je länger umso mehr Platz TI");
infoBoxti.setTitle("Hinweis TI");
infoBoxti.setUrlTitle("Und ein externer Link TI");
infoBoxti.setUrl("https://www.bag.admin.ch/bag/en/home.html");
infoBoxti.setIsDismissible(dismissible);

InfoBoxCollection collection = new InfoBoxCollection();
collection.setDeInfoBox(infoBoxde);
collection.setEnInfoBox(infoBoxen);
collection.setFrInfoBox(infoBoxfr);
collection.setItInfoBox(infoBoxit);
collection.setPtInfoBox(infoBoxpt);
collection.setEsInfoBox(infoBoxes);
collection.setSqInfoBox(infoBoxsq);
collection.setHrInfoBox(infoBoxhr);
collection.setBsInfoBox(infoBoxbs);
collection.setRmInfoBox(infoBoxrm);
collection.setSrInfoBox(infoBoxsr);
collection.setTrInfobox(Infoboxtr);
collection.setTiInfobox(infoBoxti);

configResponse.setInfoBox(collection);

return configResponse;
}
}
Loading

0 comments on commit 53f805d

Please sign in to comment.