|
1 / 1 / 0
Регистрация: 12.06.2011
Сообщений: 68
|
|
Тестирование методов, возвращающие сложные объекты26.09.2011, 01:16. Показов 4166. Ответов 6
Метки нет (Все метки)
Привет!
Тестируется все JUnit. Вот вопрос тут возник. Если методы, которые возвращают коллекции объектов. Руками их создавать - ломает: и коллекции не маленькие и объекты там тоже не простые. Вот и подумалось - а, может, сериализовать эталонные результаты, а потом сравнивать с ними? Правда, после педактирования класса коллекции придется заново сохранять результаты тестов. Что по этому поводу народ думает?
0
|
|
| 26.09.2011, 01:16 | |
|
Ответы с готовыми решениями:
6
Сложные объекты передаются и принимаются (ajax) , Как передать простой int? Тестирование методов |
|
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
|
|
| 02.10.2011, 20:09 | |
|
Помогаю со студенческими работами здесь
7
Тестирование приватных методов. Тестирование приватных классов/методов Тестирование методов через JUnit Юнит тестирование методов, работающих с файлами Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Жизнь в неопределённости
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
Установка программного отбора элементов справочника "Сотрудники" из модуля формы документа.
В качестве фильтра для отбора служит значение перечислений.
/ / Событие "НачалоВыбора" реквизита на форме. . .
|