Configurar o MSTest
MSTest, Microsoft Testing Framework, é uma estrutura de teste para aplicativos .NET. Ele permite que você escreva e execute testes e forneça pacotes de teste com integração com Visual Studio e Visual Studio Code Test Explorers, a CLI do .NET e muitos pipelines de CI.
O MSTest é uma estrutura de teste totalmente suportada, de código aberto e multiplataforma que funciona com todos os destinos .NET suportados (.NET Framework, .NET Core, .NET, UWP, WinUI e assim por diante) hospedados no GitHub.
Configurações de execução
Um arquivo .runsettings pode ser usado para configurar como os testes de unidade estão sendo executados. Para saber mais sobre as runsettings e as configurações relacionadas à plataforma, você pode verificar a documentação runsettings do VSTest ou a documentação runsettings do MSTest runner.
Elemento MSTest
As seguintes entradas runsettings permitem configurar como o MSTest se comporta.
Configuração | Predefinido | Valores |
---|---|---|
AssemblyCleanupTimeout | 0 | Especifique globalmente o tempo limite a ser aplicado em cada instância do método de limpeza de assembly. [Timeout] atributo especificado no método de limpeza de assembly substitui o tempo limite global . |
AssemblyInitializeTimeout | 0 | Especifique globalmente o tempo limite a ser aplicado em cada instância do método de inicialização do assembly. [Timeout] especificado no método de inicialização do assembly substitui o tempo limite global. |
AssembleiaResolução | false | Você pode especificar caminhos para assemblies extras ao localizar e executar testes de unidade. Por exemplo, use esses caminhos para assemblies de dependência que não estão no mesmo diretório que o assembly de teste. Para especificar um caminho, use um elemento Directory Path . Os caminhos podem incluir variáveis de ambiente.<AssemblyResolution> <Directory path="D:\myfolder\bin\" includeSubDirectories="false"/> </AssemblyResolution> Esse recurso só é aplicado ao usar um destino do .NET Framework. |
CaptureTraceOutput | verdadeiro | Capture mensagens de texto provenientes do Console.Write* , Trace.Write* e Debug.Write* APIs que serão associadas ao teste em execução atual. |
ClassCleanupLifecycle | Fim de Classe | Se desejar que a limpeza de classe ocorra no final da montagem, defina-a como EndOfAssembly. (Não há mais suporte a partir do MSTest v4, pois EndOfClass é o padrão e apenas Comportamento ClassCleanup ) |
ClassCleanupTimeout | 0 | Especifique globalmente o tempo limite a ser aplicado em cada instância do método de limpeza de classe. [Timeout] atributo especificado no método de limpeza de classe substitui o tempo limite global. |
ClassInitializeTimeout | 0 | Especifique globalmente o tempo limite a ser aplicado em cada instância do método de inicialização de classe. [Timeout] atributo especificado no método de inicialização de classe substitui o tempo limite global. |
DeleteDeploymentDirectoryAfterTestRunIsComplete | verdadeiro | Para manter o diretório de implantação após uma execução de teste, defina esse valor como false. |
DeploymentEnabled | verdadeiro | Se você definir o valor como false, os itens de implantação especificados no método de teste não serão copiados para o diretório de implantação. |
DeployTestSourceDependencies | verdadeiro | Um valor que indica se as referências de origem de teste devem ser implantadas. |
EnableBaseClassTestMethodsFromOtherAssemblies | verdadeiro | Um valor que indica se a descoberta de métodos de teste de classes base deve ser habilitada em um assembly diferente da classe de teste herdeira. |
ForcedLegacyMode | false | Em versões mais antigas do Visual Studio, o adaptador MSTest foi otimizado para torná-lo mais rápido e escalável. Alguns comportamentos, como a ordem em que os testes são executados, podem não ser exatamente como era em edições anteriores do Visual Studio. Defina o valor como true para usar o adaptador de teste mais antigo. Por exemplo, você pode usar essa configuração se tiver um arquivo app.config especificado para um teste de unidade. Recomendamos que você considere a refatoração de seus testes para permitir que você use o adaptador mais recente. |
MapInconclusiveToFailed | false | Se um teste for concluído com um status inconclusivo, ele será mapeado para o status ignorado no Gerenciador de Testes. Se você quiser que testes inconclusivos sejam mostrados como reprovados, defina o valor como true. |
MapNotRunnableToFailed | verdadeiro | Um valor que indica se um resultado não executável é mapeado para teste com falha. |
Paralelizar | Usado para definir as configurações de paralelização: Trabalhadores: O número de threads/trabalhadores a serem usados para paralelização, que é, por padrão , o número de processadores na máquina atual. ESCOPO: O escopo da paralelização. Você pode defini-lo como MethodLevel. Por padrão, é ClassLevel. <Parallelize><Workers>32</Workers><Scope>MethodLevel</Scope></Parallelize> |
|
ConfiguraçõesArquivo | Você pode especificar um arquivo de configurações de teste para usar com o adaptador MSTest aqui. Você também pode especificar um arquivo de configurações de teste no menu de configurações. Se você especificar esse valor, também deverá definir o ForcedLegacyMode como true. <ForcedLegacyMode>true</ForcedLegacyMode> |
|
TestCleanupTimeout | 0 | Especifique globalmente o tempo limite a ser aplicado em cada instância do método de limpeza de teste. [Timeout] atributo especificado no método de limpeza de teste substitui o tempo limite global. |
TestInitializeTimeout | 0 | Especifique globalmente o tempo limite a ser aplicado em cada instância do método de inicialização de teste. [Timeout] atributo especificado no método de inicialização de teste substitui o tempo limite global. |
TestTimeout | 0 | Obtém o tempo limite do caso de teste global especificado. |
TreatClassAndAssemblyCleanupWarningsAsErrors | false | Para ver suas falhas nas limpezas de classe como erros, defina esse valor como true. |
TreatDiscoveryWarningsAsErrors | false | Para relatar avisos de descoberta de teste como erros, defina esse valor como true. |
ConsiderFixturesAsSpecialTests | false | Para exibir AssemblyInitialize , AssemblyCleanup , , ClassInitialize como ClassCleanup entradas individuais no Visual Studio e no Visual Studio Code Test Explorer e no log .trx , defina esse valor como true |
TestRunParameter
elemento
<TestRunParameters>
<Parameter name="webAppUrl" value="http://localhost" />
</TestRunParameters>
Os parâmetros de execução de teste fornecem uma maneira de definir variáveis e valores que estão disponíveis para os testes em tempo de execução. Acesse os parâmetros usando a propriedade MSTest TestContext.Properties :
private string _appUrl;
public TestContext TestContext { get; set; }
[TestMethod]
public void HomePageTest()
{
string _appUrl = TestContext.Properties["webAppUrl"];
}
Para usar parâmetros de execução de teste, adicione uma propriedade pública TestContext à sua classe de teste.
Exemplo de arquivo .runsettings
O XML a seguir mostra o conteúdo de um arquivo .runsettings típico. Copie este código e edite-o de acordo com as suas necessidades.
Cada elemento do arquivo é opcional porque tem um valor padrão.
<?xml version="1.0" encoding="utf-8"?>
<RunSettings>
<!-- Parameters used by tests at run time -->
<TestRunParameters>
<Parameter name="webAppUrl" value="http://localhost" />
<Parameter name="webAppUserName" value="Admin" />
<Parameter name="webAppPassword" value="Password" />
</TestRunParameters>
<!-- MSTest -->
<MSTest>
<MapInconclusiveToFailed>True</MapInconclusiveToFailed>
<CaptureTraceOutput>false</CaptureTraceOutput>
<DeleteDeploymentDirectoryAfterTestRunIsComplete>False</DeleteDeploymentDirectoryAfterTestRunIsComplete>
<DeploymentEnabled>False</DeploymentEnabled>
<ConsiderFixturesAsSpecialTests>False</ConsiderFixturesAsSpecialTests>
<AssemblyResolution>
<Directory path="D:\myfolder\bin\" includeSubDirectories="false"/>
</AssemblyResolution>
</MSTest>
</RunSettings>