mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-26 13:36:27 +00:00 
			
		
		
		
	Merge #3269
3269: Simplify primary key inference r=dureuill a=dureuill # Pull Request ## Related issue Related to https://github.com/meilisearch/meilisearch/issues/3233 ## What does this PR do? - Integrates https://github.com/meilisearch/milli/pull/752 in meilisearch - Remove `Serialize` and `Deserialize` from `error::Code` as it is unused. - No longer filter on `milli` logs when `--log-level` is "info". - `milli` only has the newly-added inference log at the `info` level (from greping `info` in the codebase) - the default value for `--log-level` is "INFO" and not "info" since `v0.30` so the filter is not active by default. - updates milli to v0.38.0 ## PR checklist Please check if your PR fulfills the following requirements: - [x] Does this PR fix an existing issue, or have you listed the changes applied in the PR description (and why they are needed)? - [x] Have you read the contributing guidelines? - [x] Have you made sure that the title is accurate and descriptive of the changes? Thank you so much for contributing to Meilisearch! Co-authored-by: Louis Dureuil <louis@meilisearch.com>
This commit is contained in:
		| @@ -76,6 +76,7 @@ yaup = "0.2.0" | ||||
| actix-rt = "2.7.0" | ||||
| assert-json-diff = "2.0.2" | ||||
| brotli = "3.3.4" | ||||
| insta = "1.19.1" | ||||
| manifest-dir-macros = "0.1.16" | ||||
| maplit = "1.0.2" | ||||
| meili-snap = {path = "../meili-snap"} | ||||
|   | ||||
| @@ -7,7 +7,6 @@ use actix_web::web::Data; | ||||
| use actix_web::HttpServer; | ||||
| use index_scheduler::IndexScheduler; | ||||
| use meilisearch::analytics::Analytics; | ||||
| use meilisearch::option::LogLevel; | ||||
| use meilisearch::{analytics, create_app, setup_meilisearch, Opt}; | ||||
| use meilisearch_auth::{generate_master_key, AuthController, MASTER_KEY_MIN_SIZE}; | ||||
|  | ||||
| @@ -18,10 +17,6 @@ static ALLOC: mimalloc::MiMalloc = mimalloc::MiMalloc; | ||||
| fn setup(opt: &Opt) -> anyhow::Result<()> { | ||||
|     let mut log_builder = env_logger::Builder::new(); | ||||
|     log_builder.parse_filters(&opt.log_level.to_string()); | ||||
|     if matches!(opt.log_level, LogLevel::Info) { | ||||
|         // if we are in info we only allow the warn log_level for milli | ||||
|         log_builder.filter_module("milli", log::LevelFilter::Warn); | ||||
|     } | ||||
|  | ||||
|     log_builder.init(); | ||||
|  | ||||
|   | ||||
| @@ -896,16 +896,104 @@ async fn error_primary_key_inference() { | ||||
|     index.wait_task(0).await; | ||||
|     let (response, code) = index.get_task(0).await; | ||||
|     assert_eq!(code, 200); | ||||
|     assert_eq!(response["status"], "failed"); | ||||
|  | ||||
|     let expected_error = json!({ | ||||
|         "message": r#"The primary key inference process failed because the engine did not find any fields containing `id` substring in their name. If your document identifier does not contain any `id` substring, you can set the primary key of the index."#, | ||||
|         "code": "primary_key_inference_failed", | ||||
|     insta::assert_json_snapshot!(response, { ".duration" => "[duration]", ".enqueuedAt" => "[date]", ".startedAt" => "[date]", ".finishedAt" => "[date]" }, | ||||
|     @r###" | ||||
|     { | ||||
|       "uid": 0, | ||||
|       "indexUid": "test", | ||||
|       "status": "failed", | ||||
|       "type": "documentAdditionOrUpdate", | ||||
|       "canceledBy": null, | ||||
|       "details": { | ||||
|         "receivedDocuments": 1, | ||||
|         "indexedDocuments": 1 | ||||
|       }, | ||||
|       "error": { | ||||
|         "message": "The primary key inference process failed because the engine did not find any field ending with `id` in its name. Please specify the primary key manually using the `primaryKey` query parameter.", | ||||
|         "code": "index_primary_key_no_candidate_found", | ||||
|         "type": "invalid_request", | ||||
|         "link": "https://docs.meilisearch.com/errors#primary_key_inference_failed" | ||||
|     }); | ||||
|         "link": "https://docs.meilisearch.com/errors#index_primary_key_no_candidate_found" | ||||
|       }, | ||||
|       "duration": "[duration]", | ||||
|       "enqueuedAt": "[date]", | ||||
|       "startedAt": "[date]", | ||||
|       "finishedAt": "[date]" | ||||
|     } | ||||
|     "###); | ||||
|  | ||||
|     assert_eq!(response["error"], expected_error); | ||||
|     let documents = json!([ | ||||
|         { | ||||
|             "primary_id": "12", | ||||
|             "object_id": "42", | ||||
|             "id": "124", | ||||
|             "title": "11", | ||||
|             "desc": "foobar" | ||||
|         } | ||||
|     ]); | ||||
|  | ||||
|     index.add_documents(documents, None).await; | ||||
|     index.wait_task(1).await; | ||||
|     let (response, code) = index.get_task(1).await; | ||||
|     assert_eq!(code, 200); | ||||
|  | ||||
|     insta::assert_json_snapshot!(response, { ".duration" => "[duration]", ".enqueuedAt" => "[date]", ".startedAt" => "[date]", ".finishedAt" => "[date]" }, | ||||
|     @r###" | ||||
|     { | ||||
|       "uid": 1, | ||||
|       "indexUid": "test", | ||||
|       "status": "failed", | ||||
|       "type": "documentAdditionOrUpdate", | ||||
|       "canceledBy": null, | ||||
|       "details": { | ||||
|         "receivedDocuments": 1, | ||||
|         "indexedDocuments": 1 | ||||
|       }, | ||||
|       "error": { | ||||
|         "message": "The primary key inference process failed because the engine found 3 fields ending with `id` in their name, such as 'id' and 'object_id'. Please specify the primary key manually using the `primaryKey` query parameter.", | ||||
|         "code": "index_primary_key_multiple_candidates_found", | ||||
|         "type": "invalid_request", | ||||
|         "link": "https://docs.meilisearch.com/errors#index_primary_key_multiple_candidates_found" | ||||
|       }, | ||||
|       "duration": "[duration]", | ||||
|       "enqueuedAt": "[date]", | ||||
|       "startedAt": "[date]", | ||||
|       "finishedAt": "[date]" | ||||
|     } | ||||
|     "###); | ||||
|  | ||||
|     let documents = json!([ | ||||
|         { | ||||
|             "primary_id": "12", | ||||
|             "title": "11", | ||||
|             "desc": "foobar" | ||||
|         } | ||||
|     ]); | ||||
|  | ||||
|     index.add_documents(documents, None).await; | ||||
|     index.wait_task(2).await; | ||||
|     let (response, code) = index.get_task(2).await; | ||||
|     assert_eq!(code, 200); | ||||
|  | ||||
|     insta::assert_json_snapshot!(response, { ".duration" => "[duration]", ".enqueuedAt" => "[date]", ".startedAt" => "[date]", ".finishedAt" => "[date]" }, | ||||
|     @r###" | ||||
|     { | ||||
|       "uid": 2, | ||||
|       "indexUid": "test", | ||||
|       "status": "succeeded", | ||||
|       "type": "documentAdditionOrUpdate", | ||||
|       "canceledBy": null, | ||||
|       "details": { | ||||
|         "receivedDocuments": 1, | ||||
|         "indexedDocuments": 1 | ||||
|       }, | ||||
|       "error": null, | ||||
|       "duration": "[duration]", | ||||
|       "enqueuedAt": "[date]", | ||||
|       "startedAt": "[date]", | ||||
|       "finishedAt": "[date]" | ||||
|     } | ||||
|     "###); | ||||
| } | ||||
|  | ||||
| #[actix_rt::test] | ||||
|   | ||||
		Reference in New Issue
	
	Block a user