-
Notifications
You must be signed in to change notification settings - Fork 1.4k
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
DOCSP-35974: Update one usage example #2781
Changes from all commits
2a01a1f
5d5bc52
de2fb19
0f0479c
6edf281
8bcf1a7
a1238b0
30be915
3f9ef3d
82a4f20
74db7ef
c9e279c
ae4bb21
5ceb6b3
97187cd
d9aa3c1
0008e18
cb10358
6c3d851
71f72e7
f3ac9c8
b237a86
4856810
777e3cb
d67827a
abab190
d7b03f1
aabaf2c
2fb18a5
3f9e394
1c90a28
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,12 @@ | ||
<?php | ||
|
||
namespace App\Models; | ||
|
||
use MongoDB\Laravel\Eloquent\Model; | ||
|
||
class Movie extends Model | ||
{ | ||
protected $connection = 'mongodb'; | ||
protected $collection = 'movies'; | ||
protected $fillable = ['title', 'year', 'runtime', 'imdb', 'plot']; | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,48 @@ | ||
<?php | ||
|
||
declare(strict_types=1); | ||
|
||
namespace App\Http\Controllers; | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. @GromNaN: more generally I don't see a clear benefit to putting PHPUnit test files outside of the Based on the current PHPUnit configuration, these files won't be picked up by the test suite (nor tools like phpcs and phpstan). It might make more sense to organize these files within the actual test suite and then have docs refer to them there. And in that case, we can use meaningful namespaces. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. The namespace is of no particular interest. I think we'll come back to it to clean it up. |
||
|
||
use App\Models\Movie; | ||
use MongoDB\Laravel\Tests\TestCase; | ||
|
||
class UpdateOneTest extends TestCase | ||
{ | ||
/** | ||
* @runInSeparateProcess | ||
* @preserveGlobalState disabled | ||
*/ | ||
public function testUpdateOne(): void | ||
{ | ||
require_once __DIR__ . '/Movie.php'; | ||
|
||
Movie::truncate(); | ||
Movie::insert([ | ||
[ | ||
'title' => 'Carol', | ||
'imdb' => [ | ||
'rating' => 7.2, | ||
'votes' => 125000, | ||
], | ||
], | ||
]); | ||
|
||
// begin-update-one | ||
$updates = Movie::where('title', 'Carol') | ||
->orderBy('_id') | ||
->first() | ||
->update([ | ||
'imdb' => [ | ||
'rating' => 7.3, | ||
'votes' => 142000, | ||
], | ||
]); | ||
|
||
echo 'Updated documents: ' . $updates; | ||
// end-update-one | ||
|
||
$this->assertTrue($updates); | ||
$this->expectOutputString('Updated documents: 1'); | ||
} | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,67 @@ | ||
.. _laravel-update-one-usage: | ||
|
||
================= | ||
Update a Document | ||
================= | ||
norareidy marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
.. facet:: | ||
:name: genre | ||
:values: reference | ||
|
||
.. meta:: | ||
:keywords: update one, modify, code example | ||
|
||
.. contents:: On this page | ||
:local: | ||
:backlinks: none | ||
:depth: 1 | ||
:class: singlecol | ||
|
||
You can update a document in a collection by retrieving a single document and calling | ||
the ``update()`` method on an Eloquent model or a query builder. | ||
|
||
Pass a query filter to the ``where()`` method, sort the matching documents, and call the | ||
``first()`` method to retrieve only the first document. Then, update this matching document | ||
by passing your intended document changes to the ``update()`` method. | ||
|
||
Example | ||
------- | ||
|
||
This usage example performs the following actions: | ||
|
||
- Uses the ``Movie`` Eloquent model to represent the ``movies`` collection in the | ||
``sample_mflix`` database. | ||
- Updates a document from the ``movies`` collection that matches a query filter. | ||
|
||
The example calls the following methods on the ``Movie`` model: | ||
|
||
- ``where()``: matches documents in which the value of the ``title`` field is ``'Carol'``. | ||
- ``orderBy()``: sorts matched documents by their ascending ``_id`` values. | ||
- ``first()``: retrieves only the first matching document. | ||
- ``update()``: updates the value of the ``imdb.rating`` nested field to from ``6.9`` to | ||
``7.3``. This method also updates the ``imdb.votes`` nested field from ``493`` to ``142000``. | ||
|
||
.. io-code-block:: | ||
:copyable: true | ||
|
||
.. input:: ../includes/usage-examples/UpdateOneTest.php | ||
:start-after: begin-update-one | ||
:end-before: end-update-one | ||
:language: php | ||
:dedent: | ||
|
||
.. output:: | ||
:language: console | ||
:visible: false | ||
|
||
Updated documents: 1 | ||
|
||
For instructions on editing your Laravel application to run the usage example, see the | ||
:ref:`Usage Example landing page <laravel-usage-examples>`. | ||
|
||
.. tip:: | ||
|
||
To learn more about updating data with {+odm-short+}, see the `Updates | ||
<https://laravel.com/docs/{+laravel-docs-version+}/eloquent#updates>`__ section of the | ||
Laravel documentation. | ||
|
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.
I get the following error when running this file:
Could not open input file: vendor/bin/phpunit
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.
That would get installed by running
composer update
from the repository root to install all dependencies incomposer.json
(bothrequire
andrequire-dev
).Was the error above based on following instructions in Contributing: Run Tests. It's not clear to me how this file would even be picked up by the normal test suite (files under
tests/
), so I'll defer to @GromNaN to follow up here.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.
I'm following these instructions, but I was running the command in the wrong folder; here's what I get now:
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.
#2795 should address this.