-
Notifications
You must be signed in to change notification settings - Fork 104
Tasks refactor v1 #337
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Tasks refactor v1 #337
Conversation
| { | ||
| $this->expectException(ApiException::class); | ||
| $this->index->getTask(9999999999); | ||
| $this->index->getTask(99999999); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Reference: meilisearch/meilisearch#2555
|
|
||
| $this->assertIsArray($promise); | ||
| $response = $this->index->getTasks(); | ||
| $this->assertCount($preCount + 1, $response['results']); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The test is basically the same, but now we cannot trust the size of the list anymore, so the idea is to just compare the most recent item if they changed, we can ensure that we are filtering by index. And in the other similar test the opposite is what we look for.
alallema
left a comment
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Well done ✨ !!!
Just one comment about the refactor of the index.getTask(uid)
| public function getTask($uid): array | ||
| { | ||
| return $this->http->get(self::PATH.'/'.$this->uid.'/tasks'.'/'.$uid); | ||
| return $this->http->get('/tasks/'.$uid, ['indexUid' => $this->uid]); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
On the general issue it specified the following point:
Remove GET
/indexes/:indexUid/tasks/:taskUid. Use GET/tasks/:taskUidinstead.
So shouldn't it be something like
| return $this->http->get('/tasks/'.$uid, ['indexUid' => $this->uid]); | |
| return $this->http->get('/tasks'.'/'.$uid); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You're right! :)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Even better you can use the one from the client maybe
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@alallema is there any particular reason to suggest:
('/tasks'.'/'.$uid);instead of:
('/tasks/'.$uid);|
@alallema I'll apply your suggestion in a next PR :) |
350: Update version for the next release (v0.24.0) r=brunoocasali a=brunoocasali This version makes this package compatible with Meilisearch v0.28.0 🎉 Check out the changelog of [Meilisearch v0.28.0](https://github.com/meilisearch/meilisearch/releases/tag/v0.28.0) for more information on the changes. ## 💥 Breaking changes :warning: Small disclaimer: The `rawSearch` (and other `raw*` functions) are a direct connection between your PHP application and Meilisearch, you may find changes that are not present in this section. - `MeiliSearch\Client->getDumpStatus` method was removed. (#336) `@brunoocasali` - `MeiliSearch\Client->getIndexes` method now return a object type `IndexesResults`. (#341), (#345) `@brunoocasali` - `MeiliSearch\Client->generateTenantToken` now require a `String apiKeyUid` which is the `uid` of the `Key` instance used to sign the token. (#343) `@brunoocasali` - `MeiliSearch\Client->createDump` now responds with `Task` object. (#336, #337) `@brunoocasali` - `MeiliSearch\Client->getKeys` method now return a object type `KeysResults`. (#343), (#338) `@brunoocasali` - `MeiliSearch\Client->updateKey` now can just update a `description` and/or `name`, if there are other key/value will be silently ignored. (#343), (#338) `@brunoocasali` - `MeiliSearch\Client->getTasks` method now return a object type `TasksResults`. (#337), (#346) `@brunoocasali` - `MeiliSearch\Index->getTasks` method now return a object type `TasksResults`. (#337), (#346) `@brunoocasali` - `MeiliSearch\Index->search` `facetsDistribution` is now `facets` (#332) `@curquiza` - `MeiliSearch\Index->search` `matches` is now `showMatchesPosition` (#332) `@curquiza` - `MeiliSearch\Index->getDocuments` method now return a object type `DocumentsResults`. - `MeiliSearch\Index->getDocuments` method now accepts a object as a parameter and `offset`, `limit`, `attributesToRetrieve` were not longer accepted. - `exhaustiveNbHits`, `facetsDistribution`, `exhaustiveFacetsCount` were removed from `SearchResult`. (#332) `@curquiza` ## 🚀 Enhancements - `MeiliSearch\Client->getIndexes` accepts a object `IndexesQuery` to filter and paginate the results. - `MeiliSearch\Client->getKeys` accepts a object `KeysQuery` to filter and paginate the results. (#343), (#338) `@brunoocasali` - `MeiliSearch\Client->getKey` accepts both a `Key#uid` or `Key#key` value. (#343), (#338) `@brunoocasali` - `MeiliSearch\Client->getTasks` accepts a object `TasksQuery` to filter and paginate the results. (#337), (#346) `@brunoocasali` - `MeiliSearch\Index->getTasks` accepts a object `TasksQuery` to filter and paginate the results. (#337), (#346) `@brunoocasali` - `MeiliSearch\Client->createKey` can specify a `uid` (optionally) to create a new `Key`. (#343), (#338) `@brunoocasali` - `MeiliSearch\Index->getDocument` accepts a `fields` list to compact the remap the response. (#340), (#344) `@brunoocasali` - `MeiliSearch\Index->getDocuments` accepts a object `DocumentsQuery` to filter and paginate the results. (#340), (#344) `@brunoocasali` - `Key` has now a `name` and `uid` string fields. (#343), (#338) `@brunoocasali` - `estimatedTotalHits`, `facetDistribution` were added to `SearchResult` (#332) `@curquiza` - `nbHits` is still defined and will contain the same value as `estimatedTotalHits`. - Sending a invalid `uid` or `apiKey` will raise `InvalidApiKeyException`. (#343) `@brunoocasali` Thanks again to `@brunoocasali,` `@curquiza!` 🎉 Co-authored-by: Bruno Casali <[email protected]>
This PR changes all the places that currently are handling the summarized task version from
uidtotaskUid. And replace the tasks route index namespace with the global one + add the ability to infer the index from it.disclaimer: The work in the tasks is not done yet, this is the first step.