


Comment spécifier un chemin relatif pour l'emplacement de la base de données SQL Express dans les tests unitaires C# ?
Jan 04, 2025 am 06:21 AMDétermination de l'emplacement de la base de données SQL Express à l'aide d'un chemin relatif dans la configuration de l'application
Dans un projet de test unitaire pour C#, où les bases de données SQL Express sont utilisées, il devient nécessaire de définir une chaîne de connexion qui permet un chemin relatif à l'emplacement de l'application. Ceci est plus préférable que de spécifier explicitement le chemin absolu du fichier de base de données, tel que :
AttachDbFilename=C:\blah\blah\blah\yea\yea\yea\MyApplication\Databases\MyUnitTestDB.mdf
Au départ, il a été envisagé si |DataDirectory| pourraient être employés à cet effet. Cependant, il a été découvert que cela s'applique principalement aux applications Web et pourrait ne pas correspondre à la configuration souhaitée pour contrôler l'emplacement de la base de données dans le fichier de configuration de l'application.
Pour surmonter ce défi, une approche hybride a été mise en œuvre. , comme indiqué dans la solution fournie :
fichier app.config:
<add name="MyConnectionString" connectionString="Server=.\SQLExpress;AttachDbFilename=|DataDirectory|\MyDatabase.mdf;Database=MyDatabaseForTesting;Trusted_Connection=Yes;" />
Test unitaire class:
[TestInitialize] public void TestInitialize() { AppDomain.CurrentDomain.SetData("DataDirectory", System.IO.Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "Databases")); // rest of initialize implementation ... }
Cette approche combine la définition du chemin relatif dans la chaîne de connexion avec l'affectation de la propriété DataDirectory dans la classe de test unitaire, garantissant que le fichier de base de données est situé par rapport à l'exécutable de l'application. lors des tests unitaires, tout en permettant l'utilisation d'une base de données SQL hébergée dans des environnements de production.
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!

Article chaud

Outils chauds Tags

Article chaud

Tags d'article chaud

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

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

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Quels sont les types de valeurs renvoyées par les fonctions du langage C? Qu'est-ce qui détermine la valeur de retour?

Gulc: Cibliothèque C construite à partir de zéro

C Fonction Langue Format de lettre ÉTAPES DE CONVERSION DE CAS

Quelles sont les définitions et les règles d'appel des fonctions du langage C et quelles sont les

Utilisation distincte et partage de phrases

Où est la valeur de retour de la fonction de langue C stockée en mémoire?

Comment fonctionne la bibliothèque de modèle standard C (STL)?

Comment utiliser efficacement les algorithmes du STL (trier, trouver, transformer, etc.)?
