Читаем Программирование мобильных устройств на платформе .NET Compact Framework полностью

//-----------------------------------------------------------------

#if DEBUG_SIMULATE_FAILURES


//Переменная для хранения информация о следующем сбое

static SimulatedFailures g_failureCode = SimulatedFailures.noFailurePending;


//Список сбоев, которые мы хотим имитировать

public enum SimulatedFailures {

 noFailurePending, //Отсутствуют текущие сбои, подлежащие обработке


 //Имитируемые сбои:

 failInNextWriteSocketCode,

 failInNextWebServiceCall,

 failInNextFileIODuringFileOpen,

 failInNextFileIODuringFileRead

 //и так далее

}

#endif //DEBUG_SIMULATE_FAILURES


//-----------------------------------------------------

//Функция, которую мы используем для передачи данных...

//-----------------------------------------------------

private void writeDataToSocket(System.Net.Sockets.Socket mySocket, byte[] dataToSend) {

 //------------------------------------------------------------------

 //Этот код следует компилировать лишь при тестировании сетевых сбоев

 //------------------------------------------------------------------

#if DEBUG_SIMULATE_FAILURES

 //Если это сбой, который мы хотим тестировать, генерировать исключение

 if (g_failureCode == SimulatedFailures.failInNextWriteSocketCode) {

  //Сбросить этот сбой, чтобы он не возник

  //при следующем вызове этой функции

  g_failureCode = SimulatedFailures.noFailurePending;

  throw new Exception("Test communications failure: " + g_failureCode.ToString);

 }

#endif

 //Передать данные обычным образом...

 mySocket.Send(dataToSend);

} //конец функции

Имитация сбоев связи при помощи кода на стороне сервера

Подобно тому, как для имитации сбойных ситуаций можно использовать тестирующий код на устройстве, целесообразно ужесточить условия тестирования приложения в отношении передачи данных путем имитации сбоев и задержек с помощью кода на стороне сервера. Используя мониторинг выполнения кода на сервере, можно вынудить сервер прервать обработку запроса или сформировать "зависание" на неопределенное время в процессе отправки ответа. В этих случаях ваше мобильное приложение, несмотря на сбои, должно предоставить конечному пользователю интерфейс, сохраняющий способность к отклику, и обеспечить возможность восстановления работы приложения. Выполнение тестирование путем имитации сбоев, генерируемых на стороне клиента, а также инициация сбоев и задержек при помощи кода на стороне сервера позволяют проверить выполнение этих требований. Например, в случае вызова Web-службы это легко сделать, передав вместе с запросом дополнительный параметр, указывающий на то, какой тип сбоя требуется тестировать. Значение параметра тестирования по умолчанию может указывать на режим обычного выполнения, тогда как другие значения могут указывать на необходимость генерации сбоя или формирования длительной задержки перед отправкой ответа. Клиент, вызывающий Web-службу, для которой предусмотрен мониторинг выполнения кода, может далее сделать запрос, который сгенерирует одну из этих сбойных ситуаций, предоставляя возможность тестировать ответ. 

Информируйте пользователя о ходе выполнения процесса синхронизации данных

Перейти на страницу:

Похожие книги

Программист-прагматик. Путь от подмастерья к мастеру
Программист-прагматик. Путь от подмастерья к мастеру

Находясь на переднем крае программирования, книга "Программист-прагматик. Путь от подмастерья к мастеру" абстрагируется от всевозрастающей специализации и технических тонкостей разработки программ на современном уровне, чтобы исследовать суть процесса – требования к работоспособной и поддерживаемой программе, приводящей пользователей в восторг. Книга охватывает различные темы – от личной ответственности и карьерного роста до архитектурных методик, придающих программам гибкость и простоту в адаптации и повторном использовании.Прочитав эту книгу, вы научитесь:Бороться с недостатками программного обеспечения;Избегать ловушек, связанных с дублированием знания;Создавать гибкие, динамичные и адаптируемые программы;Избегать программирования в расчете на совпадение;Защищать вашу программу при помощи контрактов, утверждений и исключений;Собирать реальные требования;Осуществлять безжалостное и эффективное тестирование;Приводить в восторг ваших пользователей;Формировать команды из программистов-прагматиков и с помощью автоматизации делать ваши разработки более точными.

Эндрю Хант , Дэвид Томас , А. Алексашин

Программирование / Книги по IT
Разработка ядра Linux
Разработка ядра Linux

В книге детально рассмотрены основные подсистемы и функции ядер Linux серии 2.6, включая особенности построения, реализации и соответствующие программны интерфейсы. Рассмотренные вопросы включают: планирование выполнения процессов, управление временем и таймеры ядра, интерфейс системных вызовов, особенности адресации и управления памятью, страничный кэш, подсистему VFS, механизмы синхронизации, проблемы переносимости и особенности отладки. Автор книги является разработчиком основных подсистем ядра Linux. Ядро рассматривается как с теоретической, так и с прикладной точек зрения, что может привлечь читателей различными интересами и потребностями.Книга может быть рекомендована как начинающим, так и опытным разработчикам программного обеспечения, а также в качестве дополнительных учебных материалов.

Роберт Лав

Программирование, программы, базы данных / Программирование / Книги по IT