Другое событие NullPointerException
возникает, когда объявляется массив объектов, а затем сразу же пытается разыменовать его внутри.
String[] phrases = new String[10];
String keyPhrase = "Bird";
for(String phrase : phrases) {
System.out.println(phrase.equals(keyPhrase));
}
Этот конкретный NPE можно избежать, если порядок сравнения отменяется ; а именно, использовать .equals
для гарантированного непустого объекта.
Все элементы внутри массива инициализируются их общим начальным значением ; для любого типа массива объектов, это означает, что все элементы null
.
Вы должны инициализировать элементы в массиве перед доступом или разыменованием их.
String[] phrases = new String[] {"The bird", "A bird", "My bird", "Bird"};
String keyPhrase = "Bird";
for(String phrase : phrases) {
System.out.println(phrase.equals(keyPhrase));
}
платформа поблочного тестирования А для SQL Server Integration Services
некоторые методы тестирования, которым я обычно следую при тестировании пакетов SSIS.
Я всегда тестирую на уровне пакета (обычно для меня не имеет большого смысла тестировать на более низком уровне, чем этот ....)
Я обычно держу среду тестовых данных с довольно маленькими наборами данных.
Также профиль конфигурации тестирования (файлы конфигурации), указывающий на наборы данных тестирования и любые другие параметры тестирования.
В зависимости от характера проекта иногда я также храню некоторые резервные копии базы данных, которые использовались для восстановления всякий раз, когда мы хотим сбросить начальный статус среды (или любые другие статусы в процессе ETL).
Все это объединено в хороший набор тестовых скриптов (python, powershell ...), вызывающих пакеты через dtexec, для меня это довольно полезный рецепт; -)