mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 13:06:27 +00:00 
			
		
		
		
	Merge #4972
4972: Add binary quantized to error messages r=irevoire a=dureuill was missing in error messages Co-authored-by: Louis Dureuil <louis@meilisearch.com>
This commit is contained in:
		| @@ -4,6 +4,53 @@ use crate::common::{GetAllDocumentsOptions, Server}; | ||||
| use crate::json; | ||||
| use crate::vector::generate_default_user_provided_documents; | ||||
|  | ||||
| #[actix_rt::test] | ||||
| async fn field_unavailable_for_source() { | ||||
|     let server = Server::new().await; | ||||
|     let index = server.index("doggo"); | ||||
|     let (value, code) = server.set_features(json!({"vectorStore": true})).await; | ||||
|     snapshot!(code, @"200 OK"); | ||||
|     snapshot!(value, @r###" | ||||
|     { | ||||
|       "vectorStore": true, | ||||
|       "metrics": false, | ||||
|       "logsRoute": false, | ||||
|       "editDocumentsByFunction": false, | ||||
|       "containsFilter": false | ||||
|     } | ||||
|     "###); | ||||
|  | ||||
|     let (response, code) = index | ||||
|         .update_settings(json!({ | ||||
|           "embedders": { "manual": {"source": "userProvided", "documentTemplate": "{{doc.documentTemplate}}"}}, | ||||
|         })) | ||||
|         .await; | ||||
|     snapshot!(code, @"400 Bad Request"); | ||||
|     snapshot!(response, @r###" | ||||
|     { | ||||
|       "message": "`.embedders.manual`: Field `documentTemplate` unavailable for source `userProvided` (only available for sources: `huggingFace`, `openAi`, `ollama`, `rest`). Available fields: `source`, `dimensions`, `distribution`, `binaryQuantized`", | ||||
|       "code": "invalid_settings_embedders", | ||||
|       "type": "invalid_request", | ||||
|       "link": "https://docs.meilisearch.com/errors#invalid_settings_embedders" | ||||
|     } | ||||
|     "###); | ||||
|  | ||||
|     let (response, code) = index | ||||
|         .update_settings(json!({ | ||||
|           "embedders": { "default": {"source": "openAi", "revision": "42"}}, | ||||
|         })) | ||||
|         .await; | ||||
|     snapshot!(code, @"400 Bad Request"); | ||||
|     snapshot!(response, @r###" | ||||
|     { | ||||
|       "message": "`.embedders.default`: Field `revision` unavailable for source `openAi` (only available for sources: `huggingFace`). Available fields: `source`, `model`, `apiKey`, `documentTemplate`, `dimensions`, `distribution`, `url`, `binaryQuantized`", | ||||
|       "code": "invalid_settings_embedders", | ||||
|       "type": "invalid_request", | ||||
|       "link": "https://docs.meilisearch.com/errors#invalid_settings_embedders" | ||||
|     } | ||||
|     "###); | ||||
| } | ||||
|  | ||||
| #[actix_rt::test] | ||||
| async fn update_embedder() { | ||||
|     let server = Server::new().await; | ||||
|   | ||||
| @@ -417,6 +417,8 @@ impl EmbeddingSettings { | ||||
|  | ||||
|     pub const DISTRIBUTION: &'static str = "distribution"; | ||||
|  | ||||
|     pub const BINARY_QUANTIZED: &'static str = "binaryQuantized"; | ||||
|  | ||||
|     pub fn allowed_sources_for_field(field: &'static str) -> &'static [EmbedderSource] { | ||||
|         match field { | ||||
|             Self::SOURCE => &[ | ||||
| @@ -456,6 +458,13 @@ impl EmbeddingSettings { | ||||
|                 EmbedderSource::Rest, | ||||
|                 EmbedderSource::UserProvided, | ||||
|             ], | ||||
|             Self::BINARY_QUANTIZED => &[ | ||||
|                 EmbedderSource::HuggingFace, | ||||
|                 EmbedderSource::Ollama, | ||||
|                 EmbedderSource::OpenAi, | ||||
|                 EmbedderSource::Rest, | ||||
|                 EmbedderSource::UserProvided, | ||||
|             ], | ||||
|             _other => unreachable!("unknown field"), | ||||
|         } | ||||
|     } | ||||
| @@ -470,6 +479,7 @@ impl EmbeddingSettings { | ||||
|                 Self::DIMENSIONS, | ||||
|                 Self::DISTRIBUTION, | ||||
|                 Self::URL, | ||||
|                 Self::BINARY_QUANTIZED, | ||||
|             ], | ||||
|             EmbedderSource::HuggingFace => &[ | ||||
|                 Self::SOURCE, | ||||
| @@ -477,6 +487,7 @@ impl EmbeddingSettings { | ||||
|                 Self::REVISION, | ||||
|                 Self::DOCUMENT_TEMPLATE, | ||||
|                 Self::DISTRIBUTION, | ||||
|                 Self::BINARY_QUANTIZED, | ||||
|             ], | ||||
|             EmbedderSource::Ollama => &[ | ||||
|                 Self::SOURCE, | ||||
| @@ -486,8 +497,11 @@ impl EmbeddingSettings { | ||||
|                 Self::API_KEY, | ||||
|                 Self::DIMENSIONS, | ||||
|                 Self::DISTRIBUTION, | ||||
|                 Self::BINARY_QUANTIZED, | ||||
|             ], | ||||
|             EmbedderSource::UserProvided => &[Self::SOURCE, Self::DIMENSIONS, Self::DISTRIBUTION], | ||||
|             EmbedderSource::UserProvided => { | ||||
|                 &[Self::SOURCE, Self::DIMENSIONS, Self::DISTRIBUTION, Self::BINARY_QUANTIZED] | ||||
|             } | ||||
|             EmbedderSource::Rest => &[ | ||||
|                 Self::SOURCE, | ||||
|                 Self::API_KEY, | ||||
| @@ -498,6 +512,7 @@ impl EmbeddingSettings { | ||||
|                 Self::RESPONSE, | ||||
|                 Self::HEADERS, | ||||
|                 Self::DISTRIBUTION, | ||||
|                 Self::BINARY_QUANTIZED, | ||||
|             ], | ||||
|         } | ||||
|     } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user