Это вопрос о «паттернах тестирования». Как «не издеваться над вещами, которыми вы не владеете» с помощью JDBC?
Я попробовал проверить концепцию адаптера JDBC по ссылке ниже, и после нескольких попыток это максимально близко к заповеди Mockito.org «Не издевайтесь над вещами, которыми вы не владеете». Есть ли другой способ добиться этого? Есть ли у кого-нибудь опыт в этом? В данном случае я хочу протестировать этот класс адаптера, не имитируя поведение ResultSet.class, которым я не владею.
Моя другая идея заключалась в том, чтобы импортировать библиотеку H2 DB в мой проект и протестировать ее на реальной БД с H2, чтобы мне не нужно было издеваться, но такое тестирование не обязательно доказывает подключение к Oracle DB, не так ли?
https://github.com/austenjt/jdbc-wrappe ... rTest.java
Мой адаптер
public class JdbcResultSetAdapter implements DatabaseResultSet {
private final ResultSet resultSet;
public JdbcResultSetAdapter(ResultSet resultSet) {
if (resultSet == null) {
throw new NullPointerException("ResultSet cannot be null");
}
this.resultSet = resultSet;
}
@Override
public boolean next() throws SQLException {
return resultSet.next();
}
@Override
public String getString(String columnLabel) throws SQLException {
return resultSet.getString(columnLabel);
}
@Override
public void close() throws SQLException {
resultSet.close();
}
}
И мой итоговый тестовый код, который высмеивает вещи, которыми я не владею:
public class JdbcResultSetAdapterTest {
@Mock
private ResultSet resultSet;
private JdbcResultSetAdapter resultSetAdapter;
@BeforeEach
void setUp() {
resultSetAdapter = new JdbcResultSetAdapter(resultSet);
}
@Test
void testNext_DelegatesToResultSet() {
assertDoesNotThrow(() -> {
when(resultSet.next()).thenReturn(true);
boolean hasNext = resultSetAdapter.next();
assertTrue(hasNext, "next() should return true");
verify(resultSet).next();
});
}
@Test
void testGetString_DelegatesToResultSet() {
String columnLabel = "name";
assertDoesNotThrow(() -> {
when(resultSet.getString(columnLabel)).thenReturn("John Doe");
String value = resultSetAdapter.getString(columnLabel);
assertEquals("John Doe", value, "getString() should return the correct value");
verify(resultSet).getString(columnLabel);
});
}
....
Подробнее здесь: https://stackoverflow.com/questions/795 ... -with-jdbc
Как «не издеваться над вещами, которыми вы не владеете» с помощью JDBC ⇐ JAVA
Программисты JAVA общаются здесь
1771817455
Anonymous
Это вопрос о «паттернах тестирования». Как «не издеваться над вещами, которыми вы не владеете» с помощью JDBC?
Я попробовал проверить концепцию адаптера JDBC по ссылке ниже, и после нескольких попыток это максимально близко к заповеди Mockito.org «Не издевайтесь над вещами, которыми вы не владеете». Есть ли другой способ добиться этого? Есть ли у кого-нибудь опыт в этом? В данном случае я хочу протестировать этот класс адаптера, не имитируя поведение ResultSet.class, которым я не владею.
Моя другая идея заключалась в том, чтобы импортировать библиотеку H2 DB в мой проект и протестировать ее на реальной БД с H2, чтобы мне не нужно было издеваться, но такое тестирование не обязательно доказывает подключение к Oracle DB, не так ли?
https://github.com/austenjt/jdbc-wrapper-and-test-double/blob/main/src/test/java/org/example/adapters/JdbcResultSetAdapterTest.java
Мой адаптер
public class JdbcResultSetAdapter implements DatabaseResultSet {
private final ResultSet resultSet;
public JdbcResultSetAdapter(ResultSet resultSet) {
if (resultSet == null) {
throw new NullPointerException("ResultSet cannot be null");
}
this.resultSet = resultSet;
}
@Override
public boolean next() throws SQLException {
return resultSet.next();
}
@Override
public String getString(String columnLabel) throws SQLException {
return resultSet.getString(columnLabel);
}
@Override
public void close() throws SQLException {
resultSet.close();
}
}
И мой итоговый тестовый код, который высмеивает вещи, которыми я не владею:
public class JdbcResultSetAdapterTest {
@Mock
private ResultSet resultSet;
private JdbcResultSetAdapter resultSetAdapter;
@BeforeEach
void setUp() {
resultSetAdapter = new JdbcResultSetAdapter(resultSet);
}
@Test
void testNext_DelegatesToResultSet() {
assertDoesNotThrow(() -> {
when(resultSet.next()).thenReturn(true);
boolean hasNext = resultSetAdapter.next();
assertTrue(hasNext, "next() should return true");
verify(resultSet).next();
});
}
@Test
void testGetString_DelegatesToResultSet() {
String columnLabel = "name";
assertDoesNotThrow(() -> {
when(resultSet.getString(columnLabel)).thenReturn("John Doe");
String value = resultSetAdapter.getString(columnLabel);
assertEquals("John Doe", value, "getString() should return the correct value");
verify(resultSet).getString(columnLabel);
});
}
....
Подробнее здесь: [url]https://stackoverflow.com/questions/79587072/how-to-dont-mock-things-you-dont-own-with-jdbc[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия