-
Notifications
You must be signed in to change notification settings - Fork 3
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Added tests for the DNB scenario with custom max match and context size.
Change-Id: Ie0a78c79d6f4128c400230f64929c062ffa400f5
- Loading branch information
1 parent
1668d87
commit 46e2c95
Showing
8 changed files
with
599 additions
and
3 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
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -58,4 +58,5 @@ src\main\resources\Kustvakt.conf | |
/test-config-icc.xml | ||
/data/ | ||
/old-jars/ | ||
/data-backup | ||
/data-backup | ||
/notes |
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
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,78 @@ | ||
package de.ids_mannheim.korap.scenario; | ||
|
||
import static org.junit.jupiter.api.Assertions.assertEquals; | ||
|
||
import org.junit.jupiter.api.AfterAll; | ||
import org.junit.jupiter.api.Test; | ||
import org.springframework.test.context.ContextConfiguration; | ||
|
||
import com.fasterxml.jackson.databind.JsonNode; | ||
|
||
import de.ids_mannheim.korap.config.SpringJerseyTest; | ||
import de.ids_mannheim.korap.exceptions.KustvaktException; | ||
import de.ids_mannheim.korap.util.KrillProperties; | ||
import de.ids_mannheim.korap.utils.JsonUtils; | ||
import jakarta.ws.rs.core.Response; | ||
import jakarta.ws.rs.core.Response.Status; | ||
|
||
@ContextConfiguration("classpath:test-config-dnb.xml") | ||
public class DNBTest extends SpringJerseyTest { | ||
|
||
public final static String API_VERSION = "v1.0"; | ||
|
||
private JsonNode sendQuery (String query) throws KustvaktException { | ||
Response r = target().path(API_VERSION).path("search") | ||
.queryParam("q", query).queryParam("ql", "poliqarp") | ||
.queryParam("show-tokens", true).request().get(); | ||
assertEquals(Status.OK.getStatusCode(), r.getStatus()); | ||
String entity = r.readEntity(String.class); | ||
JsonNode node = JsonUtils.readTree(entity); | ||
|
||
return node; | ||
|
||
} | ||
|
||
@AfterAll | ||
public static void resetKrillProperties() { | ||
KrillProperties.loadProperties("kustvakt-test.conf"); | ||
} | ||
|
||
@Test | ||
public void testTokenMatchSize () throws KustvaktException { | ||
assertEquals(1, KrillProperties.maxTokenMatchSize); | ||
assertEquals(25, KrillProperties.maxTokenContextSize); | ||
|
||
JsonNode node = sendQuery("[orth=das]"); | ||
assertEquals(KrillProperties.maxTokenMatchSize, | ||
node.at("/matches/0/tokens/match").size()); | ||
|
||
node = sendQuery("[orth=das][orth=Glück]"); | ||
assertEquals(KrillProperties.maxTokenMatchSize, | ||
node.at("/matches/0/tokens/match").size()); | ||
} | ||
|
||
@Test | ||
public void testTokenContextMatchSize () throws KustvaktException { | ||
Response r = target().path(API_VERSION).path("search") | ||
.queryParam("q", "[orth=das][orth=Glück]") | ||
.queryParam("ql", "poliqarp").queryParam("show-tokens", true) | ||
.queryParam("context", "30-token,30-token").request().get(); | ||
assertEquals(Status.OK.getStatusCode(), r.getStatus()); | ||
String entity = r.readEntity(String.class); | ||
JsonNode node = JsonUtils.readTree(entity); | ||
|
||
assertEquals(KrillProperties.maxTokenContextSize, | ||
node.at("/meta/context/left/1").asInt()); | ||
assertEquals(KrillProperties.maxTokenContextSize, | ||
node.at("/meta/context/right/1").asInt()); | ||
|
||
assertEquals(KrillProperties.maxTokenContextSize, | ||
node.at("/matches/0/tokens/left").size()); | ||
|
||
// There is a bug in Krill (https://github.com/KorAP/Krill/issues/141) | ||
// So the following test fails | ||
// assertEquals(KrillProperties.maxTokenContextSize, | ||
// node.at("/matches/0/tokens/right").size()); | ||
} | ||
|
||
} |
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,126 @@ | ||
# Krill settings | ||
# | ||
# A sample configuration for the DNB instance | ||
|
||
krill.match.max.token=1 | ||
krill.context.max.token=25 | ||
|
||
krill.indexDir = sample-index | ||
|
||
krill.index.commit.count = 134217000 | ||
krill.index.commit.log = log/krill.commit.log | ||
krill.index.commit.auto = 500 | ||
krill.index.relations.max = 100 | ||
# Directory path of virtual corpora to cache | ||
krill.namedVC = vc | ||
krill.test = true | ||
|
||
# LDAP configuration file | ||
# | ||
ldap.config = src/test/resources/test-ldap.conf | ||
|
||
# Kustvakt versions | ||
# | ||
# multiple versions separated by space | ||
current.api.version = v1.0 | ||
supported.api.version = v0.1 v1.0 | ||
|
||
# Server | ||
# | ||
server.port=8089 | ||
server.host=localhost | ||
|
||
# Mail settings | ||
# | ||
mail.enabled = false | ||
mail.receiver = test@localhost | ||
mail.sender = [email protected] | ||
mail.address.retrieval = test | ||
|
||
# Mail.templates | ||
# | ||
template.group.invitation = notification.vm | ||
|
||
# Default foundries for specific layers (optional) | ||
# | ||
default.foundry.partOfSpeech = tt | ||
default.foundry.lemma = tt | ||
default.foundry.orthography = opennlp | ||
default.foundry.dependency = malt | ||
default.foundry.constituent = corenlp | ||
default.foundry.morphology = marmot | ||
default.foundry.surface = base | ||
|
||
# Delete configuration (default hard) | ||
# | ||
# delete.auto.group = hard | ||
delete.group = soft | ||
delete.group.member = soft | ||
|
||
# Virtual corpus and queries | ||
max.user.persistent.queries = 5 | ||
|
||
# Availability regex only support | | ||
# It should be removed/commented when the data doesn't contain availability field. | ||
# | ||
availability.regex.free = CC-BY.* | ||
availability.regex.public = ACA.*|QAO-NC | ||
availability.regex.all = QAO.* | ||
|
||
|
||
# Define resource filters for search and match info API | ||
# AuthenticationFilter activates authentication using OAuth2 tokens | ||
# DemoUserFilter allows access to API without login | ||
# | ||
# Default values: AuthenticationFilter,DemoUserFilter | ||
# | ||
search.resource.filters=AuthenticationFilter,DemoUserFilter | ||
|
||
|
||
# options referring to the security module! | ||
|
||
# OAuth | ||
# (see de.ids_mannheim.korap.constant.AuthenticationMethod for possible | ||
# oauth.password.authentication values) | ||
# | ||
oauth2.password.authentication = TEST | ||
oauth2.native.client.host = korap.ids-mannheim.de | ||
oauth2.max.attempts = 2 | ||
# expiry in seconds (S), minutes (M), hours (H), days (D) | ||
oauth2.access.token.expiry = 3M | ||
oauth2.refresh.token.expiry = 90D | ||
oauth2.authorization.code.expiry = 10M | ||
# -- scopes separated by space | ||
oauth2.default.scopes = search match_info | ||
oauth2.client.credentials.scopes = client_info | ||
|
||
oauth2.initial.super.client=true | ||
|
||
|
||
# see SecureRandom Number Generation Algorithms | ||
# optional | ||
security.secure.random.algorithm=SHA1PRNG | ||
|
||
# see MessageDigest Algorithms | ||
# default MD5 | ||
security.md.algoritm = SHA-256 | ||
|
||
# secure hash support: BCRYPT | ||
security.secure.hash.algorithm=BCRYPT | ||
security.encryption.loadFactor = 10 | ||
|
||
# DEPRECATED | ||
# JWT | ||
security.jwt.issuer=https://korap.ids-mannheim.de | ||
security.sharedSecret=this-is-shared-secret-code-for-JWT-Signing.It-must-contains-minimum-256-bits | ||
|
||
# token expiration time | ||
security.longTokenTTL = 1D | ||
security.tokenTTL = 2S | ||
security.shortTokenTTL = 1S | ||
|
||
# Session authentication | ||
security.idleTimeoutDuration = 25M | ||
security.multipleLogIn = true | ||
security.loginAttemptNum = 3 | ||
security.authAttemptTTL = 45M |
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
Oops, something went wrong.