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

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

26.09.2011, 01:16. Показов 4166. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Жизнь в неопределённости
kumehtar 23.03.2026
Жизнь — это постоянное существование в неопределённости. Например, даже если у тебя есть список дел, невозможно дойти до точки, где всё окончательно завершено и больше ничего не осталось. В принципе,. . .
Модель здравоСохранения: работники работают быстрее после её введения.
anaschu 23.03.2026
geJalZw1fLo Корпорация до введения программа здравоохранения имела много невыполненных работниками заданий, после введения программы количество заданий выросло. Но на выплатах по больничным это. . .
1С: Контроль уникальности заводского номера
Maks 23.03.2026
Алгоритм контроля уникальности заводского (или серийного) номера на примере документа выдачи шин для спецтехники с табличной частью. Данные берутся из регистра сведений, по которому настроено. . .
Хочу заставить корпорации вкладываться в здоровье сотрудников: делаю мат модель здравосохранения
anaschu 22.03.2026
e7EYtONaj8Y Z4Tv2zpXVVo https:/ / github. com/ shumilovas/ med2. git
1С: Программный отбор элементов справочника по группе
Maks 22.03.2026
Установка программного отбора элементов справочника "Номенклатура" из модуля формы документа. В качестве фильтра для отбора справочника служит группа номенклатуры. Отбор по наименованию группы. . .
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
1С: Программный отбор элементов справочника по значению перечисления
Maks 21.03.2026
Установка программного отбора элементов справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит значение перечислений. / / Событие "НачалоВыбора" реквизита на форме. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru