refactor(search): align ResponseStatusException imports + add wildcard HTTP test
This commit is contained in:
@@ -15,6 +15,7 @@ import com.cameleer.server.core.search.TopError;
|
|||||||
import com.cameleer.server.core.storage.StatsStore;
|
import com.cameleer.server.core.storage.StatsStore;
|
||||||
import io.swagger.v3.oas.annotations.Operation;
|
import io.swagger.v3.oas.annotations.Operation;
|
||||||
import io.swagger.v3.oas.annotations.tags.Tag;
|
import io.swagger.v3.oas.annotations.tags.Tag;
|
||||||
|
import org.springframework.http.HttpStatus;
|
||||||
import org.springframework.http.ResponseEntity;
|
import org.springframework.http.ResponseEntity;
|
||||||
import org.springframework.web.bind.annotation.GetMapping;
|
import org.springframework.web.bind.annotation.GetMapping;
|
||||||
import org.springframework.web.bind.annotation.PostMapping;
|
import org.springframework.web.bind.annotation.PostMapping;
|
||||||
@@ -22,6 +23,7 @@ import org.springframework.web.bind.annotation.RequestBody;
|
|||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
import org.springframework.web.bind.annotation.RequestMapping;
|
||||||
import org.springframework.web.bind.annotation.RequestParam;
|
import org.springframework.web.bind.annotation.RequestParam;
|
||||||
import org.springframework.web.bind.annotation.RestController;
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
|
import org.springframework.web.server.ResponseStatusException;
|
||||||
|
|
||||||
import java.time.Instant;
|
import java.time.Instant;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
@@ -69,8 +71,7 @@ public class SearchController {
|
|||||||
try {
|
try {
|
||||||
attributeFilters = parseAttrParams(attr);
|
attributeFilters = parseAttrParams(attr);
|
||||||
} catch (IllegalArgumentException e) {
|
} catch (IllegalArgumentException e) {
|
||||||
throw new org.springframework.web.server.ResponseStatusException(
|
throw new ResponseStatusException(HttpStatus.BAD_REQUEST, e.getMessage(), e);
|
||||||
org.springframework.http.HttpStatus.BAD_REQUEST, e.getMessage(), e);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
SearchRequest request = new SearchRequest(
|
SearchRequest request = new SearchRequest(
|
||||||
|
|||||||
@@ -465,6 +465,16 @@ class SearchControllerIT extends AbstractPostgresIT {
|
|||||||
assertThat(body.get("data").get(0).get("correlationId").asText()).isEqualTo("corr-attr-alpha");
|
assertThat(body.get("data").get(0).get("correlationId").asText()).isEqualTo("corr-attr-alpha");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void attrParam_wildcardValue_matchesOnPrefix() throws Exception {
|
||||||
|
ResponseEntity<String> response = searchGet("?attr=order:1*&correlationId=corr-attr-alpha");
|
||||||
|
assertThat(response.getStatusCode()).isEqualTo(HttpStatus.OK);
|
||||||
|
|
||||||
|
JsonNode body = objectMapper.readTree(response.getBody());
|
||||||
|
assertThat(body.get("total").asLong()).isEqualTo(1);
|
||||||
|
assertThat(body.get("data").get(0).get("correlationId").asText()).isEqualTo("corr-attr-alpha");
|
||||||
|
}
|
||||||
|
|
||||||
// --- Helper methods ---
|
// --- Helper methods ---
|
||||||
|
|
||||||
private void ingest(String json) {
|
private void ingest(String json) {
|
||||||
|
|||||||
Reference in New Issue
Block a user