Форум программистов, компьютерный форум, киберфорум
Java
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.95/21: Рейтинг темы: голосов - 21, средняя оценка - 4.95
1 / 1 / 0
Регистрация: 12.06.2011
Сообщений: 68

Тестирование методов, возвращающие сложные объекты

26.09.2011, 01:16. Показов 4128. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Привет!

Тестируется все JUnit.

Вот вопрос тут возник. Если методы, которые возвращают коллекции объектов. Руками их создавать - ломает: и коллекции не маленькие и объекты там тоже не простые.

Вот и подумалось - а, может, сериализовать эталонные результаты, а потом сравнивать с ними? Правда, после педактирования класса коллекции придется заново сохранять результаты тестов.

Что по этому поводу народ думает?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
26.09.2011, 01:16
Ответы с готовыми решениями:

Сложные объекты Xamarin
Здравствуйте. Суть такая: у меня есть список который содержит свойства с названием и описанием; Я создал ListView и 2 поля лейбл. К...

Сложные объекты передаются и принимаются (ajax) , Как передать простой int?
Сторона клиента заходит в аякс формирует запрос все ОК $.ajax({ url: "/CodeLiveExamples/GetTasksByTypeId/", ...

Тестирование методов
Здравствуйте! Такая проблема: если допустим есть метод public int sum(int first, int second) { return first + second; ...

6
1 / 1 / 0
Регистрация: 02.08.2011
Сообщений: 64
26.09.2011, 09:00
Лично мне кажется, что если в модульном тесте идёт работа с большим объёмом разнородных данных, то это уже не модульный, а интеграционный тест. Соответственно подход должен быть совсем другим.

Ну а если ближе к теме, то можно предложить кое-что:

1) Возможно для целей тестирования не обязательно проверять содержимое всей коллекции, а достаточно просто проверить наличие/отсутствие в ней ключевых элементов методами типа Collection.contains() или Map.containsKey().

2) Откуда-то этот большой объём данных берётся. Если метод их не генерит сам, то значит на вход ему поступает (или извлекается из контекста) тоже большой объём информации. Соответственно, можно было бы проверить работу метода на меньшем объёме входной информации.

3) Попробовать непосредственно тестировать те объекты, которые используются при реализации вашего метода. Если ваш метод большой и толстый, но при этом не использует какие-то другие объекты, то возможно стоит задуматься о разделении логики метода между несколькими объектами и тестировать уже их.

Если вы действительно хотите выполнить интеграционное тестирование, то использование прегенерированных тестовых данных вполне уместно. Вот только всё равно эти данные как-то нужно создать, то есть написать соответствующий код. Тогда почему бы не включить этот код в сам тест?
0
1 / 1 / 0
Регистрация: 12.06.2011
Сообщений: 68
26.09.2011, 20:27  [ТС]
Блин! Писал-писал! А оно все сломалось!

Спасибо за ответ.

Данные в тесте получаются из базы, туда они запихиваются dbunit.

А так подумал, наверное, действительно не надо сериализовать коллекции, а сравнивать какие-нибудь суммы из них(типа CRC). Если сравнить достаточно много сумм, то можно говорить о соответствии результатов.

Спасибо за идею!
0
1 / 1 / 0
Регистрация: 02.08.2011
Сообщений: 64
27.09.2011, 08:14
Приятно подавать идеи

Есть ещё вариант, который может существенно упростить тестирование: использование mock-объектов. Суть в том, чтобы тестировать не состояние после выполнения определённых действий, а сам ход выполнения действий. В вашем случае, например, можно было бы всего-лишь протестировать корректность запросов, которые даются СУБД.

Подробнее, можно почитать тут: http://www.martinfowler.com/articles/mocksArentStubs.html

а тут скачать сами инструменты:
http://www.jmock.org
http://www.easymock.org
0
1 / 1 / 0
Регистрация: 12.06.2011
Сообщений: 68
27.09.2011, 23:50  [ТС]
>>Приятно подавать идеи
Ну дык! Мы все из страны советов :-)

>>Есть ещё вариант, который может существенно упростить тестирование:
...
>>лишь протестировать корректность запросов, которые даются СУБД.
Там всего один запрос, который возвращает коллекцию строк из базы. А вот дальше ее обрабатывают другие методы. Про мок объекты я, конечно, знаю, но не могу понять как их тут использовать.

Надо будет разобраться с ними по-подробнее.

Еще раз спасибо!
0
0 / 0 / 0
Регистрация: 28.08.2010
Сообщений: 42
01.10.2011, 10:47
>> Вот и подумалось - а, может, сериализовать эталонные результаты, а потом сравнивать с ними? Правда, после педактирования класса коллекции придется заново сохранять результаты тестов.

Если используете Spring framework, то эталлоные результаты можно обьявить в отдельном конфиг.файле и включить этот конфиг файл в ваш тест.класс.
Начиная с версии 1.1.4 есть возможность юзать вот этот класс, не чистив базу после теста; смотрите подробности:
http://static.springframework.org/spring/docs/1.1.5/api/index.html
0
1 / 1 / 0
Регистрация: 12.06.2011
Сообщений: 68
02.10.2011, 20:09  [ТС]
Ага! Спасибо! Посмотрю!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
02.10.2011, 20:09
Помогаю со студенческими работами здесь

Тестирование вспомогательных методов
И еще один вопрос по тестированию... Нужно ли тестировать вспомогательные методы? Они как правило закрыты. Например, есть метод, который...

Тестирование приватных методов.
Подскажите пожалуйст,как можо тестировать приватные методы с помощю JUnit ? Мне говорили что с помощю Рефлексии,но я почитал и не понял...

Тестирование приватных классов/методов
Не могу понять как мне тестировать приватные модули. Если я создаю тестовый проект для моего проекта, даю ему ссылку на мой проект и...

Тестирование методов через JUnit
Доброго времени суток Помогите пожалуйста. Есть такой метод для удаления файлов private void deleteFile(FileElement fi) { ...

Юнит тестирование методов, работающих с файлами
Всем доброго времени суток! Возникла у меня небольшая проблема с тестированием методов, которые выполняют сериализацию объекта в XML, JSON....


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru