mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-24 20:46:27 +00:00 
			
		
		
		
	3370: make the swap indexes not found errors return an IndexNotFound error-code r=irevoire a=irevoire Fix https://github.com/meilisearch/meilisearch/issues/3368 3373: fix a wrong error code and add tests on the document resource r=irevoire a=irevoire Fix https://github.com/meilisearch/meilisearch/issues/3371 3375: Avoid deleting all task invalid canceled by r=irevoire a=Kerollmops Fixes #3369 by making sure that at least one `canceledBy` task filter parameter matches something. Co-authored-by: Tamo <tamo@meilisearch.com> Co-authored-by: Kerollmops <clement@meilisearch.com>
This commit is contained in:
		| @@ -141,8 +141,8 @@ impl ErrorCode for Error { | ||||
|             Error::IndexAlreadyExists(_) => Code::IndexAlreadyExists, | ||||
|             Error::SwapDuplicateIndexesFound(_) => Code::InvalidSwapDuplicateIndexFound, | ||||
|             Error::SwapDuplicateIndexFound(_) => Code::InvalidSwapDuplicateIndexFound, | ||||
|             Error::SwapIndexNotFound(_) => Code::InvalidSwapIndexes, | ||||
|             Error::SwapIndexesNotFound(_) => Code::InvalidSwapIndexes, | ||||
|             Error::SwapIndexNotFound(_) => Code::IndexNotFound, | ||||
|             Error::SwapIndexesNotFound(_) => Code::IndexNotFound, | ||||
|             Error::InvalidTaskDate { field, .. } => (*field).into(), | ||||
|             Error::InvalidTaskUids { .. } => Code::InvalidTaskUids, | ||||
|             Error::InvalidTaskStatuses { .. } => Code::InvalidTaskStatuses, | ||||
|   | ||||
| @@ -502,13 +502,22 @@ impl IndexScheduler { | ||||
|         } | ||||
|  | ||||
|         if let Some(canceled_by) = &query.canceled_by { | ||||
|             let mut all_canceled_tasks = RoaringBitmap::new(); | ||||
|             for cancel_task_uid in canceled_by { | ||||
|                 if let Some(canceled_by_uid) = | ||||
|                     self.canceled_by.get(rtxn, &BEU32::new(*cancel_task_uid))? | ||||
|                 { | ||||
|                     tasks &= canceled_by_uid; | ||||
|                     all_canceled_tasks |= canceled_by_uid; | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|             // if the canceled_by has been specified but no task | ||||
|             // matches then we prefer matching zero than all tasks. | ||||
|             if all_canceled_tasks.is_empty() { | ||||
|                 return Ok(RoaringBitmap::new()); | ||||
|             } else { | ||||
|                 tasks &= all_canceled_tasks; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         if let Some(kind) = &query.types { | ||||
|   | ||||
| @@ -10,7 +10,7 @@ source: index-scheduler/src/lib.rs | ||||
| 1 {uid: 1, status: succeeded, details: { primary_key: Some("id") }, kind: IndexCreation { index_uid: "b", primary_key: Some("id") }} | ||||
| 2 {uid: 2, status: succeeded, details: { primary_key: Some("id") }, kind: IndexCreation { index_uid: "c", primary_key: Some("id") }} | ||||
| 3 {uid: 3, status: succeeded, details: { primary_key: Some("id") }, kind: IndexCreation { index_uid: "d", primary_key: Some("id") }} | ||||
| 4 {uid: 4, status: failed, error: ResponseError { code: 200, message: "Indexes `e`, `f` not found.", error_code: "invalid_swap_indexes", error_type: "invalid_request", error_link: "https://docs.meilisearch.com/errors#invalid-swap-indexes" }, details: { swaps: [IndexSwap { indexes: ("a", "b") }, IndexSwap { indexes: ("c", "e") }, IndexSwap { indexes: ("d", "f") }] }, kind: IndexSwap { swaps: [IndexSwap { indexes: ("a", "b") }, IndexSwap { indexes: ("c", "e") }, IndexSwap { indexes: ("d", "f") }] }} | ||||
| 4 {uid: 4, status: failed, error: ResponseError { code: 200, message: "Indexes `e`, `f` not found.", error_code: "index_not_found", error_type: "invalid_request", error_link: "https://docs.meilisearch.com/errors#index-not-found" }, details: { swaps: [IndexSwap { indexes: ("a", "b") }, IndexSwap { indexes: ("c", "e") }, IndexSwap { indexes: ("d", "f") }] }, kind: IndexSwap { swaps: [IndexSwap { indexes: ("a", "b") }, IndexSwap { indexes: ("c", "e") }, IndexSwap { indexes: ("d", "f") }] }} | ||||
| ---------------------------------------------------------------------- | ||||
| ### Status: | ||||
| enqueued [] | ||||
|   | ||||
		Reference in New Issue
	
	Block a user