Форум программистов, компьютерный форум, киберфорум
Java SE (J2SE)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/4: Рейтинг темы: голосов - 4, средняя оценка - 5.00
 Аватар для Sma6nta
5 / 3 / 1
Регистрация: 12.05.2019
Сообщений: 201

Как написать JUnit тест к методу который лазит в БД?

01.04.2020, 13:05. Показов 981. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
есть простой метод добавляющий акк в базу

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
@Override
    public boolean addAccount(String currUserEmail, String account, String info) throws SQLException {
        boolean res = false;
        PreparedStatement ps = null;
        ResultSet rs = null;
        Connection con = null;
        try {
            con = ConnectionPool.getInstance().getConnection();
            ps = (PreparedStatement) con.prepareStatement(SQL_ADD_CARD);
            ps.setString(1, currUserEmail);
            ps.setString(2, account);
            ps.setString(3, info);
            ps.executeUpdate();
 
            res = true;
 
        } finally {
            ConnectionPool.close(rs);
            ConnectionPool.close(ps);
            ConnectionPool.close(con);
        }
        return res;
 
    }
пытаюсь к нему написать тест

Java
1
2
3
4
5
6
7
8
9
10
11
    
    private FactoryDAO factoryDAO = FactoryDAO.getInstance();  
 
@Test
    public void testaddAccount() throws SQLException {
        String currUserEmail = "mail";
        String account = "account";
        String info = "info";
        
        assertEquals(true, factoryDAO.getAccountDao().addAccount(currUserEmail, account, info));
    }
но он естественно не работает(. ибо доступ в БД через пулл который работает только когда запущен томкат.
как правильно сделать чтоб он отработал с базой данных?

правильно ли то что я пытаюсь сделать в принципе? (Это у меня вроде курсового, должно быть все по-человечески)
помогите пожалуйста тест написать
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
01.04.2020, 13:05
Ответы с готовыми решениями:

JUnit как написать тест
Товарищи, доброго времени суток. Хочу научиться правильно писать. И наткнулся на тестирование, почитав, понял что очень интересно, НО...

JUnit @Before и @After к какому методу относятся
Как в JUnit указать, что один метод с пометкой @Before и один метод с пометкой @After относятся к одному методу, в то время, как другие...

Как можно сделать тест на то, что вернётся именно моё возвращаемое значение ? (JUnit)
@GetMapping("/") @ResponseBody public String index() { Map<String, Object> context = Maps.newHashMap(); ...

5
Эксперт функциональных языков программированияЭксперт Java
 Аватар для korvin_
4575 / 2774 / 491
Регистрация: 28.04.2012
Сообщений: 8,765
01.04.2020, 13:20
Цитата Сообщение от Sma6nta Посмотреть сообщение
правильно ли то что я пытаюсь сделать в принципе?
Нет.
0
 Аватар для Sma6nta
5 / 3 / 1
Регистрация: 12.05.2019
Сообщений: 201
01.04.2020, 13:35  [ТС]
не могли бы вы написать код, как правильно?
0
614 / 488 / 175
Регистрация: 02.03.2010
Сообщений: 1,238
01.04.2020, 17:21
Рекомендую загуглить easymock или mockito.
Замокать поведение PreparedStatement, ResultSet и Connection, но по факту от этого теста толку будет ровно столько, на сколько детально будут замоканы вышеуказанные поведения.
0
Эксперт Java
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
01.04.2020, 18:57
_ViPeR_,
Цитата Сообщение от Sma6nta Посмотреть сообщение
ConnectionPool.getInstance().getConnecti on();
как это будешь мокать?
0
614 / 488 / 175
Регистрация: 02.03.2010
Сообщений: 1,238
03.04.2020, 09:44
Цитата Сообщение от xoraxax Посмотреть сообщение
как это будешь мокать?
Ну как нибудь
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
03.04.2020, 09:44
Помогаю со студенческими работами здесь

Junit тест NullPointerException
Подскажите, пожалуйста, как кинуть эксепшн с месседжем до того, как эксепшн появится сам во время рассчетов? И проверить сходятся ли...

Не работает JUnit тест
Всем привет, я создаю консольную программу, система заявок. Стал писать тесты на основные методы, и столкнулся с проблемой, при написании...

нужно написать прогу который по временным трендам сможет идентифицировать объект управления по методу наименьших квадрантов
нужно написать прогу который по временным трендам сможет идентифицировать объект управления по методу наименьших квадратов желательно с...

Junit тест простейшего калькулятора
Доброго дня! Сделал первый шажок - написал калькулятор в Eclipse. Все вычисления назначил по нажатию на "=". Никак не соображу:...

Тест для метода в JUnit
Здравствуйте, уважаемые форумчане! Изучаю java и вот, озадачился написанием тестов для кода. Посмотрел некоторые материалы в интернете по...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru