Как «не издеваться над вещами, которыми вы не владеете» с помощью JDBCJAVA

Программисты JAVA общаются здесь
Ответить
Anonymous
 Как «не издеваться над вещами, которыми вы не владеете» с помощью JDBC

Сообщение Anonymous »

Это вопрос о «паттернах тестирования». Как «не издеваться над вещами, которыми вы не владеете» с помощью 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
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «JAVA»