|
31 | 31 | import org.elasticsearch.xpack.core.inference.results.RankedDocsResults;
|
32 | 32 | import org.elasticsearch.xpack.core.inference.results.SparseEmbeddingResults;
|
33 | 33 | import org.elasticsearch.xpack.core.inference.results.TextEmbeddingFloatResults;
|
| 34 | +import org.elasticsearch.xpack.inference.chunking.ChunkingSettingsBuilder; |
34 | 35 | import org.elasticsearch.xpack.inference.chunking.ChunkingSettingsTests;
|
35 | 36 | import org.elasticsearch.xpack.inference.external.http.HttpClientManager;
|
36 | 37 | import org.elasticsearch.xpack.inference.external.http.sender.HttpRequestSenderTests;
|
|
53 | 54 | import java.util.Map;
|
54 | 55 |
|
55 | 56 | import static org.elasticsearch.xpack.inference.Utils.TIMEOUT;
|
| 57 | +import static org.elasticsearch.xpack.inference.Utils.getPersistedConfigMap; |
56 | 58 | import static org.elasticsearch.xpack.inference.Utils.getRequestConfigMap;
|
| 59 | +import static org.elasticsearch.xpack.inference.chunking.ChunkingSettingsTests.createRandomChunkingSettingsMap; |
57 | 60 | import static org.elasticsearch.xpack.inference.external.http.Utils.entityAsMap;
|
58 | 61 | import static org.elasticsearch.xpack.inference.external.http.Utils.getUrl;
|
59 | 62 | import static org.elasticsearch.xpack.inference.services.ServiceComponentsTests.createWithEmptySettings;
|
@@ -312,6 +315,93 @@ private static CustomServiceSettings.TextEmbeddingSettings getDefaultTextEmbeddi
|
312 | 315 | : CustomServiceSettings.TextEmbeddingSettings.NON_TEXT_EMBEDDING_TASK_TYPE_SETTINGS;
|
313 | 316 | }
|
314 | 317 |
|
| 318 | + public void testParseRequestConfig_CreatesAnEmbeddingsModel_WhenChunkingSettingsProvided() throws Exception { |
| 319 | + var chunkingSettingsMap = createRandomChunkingSettingsMap(); |
| 320 | + |
| 321 | + try (var service = createService(threadPool, clientManager)) { |
| 322 | + var config = getRequestConfigMap( |
| 323 | + createServiceSettingsMap(TaskType.TEXT_EMBEDDING), |
| 324 | + createTaskSettingsMap(), |
| 325 | + chunkingSettingsMap, |
| 326 | + createSecretSettingsMap() |
| 327 | + ); |
| 328 | + |
| 329 | + var listener = new PlainActionFuture<Model>(); |
| 330 | + service.parseRequestConfig("id", TaskType.TEXT_EMBEDDING, config, listener); |
| 331 | + var model = listener.actionGet(TIMEOUT); |
| 332 | + |
| 333 | + assertModel(model, TaskType.TEXT_EMBEDDING); |
| 334 | + |
| 335 | + var expectedChunkingSettings = ChunkingSettingsBuilder.fromMap(chunkingSettingsMap); |
| 336 | + assertThat(model.getConfigurations().getChunkingSettings(), is(expectedChunkingSettings)); |
| 337 | + } |
| 338 | + } |
| 339 | + |
| 340 | + public void testParseRequestConfig_CreatesAnEmbeddingsModel_WhenChunkingSettingsNotProvided() throws Exception { |
| 341 | + try (var service = createService(threadPool, clientManager)) { |
| 342 | + var config = getRequestConfigMap( |
| 343 | + createServiceSettingsMap(TaskType.TEXT_EMBEDDING), |
| 344 | + createTaskSettingsMap(), |
| 345 | + createSecretSettingsMap() |
| 346 | + ); |
| 347 | + |
| 348 | + var listener = new PlainActionFuture<Model>(); |
| 349 | + service.parseRequestConfig("id", TaskType.TEXT_EMBEDDING, config, listener); |
| 350 | + var model = listener.actionGet(TIMEOUT); |
| 351 | + |
| 352 | + assertModel(model, TaskType.TEXT_EMBEDDING); |
| 353 | + |
| 354 | + var expectedChunkingSettings = ChunkingSettingsBuilder.fromMap(Map.of()); |
| 355 | + assertThat(model.getConfigurations().getChunkingSettings(), is(expectedChunkingSettings)); |
| 356 | + } |
| 357 | + } |
| 358 | + |
| 359 | + public void testParsePersistedConfigWithSecrets_CreatesAnEmbeddingsModel_WhenChunkingSettingsProvided() throws Exception { |
| 360 | + var chunkingSettingsMap = createRandomChunkingSettingsMap(); |
| 361 | + |
| 362 | + try (var service = createService(threadPool, clientManager)) { |
| 363 | + var persistedConfigMap = getPersistedConfigMap( |
| 364 | + createServiceSettingsMap(TaskType.TEXT_EMBEDDING), |
| 365 | + createTaskSettingsMap(), |
| 366 | + chunkingSettingsMap, |
| 367 | + createSecretSettingsMap() |
| 368 | + ); |
| 369 | + |
| 370 | + var model = service.parsePersistedConfigWithSecrets( |
| 371 | + "id", |
| 372 | + TaskType.TEXT_EMBEDDING, |
| 373 | + persistedConfigMap.config(), |
| 374 | + persistedConfigMap.secrets() |
| 375 | + ); |
| 376 | + |
| 377 | + assertModel(model, TaskType.TEXT_EMBEDDING); |
| 378 | + |
| 379 | + var expectedChunkingSettings = ChunkingSettingsBuilder.fromMap(chunkingSettingsMap); |
| 380 | + assertThat(model.getConfigurations().getChunkingSettings(), is(expectedChunkingSettings)); |
| 381 | + } |
| 382 | + } |
| 383 | + |
| 384 | + public void testParsePersistedConfigWithSecrets_CreatesAnEmbeddingsModel_WhenChunkingSettingsNotProvided() throws Exception { |
| 385 | + try (var service = createService(threadPool, clientManager)) { |
| 386 | + var persistedConfigMap = getPersistedConfigMap( |
| 387 | + createServiceSettingsMap(TaskType.TEXT_EMBEDDING), |
| 388 | + createTaskSettingsMap(), |
| 389 | + createSecretSettingsMap() |
| 390 | + ); |
| 391 | + |
| 392 | + var model = service.parsePersistedConfigWithSecrets( |
| 393 | + "id", |
| 394 | + TaskType.TEXT_EMBEDDING, |
| 395 | + persistedConfigMap.config(), |
| 396 | + persistedConfigMap.secrets() |
| 397 | + ); |
| 398 | + assertModel(model, TaskType.TEXT_EMBEDDING); |
| 399 | + |
| 400 | + var expectedChunkingSettings = ChunkingSettingsBuilder.fromMap(null); |
| 401 | + assertThat(model.getConfigurations().getChunkingSettings(), is(expectedChunkingSettings)); |
| 402 | + } |
| 403 | + } |
| 404 | + |
315 | 405 | public void testInfer_ReturnsAnError_WithoutParsingTheResponseBody() throws IOException {
|
316 | 406 | try (var service = createService(threadPool, clientManager)) {
|
317 | 407 | String responseJson = "error";
|
|
0 commit comments