Mengurus Laluan Fail SQL Express MDF dalam Ujian Unit C#
Ujian unit C# selalunya bergantung pada pangkalan data SQL Express, biasanya merujuk fail MDF melalui laluan mutlak dalam rentetan sambungan. Pendekatan ini tidak fleksibel. Penyelesaian yang lebih mantap melibatkan penggunaan laluan relatif atau pembolehubah persekitaran untuk mengesan fail pangkalan data secara dinamik.
Walaupun |DataDirectory|
biasanya digunakan dalam aplikasi web, ia tidak boleh digunakan secara langsung untuk konsol atau aplikasi bukan web yang lain. Penyelesaiannya adalah dengan menetapkan sifat DataDirectory
secara manual dan membina rentetan sambungan dengan sewajarnya.
Berikut ialah contoh praktikal:
<code class="language-xml"><configuration> <connectionStrings> <add connectionString="Server=.\SQLExpress;AttachDbFilename=|DataDirectory|\MyDatabase.mdf;Database=MyDatabaseForTesting;Trusted_Connection=Yes;" name="MyConnectionString" /> </connectionStrings> </configuration></code>
Dalam kelas ujian unit anda, tetapkan sifat DataDirectory
sebelum pelaksanaan ujian:
<code class="language-csharp">[TestInitialize] public void TestInitialize() { string databaseDirectory = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "Databases"); AppDomain.CurrentDomain.SetData("DataDirectory", databaseDirectory); // ... remaining test initialization ... }</code>
Kaedah ini membenarkan penggunaan laluan relatif dalam rentetan sambungan anda, membolehkan kawalan yang lebih baik ke atas lokasi fail pangkalan data melalui fail konfigurasi aplikasi, mempromosikan kebolehselenggaraan dan kemudahalihan kod.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menggunakan Laluan Relatif untuk Fail MDF SQL Express dalam Ujian Unit C#?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!