【发布时间】:2018-12-29 03:48:07
【问题描述】:
我正在研究 java 项目,其中我有一个名为 user 的类,它将用户的详细信息存储在数据库中。我正在尝试使用测试用例测试这个类:当用户成功创建表时,我创建了一个返回“用户创建”的字符串,我想使用 junit 进行测试。下面是我的junit测试代码
public class UserDatabaseTest
{
User user = null;
IterationDetailsParser iterationDetails = mock(IterationDetailsParser.class);
DatabaseConnection dbConnection = mock(DatabaseConnection.class);
Object obj ;
Connection con;
@Before
public void setUp() throws SQLException
{
MockitoAnnotations.initMocks(this);
user = new User();
con = (Connection) dbConnection.GetDBConnection();
obj = iterationDetails.getUserId();
}
@Test
public void test() throws JsonProcessingException, SQLException
{
Mockito.when(dbConnection.GetDBConnection()).thenReturn(con);
Mockito.when(iterationDetails.getUserId()).thenReturn("8");
assertSame("User ID alreday exits", user.CreateUserDetails());
}
}
现在我想模拟我从其他类中使用的对象,例如“iterationDetails.getUserId()”。当我尝试模拟对象而不是被模拟时,它正在调用真正的方法 getuserId() 并返回 null。我该如何解决这个问题?下面是我的用户创建类。
public String CreateUserDetails() throws SQLException, JsonProcessingException
{
dbcon = DatabaseConnection.getInstance();
iteratinDetails = IterationDetailsParser.getInstance();
String st;
try {
String sqlUser = "INSERT INTO user (User_Id,Username,Active_Indi)VALUES(?,?,?)";
PreparedStatement statement = (PreparedStatement) dbcon.GetDBConnection().prepareStatement(sqlUser);
statement.setString(1, iteratinDetails.getUserId());
statement.setString(2, iteratinDetails.getUserObj());
statement.setBoolean(3, true );
statement.executeUpdate();
statement.close();
System.out.println("user created");
// string i return in last compare using assertEquals
st = "user created";
} catch (SQLException e)
{
System.out.println("user id alredy exits");
userIdExits = false;
}
return st;
}
tl;博士
在这种情况下我应该如何模拟对象?
【问题讨论】: