MSTest: как увеличить время тестирования

У меня есть один тест, который должен работать более 1 минуты (VS2008, MSTest, тесты запускаются из VisualStudio):

    const int TestTimeout = 1;

    [TestMethod]
    [Timeout(10*60*1000)] // 10 minutes
    public void Login_ExpirationFail_Test()
    {
        IAuthenticationParameters parameters = new AuthenticationParameters(...);
        LdapAuthentication auth1 = new LdapAuthentication();
        IAuthenticationLoginResult res = auth1.Login(parameters);

        Assert.IsNotNull(res);
        Assert.IsFalse(string.IsNullOrEmpty(res.SessionId));

        const int AdditionalMilisecodns = 400;
        System.Threading.Thread.Sleep((TestTimeout * 1000 + AdditionalMilisecodns) * 60);

        LdapAuthentication auth2 = new LdapAuthentication();
        auth2.CheckTicket(res.SessionId);
    }

Этот тест завершен в режиме "Выполнить" с превышением периода ожидания выполнения теста "Login_ExpirationFail_Test"." Сообщение об ошибке в "Отладке" - работает нормально.

Я видел несколько похожих проблем, связанных с запуском тестов из командной строки.

Как я могу сделать свой тест работоспособным в режиме "Выполнить"?

Благодарю.

3 ответа

Решение

Ответ очень прост: значение атрибута должно быть константой, а не выражением.

+ Изменить

[Timeout(10*60*1000)]

в

[Timeout(600000)]

решил проблему.

РЕДАКТИРОВАТЬ: Комментарий к ответу привлек мое внимание к ошибке, которую я первоначально сделал в ответе (записал "60000" в качестве значения тайм-аута). В моем исходном коде у меня есть 6000000, и это значение помогло. ответ был недавно исправлен

В дополнение к указанию количества секунд, Timeout() поддерживает константу, которая позволяет бесконечное ожидание.

[Timeout(TestTimeout.Infinite)]

Не конкретные шаги, но должны указывать вам в правильном направлении:

Добавьте тестовый файл настроек в решение, если у вас его еще нет.

Откройте мастер настройки с настройками теста и найдите параметр, управляющий временем ожидания теста.

Другие вопросы по тегам