


Tester l'égalité entre les colonnes JSON dans Laravel nécessite une attention particulière puisque les données JSON sont stockées sous forme de chaînes dans la base de données. Les différences dans la façon dont JSON est codé peuvent entraîner des échecs de test inattendus lors de la comparaison des colonnes JSON. Cet article vous guidera pour comparer efficacement les colonnes JSON dans les tests de votre application Laravel.
Comprendre le défi
Lorsque les données JSON sont stockées dans la base de données, elles sont enregistrées sous forme de chaîne. Des différences mineures dans le codage JSON, telles que l'espacement ou l'ordre des clés, peuvent entraîner l'échec des comparaisons directes de chaînes. Cela signifie que même si le contenu est logiquement équivalent, les tests utilisant $this->assertDatabaseHas() peuvent échouer.
Exemple de modèle
Tout d'abord, considérons le modèle PriceSchedule, qui inclut des colonnes JSON :
final class PriceSchedule extends Model { protected $fillable = [ 'user_id', 'price_supplier_id', 'weekday', 'hour', 'is_active' ]; protected $casts = [ 'weekday' => 'array', 'hour' => 'array', ]; }
Les attributs du jour de la semaine et de l'heure sont convertis en tableaux, permettant une manipulation facile dans votre application.
Écrire le test
Voici un exemple de test de mise à jour d'un PriceSchedule :
final class PriceExportScheduleTest extends TestCase { public function test_price_export_schedule_update(): void { $user = UserFactory::new()->create(); $this->actingAsFrontendUser($user); $priceSchedule = PriceScheduleFactory::new()->make(); $updatedData = [ 'weekday' => $this->faker->randomElements(DayOfWeek::values(), 3), 'hour' => $priceSchedule->hour, 'is_active' => true, ]; $response = $this->putJson(route('api-v2:price-export.suppliers.schedules.update'), $updatedData); $response->assertNoContent(); $this->assertDatabaseHas(PriceSchedule::class, [ 'user_id' => $user->id, 'is_active' => $updatedData['is_active'], 'weekday' => $updatedData['weekday'], 'hour' => $updatedData['hour'], ]); } }
Problème courant avec les comparaisons JSON
Lorsque vous utilisez $this->assertDatabaseHas() pour comparer des valeurs de type JSON telles que le jour de la semaine et l'heure, les comparaisons directes peuvent échouer en raison de différences dans l'encodage JSON. Par exemple :
- JSON stocké dans la base de données : {"key":"value"}
- JSON généré par PHP : { "clé": "valeur" }
Même si les données sont logiquement identiques, le test peut échouer car les chaînes diffèrent.
Solution : utilisez $this->castAsJson()
Pour garantir des comparaisons cohérentes, utilisez $this->castAsJson() lors de l'affirmation de colonnes JSON :
$this->assertDatabaseHas(PriceSchedule::class, [ 'user_id' => $user->id, 'is_active' => $updatedData['is_active'], 'weekday' => $this->castAsJson($updatedData['weekday']), 'hour' => $this->castAsJson($updatedData['hour']), ]);
Cette méthode garantit que les données de test et les données de la base de données sont converties dans un format JSON commun avant la comparaison.
Sortie de test
L'exécution du test produit le résultat suivant :
Price Export Schedule (PriceExportSchedule) ✔ Price export schedule update OK (1 test, 3 assertions)
En utilisant $this->castAsJson(), vous pouvez éviter les problèmes d'encodage JSON et vous assurer que vos tests sont à la fois fiables et
précis.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Les longues URL, souvent encombrées de mots clés et de paramètres de suivi, peuvent dissuader les visiteurs. Un script de raccourcissement d'URL offre une solution, créant des liens concis idéaux pour les médias sociaux et d'autres plateformes. Ces scripts sont utiles pour les sites Web individuels

À la suite de son acquisition de haut niveau par Facebook en 2012, Instagram a adopté deux ensembles d'API pour une utilisation tierce. Ce sont l'API graphique Instagram et l'API d'affichage de base Instagram. En tant que développeur créant une application qui nécessite des informations à partir d'un

Laravel simplifie la gestion des données de session temporaires à l'aide de ses méthodes de flash intuitives. Ceci est parfait pour afficher de brefs messages, alertes ou notifications dans votre application. Les données ne persistent que pour la demande ultérieure par défaut: $ demande-

Il s'agit de la deuxième et dernière partie de la série sur la construction d'une application React avec un back-end Laravel. Dans la première partie de la série, nous avons créé une API RESTful utilisant Laravel pour une application de liste de base sur le produit. Dans ce tutoriel, nous serons Dev

Laravel fournit une syntaxe de simulation de réponse HTTP concise, simplifiant les tests d'interaction HTTP. Cette approche réduit considérablement la redondance du code tout en rendant votre simulation de test plus intuitive. L'implémentation de base fournit une variété de raccourcis de type de réponse: Utiliser illuminate \ support \ faades \ http; Http :: faux ([[ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

L'extension PHP Client URL (CURL) est un outil puissant pour les développeurs, permettant une interaction transparente avec des serveurs distants et des API REST. En tirant parti de Libcurl, une bibliothèque de transfert de fichiers multi-protocol très respectée, PHP Curl facilite Efficient Execu

Voulez-vous fournir des solutions instantanées en temps réel aux problèmes les plus pressants de vos clients? Le chat en direct vous permet d'avoir des conversations en temps réel avec les clients et de résoudre leurs problèmes instantanément. Il vous permet de fournir un service plus rapide à votre personnalité

L'enquête sur le paysage PHP 2025 étudie les tendances actuelles de développement du PHP. Il explore l'utilisation du cadre, les méthodes de déploiement et les défis, visant à fournir des informations aux développeurs et aux entreprises. L'enquête prévoit la croissance de la PHP moderne versio


Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

SublimeText3 Linux nouvelle version
Dernière version de SublimeText3 Linux

Version crackée d'EditPlus en chinois
Petite taille, coloration syntaxique, ne prend pas en charge la fonction d'invite de code

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

Dreamweaver Mac
Outils de développement Web visuel
