recherche
Maisondéveloppement back-endtutoriel phpTemps de congélation: tester les URL de stockage temporaire de Laravel

Freezing Time: Testing Laravel Temporary Storage URLs

Dans l'article précédent "Tester l'URL provisoire dans le stockage de Laravel", nous avons discuté de la technique de deux méthodes

pour tester Laravel. Bien que il ne prenne pas en charge Storage::temporaryUrl(), nous démontrons comment utiliser la simulation pour simuler efficacement son comportement. Si vous ne l'avez pas encore lu, il est recommandé de le lire d'abord pour comprendre les connaissances de base du test de l'URL temporaire dans Laravel. Storage::fake temporaryUrl Cet article sera dans des discussions sur la façon de passer le temps de congélation pour rendre le test URL temporaire plus fiable, en particulier en termes de fonctions sensibles au temps. Nous utiliserons les fonctions auxiliaires du test construit par Laravel et la fonction de fonctionnement du temps de Carbon pour résoudre l'incohérence potentielle du test.

Pourquoi le temps gelé est important

URL temporaire contient généralement des horodatages expirés pour le rendre sensible au temps. Dans l'environnement de test, une petite quantité de retard pendant le processus d'exécution entraînera le temps d'expiration de ne pas correspondre, entraînant la défaillance du test. Par exemple:

Lorsque le horodatage d'expiration généré pendant l'exécution du test est légèrement différent en raison du décalage de temps, cela se produira. Le temps de gel s'assurera que toutes les opérations liées au temps de retour à des valeurs cohérentes pour éliminer cette différence.
<code>断言两个字符串相等失败。
预期值:'http://localhost/test/image?expiration=1737729799'
实际值:'http://localhost/test/image?expiration=1737729800'</code>

Fonction auxiliaire congelée du temps de Laravel

Laravel fournit plusieurs méthodes pour geler et faire fonctionner le temps dans les tests:

  • : Temps gelé au moment actuel. Chaque fois que les appels basés sur le temps utiliseront ce temps de congélation. $this->freezeTime()
  • : simule le point spécifique de passer à l'heure.
  • $this->travelTo(Carbon::now()) : Réglez l'heure actuelle pour toutes les opérations de carbone.
  • Ces méthodes vous permettent de contrôler le passage du temps et d'assurer la cohérence du test. Carbon::setTestNow(Carbon::now()) Pour plus de détails, veuillez vous référer aux ressources suivantes:

Temps congelé dans le test de Laravel

Temps congelé dans le test

  • Exemple pratique: utilisez une URL temporaire pour obtenir des images externes
  • Contrôleur
  • Il s'agit d'une image d'obtention de la source externe, de la stockage dans le stockage local et génère une URL temporaire pour faire un contrôleur de redirection:

Cette méthode garantit que si l'image n'existe pas, elle sera obtenue et stockée de l'extérieur, puis l'utilisateur est redirigé vers l'URL temporaire de l'image.

Contrôleur de test

Ce qui suit est de savoir comment utiliser le temps figé pour tester les fonctions ci-dessus:

<code>断言两个字符串相等失败。
预期值:'http://localhost/test/image?expiration=1737729799'
实际值:'http://localhost/test/image?expiration=1737729800'</code>

Points clés:

  1. : Assurez-vous que les opérations basées sur tous les temps dans le test utilisent le même temps. $this->freezeTime() Affirmation de stockage
  2. :
  3. : Le fichier n'existe pas avant l'opération de vérification.
      : Le fichier a été stocké après avoir confirmé l'opération.
    • assertMissing
    • HTTP Simulation assertExists: Simulation API externe API pour obtenir des images.
    Vérification temporaire de l'URL
  4. : Comparaison des attentes et des URL temporaires réelles, car le temps est gelé, ils restent cohérents.
  5. S'il n'y a pas de temps de congélation, ce test peut échouer en raison de l'horodatage de l'URL temporaire.
  6. Conclusion Le temps congelé est une technologie simple et puissante qui peut assurer la fiabilité des tests sensibles au temps. En combinant les fonctions auxiliaires de test de Laravel () et la méthode de fonctionnement du temps de Carbon (
  7. ), vous pouvez éliminer l'incohérence causée par le retard d'exécution.

En adoptant ces pratiques, vous aurez des tests qui pourront prédire et avoir des URL temporaires plus puissantes et d'autres fonctions sensibles au temps.

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!

Déclaration
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Quelles données peuvent être stockées dans une session PHP?Quelles données peuvent être stockées dans une session PHP?May 02, 2025 am 12:17 AM

PhpSessionsCanstorestrings, Numbers, Arrays, Andobject.1.Strings: TextDatalikeUserames.2.Numbers: IntegersorFloatsForCounters.3.arrays: listslikeshoppingcarts.4.Objects: complexestructuresthataReSerialized.

Comment démarrez-vous une session PHP?Comment démarrez-vous une session PHP?May 02, 2025 am 12:16 AM

TostartaphpSession, usessession_start () aTTheScript'sbeginning.1) PlaceItBeForeanyOutputToSetTheSessionCooKie.2) USESSIONSFORUSERDATALIKELOGINSTATUSORSHOPPINGSCARS.3) RegegeraSesessionIdStopreventfixationAtTACKS.4)

Qu'est-ce que la régénération des sessions et comment améliore-t-elle la sécurité?Qu'est-ce que la régénération des sessions et comment améliore-t-elle la sécurité?May 02, 2025 am 12:15 AM

La régénération de session fait référence à la génération d'un nouvel ID de session et à l'invalidation de l'ancien ID lorsque l'utilisateur effectue des opérations sensibles en cas d'attaques fixes de session. Les étapes de mise en œuvre incluent: 1. Détectez les opérations sensibles, 2. Générer un nouvel ID de session, 3. Détruiser l'ancien ID de session, 4. Mettre à jour les informations de session côté utilisateur.

Quelles sont les considérations de performances lors de l'utilisation de sessions PHP?Quelles sont les considérations de performances lors de l'utilisation de sessions PHP?May 02, 2025 am 12:11 AM

Les séances PHP ont un impact significatif sur les performances des applications. Les méthodes d'optimisation incluent: 1. Utilisez une base de données pour stocker les données de session pour améliorer la vitesse de réponse; 2. Réduire l'utilisation des données de session et stocker uniquement les informations nécessaires; 3. Utilisez un processeur de session non bloquant pour améliorer les capacités de concurrence; 4. Ajustez le temps d'expiration de la session pour équilibrer l'expérience utilisateur et la charge du serveur; 5. Utilisez des séances persistantes pour réduire le nombre de données de lecture et d'écriture.

En quoi les séances PHP diffèrent-elles des cookies?En quoi les séances PHP diffèrent-elles des cookies?May 02, 2025 am 12:03 AM

PhpsessionsareServer-côté, whileCookiesareclient-Side.1) SessionStoredataontheServer, aremoresecure, ethandleLargerData.2) CookiesstoredataontheClient, ArelessSecure, andlimitedIzeSize.USESESSIONSFORSENSEDATAANDCOOKIESFORNONNORNE-SENSENSITION, Client-Sidedata.

Comment PHP identifie-t-il la session d'un utilisateur?Comment PHP identifie-t-il la session d'un utilisateur?May 01, 2025 am 12:23 AM

Phpidentifiesauser'sessionusingssse cookiesand sessionids.1) whenSession_start () est calculé, phpgeneratesauquesseSessionIdStoredInacookIenameDPhpSesssIdonUser'sbrowser.2) thisIdallowsphptoreTrrieSeSessionDatafromTeserver.

Quelles sont les meilleures pratiques pour sécuriser les séances PHP?Quelles sont les meilleures pratiques pour sécuriser les séances PHP?May 01, 2025 am 12:22 AM

La sécurité des sessions PHP peut être obtenue grâce aux mesures suivantes: 1. Utilisez Session_RegeReate_ID () pour régénérer l'ID de session lorsque l'utilisateur se connecte ou est une opération importante. 2. Cryptez l'ID de session de transmission via le protocole HTTPS. 3. Utilisez session_save_path () pour spécifier le répertoire sécurisé pour stocker les données de session et définir correctement les autorisations.

Où les fichiers de session PHP sont-ils stockés par défaut?Où les fichiers de session PHP sont-ils stockés par défaut?May 01, 2025 am 12:15 AM

PhpSessionFilesArestorentheDirectorySpecifiedSession.save_path, généralement / tmponunix-likesystemsorc: \ windows \ temponwindows.tocustomzethis: 1) usession_save_path () tosetacustomDirectory, astumeit'swrit

See all articles

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

VSCode Windows 64 bits Télécharger

VSCode Windows 64 bits Télécharger

Un éditeur IDE gratuit et puissant lancé par Microsoft

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

Dreamweaver Mac

Dreamweaver Mac

Outils de développement Web visuel

SublimeText3 Linux nouvelle version

SublimeText3 Linux nouvelle version

Dernière version de SublimeText3 Linux