アプリ関連ニュース
- 2023年11月29日
- AI
ローカルでチャットAIを動作させる
tanaka at 2023年11月29日 10:00:00
- 2023年11月28日
- 技術情報
Writing User CRUD API Feature Test in Laravel
Laravel empowers developers to build efficient and robust APIs effortlessly. Feature testing is an indispensable aspect of ensuring the reliability and functionality of our APIs, especially when it involves user CRUD operations. In this blog post, we’ll take a step-by-step journey through the code to feature test a User CRUD API in Laravel.
Step 1: Setting Up the Test Environment
Create a test class file with the following command.
php artisan make:test UserCrudApiTest
The test class file created can be found at tests/Feature/UserCrudApiTest.php and codes are as follows.
<?php
namespace Tests\Feature;
use Illuminate\Foundation\Testing\RefreshDatabase;
use Illuminate\Foundation\Testing\WithFaker;
use Tests\TestCase;
class UserCrudApiTest extends TestCase
{
/**
* A basic feature test example.
*
* @return void
*/
public function test_example()
{
$response = $this->get('/');
$response->assertStatus(200);
}
}
Step 2: Define and modify the Test Class
Import necessary classes and traits. And remove default test_example method.
<?php
namespace Tests\Feature;
use Illuminate\Foundation\Testing\RefreshDatabase;
use Illuminate\Foundation\Testing\WithFaker;
use Tests\TestCase;
use App\Models\User;
class UserCrudApiTest extends TestCase
{
use RefreshDatabase;
}
The `UserCrudApiTest` class is declared, extending `TestCase` and using `RefreshDatabase` for database isolation.
`RefreshDatabase` ensures a clean database state for each test, and `TestCase` is the base test case class. `User` is imported to create and interact with user models.
Step 3: Testing User Creation
public function test_user_can_be_created()
{
$userData = [
'name' => 'John Doe',
'email' => 'john@example.com',
'password' => bcrypt('password123'),
];
$response = $this->json('POST', '/api/users', $userData);
$response->assertStatus(201)
->assertJson([
'name' => 'John Doe',
'email' => 'john@example.com',
]);
$this->assertDatabaseHas('users', [
'name' => 'John Doe',
'email' => 'john@example.com',
]);
}
This method tests the creation of a user. The `$this->json(‘POST’, ‘/api/users’, $userData)` line sends a POST request to create a user with the specified data. Assertions ensure a successful response, correct JSON structure, and that the user is stored in the database.
Step 4: Testing User Retrieval
public function test_user_can_be_retrieved()
{
$user = factory(User::class)->create();
$response = $this->json('GET', "/api/users/{$user->id}");
$response->assertStatus(200)
->assertJson([
'name' => $user->name,
'email' => $user->email,
]);
}
This method tests the retrieval of a user. A user is created using the factory, and a GET request is made to fetch the user’s details. Assertions verify a successful response and the correctness of the returned data.
Step 5: Testing User Update
public function test_user_can_be_updated()
{
$user = factory(User::class)->create();
$updateData = [
'name' => 'Updated Name',
'email' => 'updated.email@example.com',
];
$response = $this->json('PUT', "/api/users/{$user->id}", $updateData);
$response->assertStatus(200)
->assertJson($updateData);
$this->assertDatabaseHas('users', [
'id' => $user->id,
'name' => 'Updated Name',
'email' => 'updated.email@example.com',
]);
}
This method tests updating a user’s details. A user is created, and a PUT request updates the user’s data. Assertions check for a successful response, the correctness of the returned JSON, and the updated data in the database.
Step 6: Testing User Deletion
public function test_user_can_be_deleted()
{
$user = factory(User::class)->create();
$response = $this->json('DELETE', "/api/users/{$user->id}");
$response->assertStatus(204);
$this->assertDatabaseMissing('users', ['id' => $user->id]);
}
This method tests the deletion of a user. A user is created, and a DELETE request is made to delete the user. Assertions ensure a successful response and confirm that the user is no longer present in the database.
After writing the necessary test methods, we can test with the following artisan command.
php artisan test --filter UserCrudApiTest
This command uses the --filter option to specify a particular test class, in this case, UserCrudApiTest. Only the tests within the UserCrudApiTest class will be executed.
The --filter option can also be used to run specific methods within a test class. For example:
php artisan test --filter UserCrudApiTest::test_user_can_be_created
Also php artisan test can be used to run all the tests in the application (all test files under tests dir).
Conclusion
Feature testing User CRUD operations in a Laravel API provides confidence in the functionality and reliability of the endpoints. Each step, from setup to testing each CRUD operation, contributes to a robust testing suite that helps maintain a high standard of code quality in our Laravel applications.
Hope you enjoy that.
Asahi
waithaw at 2023年11月28日 10:00:00
- 2023年11月27日
- AI
Google Bard expands capabilities to answer queries about YouTube videos
Google has recently announced a significant enhancement to its Bard AI chatbot, enabling it to provide specific answers to questions related to YouTube videos. While the initial YouTube Extension for Bard, launched in September, allowed users to find specific videos, the latest update empowers the chatbot to respond to queries about the content within videos.
This advancement means users can now engage in richer conversations with Bard, asking detailed questions such as the number of eggs required in a recipe featured in a particular video. Google acknowledges the users’ desire for deeper interaction with YouTube content and aims to fulfill this through Bard’s expanded capabilities.

This development follows YouTube’s recent experimentation with new generative AI features, introducing an AI conversational tool that answers questions about the platform’s content. This tool employs large language models to generate responses, utilizing information from both YouTube and the broader web. Users can now pose questions about the video they are watching, and the AI-driven conversation unfolds in real-time alongside the video playback. Additionally, YouTube has introduced a comments summarizer tool, leveraging generative AI to organize and summarize topics discussed in video comments, providing users with an overview of community discussions.
Coinciding with these updates, Google has expanded access to Bard for teenagers in most countries globally. In a blog post, Google highlighted the potential for teens to use Bard as a tool for inspiration, discovering new hobbies, and solving everyday problems. Whether seeking advice on university applications or exploring leisure activities, teens can now tap into Bard’s capabilities for a wide range of inquiries. This move aligns with Google’s commitment to making Bard a valuable resource for teens across various aspects of their lives.
Yuuma
yuuma at 2023年11月27日 10:00:00
- 2023年11月21日
- 技術情報
Getting Started with Unit Testing in Laravel
Unit testing is a crucial aspect of any robust software development process. In Laravel, a popular PHP framework, writing unit tests is not only easy but also highly encouraged. In this tutorial, we will go through the basics of writing unit tests in Laravel, ensuring the reliability and stability of the individual code units.
Prerequisites
Before diving into writing unit tests, make sure the following prerequisites be installed:
1. Composer
2. Laravel Installed
3. PHPUnit
Setting Up a Laravel Project
Use the following commands to set up a new project:
composer create-project --prefer-dist laravel/laravel my-laravel-app
cd my-laravel-app
Creating a Unit Test
Laravel provides a convenient Artisan command to generate a test class. Let’s create a simple unit test for a hypothetical `Calculator` class:
php artisan make:test CalculatorTest --unit
This will generate a test file located at `tests/Unit/CalculatorTest.php`. Open the file and you’ll see a basic test structure.
Writing a Unit Test
Now, let’s write a unit test for a basic addition method in our `Calculator` class. Open `CalculatorTest.php` and modify it as follows:
namespace Tests\Unit;
use PHPUnit\Framework\TestCase;
use App\Calculator;
class CalculatorTest extends TestCase
{
public function testAddition()
{
$calculator = new Calculator();
$result = $calculator->add(2, 3);
$this->assertEquals(5, $result);
}
}
In this example, assume we have a `Calculator` class in the `app` directory with an `add` method like that.
namespace App;
class Calculator
{
public function add($a, $b)
{
return $a + $b;
}
}
Running Unit Tests
To run the unit tests, use the following command:
php artisan test
This will execute all the tests in the `tests` directory.
Assertions
Laravel provides a variety of assertions that can be used in the tests. In this example, we used `assertEquals` to verify that the addition method returns the expected result. Explore other assertions and details in the official documentation https://laravel.com/docs/10.x/testing.
Conclusion
We’ve just written a first unit test in Laravel. As the application grows, writing tests for individual code units will become an integral part of the development process, ensuring that the code remains maintainable and reliable. Hope you enjoy that.
Asahi
waithaw at 2023年11月21日 10:00:00
- 2023年11月14日
- 技術情報
MongoDB Takes Control of Laravel Integration: Official Support Announced
MongoDB is now officially in charge of the Laravel framework’s community-driven MongoDB integration! This signals a commitment to regular updates, enhancing functionality, fixing bugs, and ensuring compatibility with the latest releases of both Laravel and MongoDB.

Formerly recognized as jenssegers/laravel-mongodb, this library expands Eloquent, Laravel’s ORM, providing PHP developers working with MongoDB a seamless experience through Eloquent models, query builders, and transactions.
For those eager to integrate MongoDB with the Laravel framework, explore the most recent release of this library, which introduces support for Laravel 10 – Laravel MongoDB 4.0.0. If you’re embarking on MongoDB PHP projects, a tutorial on constructing a Laravel + MongoDB back-end service and comprehensive library documentation are readily available here.
By Asahi
waithaw at 2023年11月14日 10:00:00