AssemblyInitializeAttribute – třída
Určuje metodu, která obsahuje kód používali spustit všechny testy v sestavení a přidělit prostředky získané shromážděním.Tato třída nemůže být zděděna.
Hierarchie dědičnosti
Object
Attribute
Microsoft.VisualStudio.TestTools.UnitTesting.AssemblyInitializeAttribute
Obor názvů: Microsoft.VisualStudio.TestTools.UnitTesting
Sestavení: Microsoft.VisualStudio.QualityTools.UnitTestFramework (v Microsoft.VisualStudio.QualityTools.UnitTestFramework.dll)
Syntaxe
'Deklarace
<AttributeUsageAttribute(AttributeTargets.Method, AllowMultiple := False)> _
Public NotInheritable Class AssemblyInitializeAttribute _
Inherits Attribute
[AttributeUsageAttribute(AttributeTargets.Method, AllowMultiple = false)]
public sealed class AssemblyInitializeAttribute : Attribute
[AttributeUsageAttribute(AttributeTargets::Method, AllowMultiple = false)]
public ref class AssemblyInitializeAttribute sealed : public Attribute
[<Sealed>]
[<AttributeUsageAttribute(AttributeTargets.Method, AllowMultiple = false)>]
type AssemblyInitializeAttribute =
class
inherit Attribute
end
public final class AssemblyInitializeAttribute extends Attribute
Typ AssemblyInitializeAttribute zveřejňuje následující členy.
Konstruktory
Název | Popis | |
---|---|---|
AssemblyInitializeAttribute | Vytvoří novou instanci třídy AssemblyInitializeAttribute. |
Nahoru
Vlastnosti
Název | Popis | |
---|---|---|
TypeId | Po implementaci v odvozené třídě získá jedinečný identifikátor pro tento Attribute. (Zděděno z Attribute.) |
Nahoru
Metody
Název | Popis | |
---|---|---|
Equals | Infrastruktura. Vrací hodnotu, která určuje, zda je tato instance rovna zadanému objektu. (Zděděno z Attribute.) | |
GetHashCode | Vrátí kód hash této instance. (Zděděno z Attribute.) | |
GetType | Získá Type aktuální instance. (Zděděno z Object.) | |
IsDefaultAttribute | Při přepsání v odvozené třídě označuje, zda je hodnota této instance výchozí hodnota pro odvozené třídy. (Zděděno z Attribute.) | |
Match | Při přepsání v odvozené třídě vrátí hodnotu, která označuje, zda tato instance se rovná zadaný objekt. (Zděděno z Attribute.) | |
ToString | Vrátí řetězec, který představuje aktuální objekt. (Zděděno z Object.) |
Nahoru
Explicitní implementace rozhraní
Název | Popis | |
---|---|---|
System#Runtime#InteropServices#_Attribute#GetIDsOfNames | Mapuje sadu názvů na odpovídající sadu identifikátorů pro rozesílání. (Zděděno z Attribute.) | |
System#Runtime#InteropServices#_Attribute#GetTypeInfo | Načte informace o typu objektu, který lze použít, chcete-li získat informace o typu rozhraní. (Zděděno z Attribute.) | |
System#Runtime#InteropServices#_Attribute#GetTypeInfoCount | Získá počet rozhraní typu informací, které objekt poskytuje (0 nebo 1). (Zděděno z Attribute.) | |
System#Runtime#InteropServices#_Attribute#Invoke | Poskytuje přístup k vlastnostem a metodám vystaveným objektem. (Zděděno z Attribute.) |
Nahoru
Poznámky
Metoda s tímto atributem bude spuštěn před metody označena ClassInitializeAttribute, TestInitializeAttribute, a TestMethodAttribute atributy.Pouze jednu metodu v sestavení může upraven pomocí tohoto atributu.
Důležité |
---|
Tento atribut by nepoužívá ASP.NET jednotky testů, jakéhokoli testu s [HostType("ASP.NET")] atributu.Z důvodu příslušnosti povahy služby IIS a ASP.NET, upraven pomocí tohoto atributu může být volána metoda více než jednou za spustit test. |
Tento atribut může být zadán pro metodu.Pouze jedna instance tohoto atributu může použít pro metodu.
[!POZNÁMKA]
Zkušební stroj spouští metoda, která je označena atributem AssemblyInitialize pouze v případě, že tato metoda je členem třídy, který je označen atributem Testovací_třída.
Další informace o použití atributů naleznete v Rozšiřování metadat pomocí atributů.
Příklady
Následující příklady ukazují inicializace a čištění atributy, které se používají k označení, které metody by měl být spuštěn test motoru v různých obdobích test.
První ukázky kódu obsahují třídy a metody testování.Chcete-li spustit příklad vytvoření projektu knihovny třídy a nahradit kód v následujícím příkladu.
using System;
namespace SampleClassLib
{
public class DivideClass
{
public static int DivideMethod(int denominator)
{
return (2 / denominator);
}
}
}
Imports System
Namespace SampleClassLib
Public Class DivideClass
Shared Function DivideMethod(ByVal denominator As Integer) As Integer
Return 2 \ denominator
End Function
End Class
End Namespace
Následující příklad obsahuje kód test DivideMethod() v předchozí příklady kódu.Vytvoření projektu zkouška a zkouška třídy dokumentu vložte následující kód.Přidejte příslušné odkazy na projekt.Tento kód obsahuje atributy, které určují pořadí inicializace a čištění provádění metody, třídy a sestavení.
Všimněte si zejména atribut AssemblyInitialize na metody AssemblyInit ().
using Microsoft.VisualStudio.TestTools.UnitTesting;
using SampleClassLib;
using System;
using System.Windows.Forms;
namespace TestNamespace
{
[TestClass()]
public sealed class DivideClassTest
{
[AssemblyInitialize()]
public static void AssemblyInit(TestContext context)
{
MessageBox.Show("AssemblyInit " + context.TestName);
}
[ClassInitialize()]
public static void ClassInit(TestContext context)
{
MessageBox.Show("ClassInit " + context.TestName);
}
[TestInitialize()]
public void Initialize()
{
MessageBox.Show("TestMethodInit");
}
[TestCleanup()]
public void Cleanup()
{
MessageBox.Show("TestMethodCleanup");
}
[ClassCleanup()]
public static void ClassCleanup()
{
MessageBox.Show("ClassCleanup");
}
[AssemblyCleanup()]
public static void AssemblyCleanup()
{
MessageBox.Show("AssemblyCleanup");
}
[TestMethod()]
[ExpectedException(typeof(System.DivideByZeroException))]
public void DivideMethodTest()
{
DivideClass.DivideMethod(0);
}
}
}
Imports Microsoft.VisualStudio.TestTools.UnitTesting
Imports SampleClassLib2.SampleClassLib
Imports System
Imports System.IO
Imports System.Windows.Forms
Namespace TestNamespace
<TestClass()> _
Public NotInheritable Class DivideClassTest
<AssemblyInitialize()> _
Public Shared Sub AssemblyInit(ByVal context As TestContext)
MsgBox("AssemblyInit " + context.TestName)
End Sub 'AssemblyInit
<ClassInitialize()> _
Public Shared Sub ClassInit(ByVal context As TestContext)
MsgBox("ClassInit " + context.TestName)
End Sub 'ClassInit
<TestInitialize()> _
Public Sub Initialize()
MsgBox("TestMethodInit")
End Sub
<TestCleanup()> _
Public Sub Cleanup()
MsgBox("TestMethodCleanup")
End Sub
<ClassCleanup()> _
Public Shared Sub ClassCleanup()
MsgBox("ClassCleanup")
End Sub
<AssemblyCleanup()> _
Public Shared Sub AssemblyCleanup()
MsgBox("AssemblyCleanup")
End Sub
<TestMethod()> _
<ExpectedException(GetType(System.DivideByZeroException))> _
Public Sub DivideMethodTest()
DivideClass.DivideMethod(0)
End Sub
End Class
End Namespace
Bezpečný přístup z více vláken
Všechny veřejné členy static (Shared v jazyce Visual Basic) tohoto typu jsou bezpečné pro přístup z více vláken. Není zaručeno, že členy instancí jsou bezpečné pro přístup z více vláken.
Viz také
Referenční dokumentace
Microsoft.VisualStudio.TestTools.UnitTesting – obor názvů