[英]JUnit test for getter method of custom object type
我需要为我的方法编写单元测试。 我遇到了一些麻烦,因为我是JUnit的新手。 我需要为我创建的对象类型的getter方法编写测试。 对象类型为UnitInfo,我需要为该方法编写测试
@Override
public UnitInfo getInfo() {
return info;
}
在教室里。 我在下面的代码中放置了建筑类,UnitInfo类和buildingTest类。 任何帮助表示赞赏。
package main.model.facility;
import java.util.List;
public class UnitInfo {
private int capacity;
private String name;
private int idNumber;
private List<String> details;
public int getCapacity() {
return capacity;
}
public void setCapacity(int capacity) {
this.capacity = capacity;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getIdNumber() {
return idNumber;
}
public void setIdNumber(int idNumber) {
this.idNumber = idNumber;
}
public List<String> getDetails() {
return details;
}
public void setDetails(List<String> details) {
this.details = details;
}
public void addDetail(String detail) {
details.add(detail);
}
public void removeDetail(String detail) {
details.remove(detail);
}
}
建筑等级:
package main.model.facility;
import java.util.List;
public class Building extends Facility {
private List<IFacility<UnitInfo>> subunits;
private UnitInfo info;
private ScheduleManager schedule;
@Override
public UnitInfo getInfo() {
return info;
}
@Override
public ScheduleManager getScheduleManager() {
return schedule;
}
@Override
public List<IFacility<UnitInfo>> listFacilities() {
return subunits;
}
@Override
public int requestAvailableCapacity() {
int availableCapacity = 0;
for (IFacility<UnitInfo> subunit : subunits){
availableCapacity += subunit.requestAvailableCapacity();
}
return availableCapacity;
}
}
朱尼特
public class BuildingTest {
Building defaultBuilding = new Building();
ScheduleManager defaultSchedule = new ScheduleManager();
@Before
public void setUp() throws Exception {
}
@After
public void tearDown() throws Exception {
}
@Test
public void testGetInfo() { //this is the test I need to write
Building b = defaultBuilding;
assertEquals(b.getInfo(), null);
}
@Test
public void testGetScheduleManager() {
Building a = defaultBuilding;
assertEquals(a.getScheduleManager(), null);
}
不要在类级别上构建Building
,而是在单元测试中创建它,以便每个测试都可以使用自己的Building
。 这样,他们就不会互相干扰。
目前,您的测试似乎还不错,在构造新Building
时不初始化info
,因此info
为null,并且在单元测试中声明了这一点。 您也可以使用assertNull(b.getInfo());
。
@Test
public void testGetInfo() { //this is the test I need to write
Building b = new Building()
assertEquals(b.getInfo(), null);
}
如果您确实将info
初始化为其他info = new UnitInfo()
,例如说info = new UnitInfo()
,则可以将测试更改为:
@Test
public void testGetInfo() { //this is the test I need to write
Building b = new Building()
assertNotNull(b.getInfo());
}
如果在创建新Building
时初始化了info
并设置了一些字段,该怎么办。
info = new UnitInfo();
info.setIdNumber(100);
info.setName("Some Unit Info");
然后在单元测试中,您可以断言已设置了字段:
@Test
public void testGetInfo() { //this is the test I need to write
Building b = new Building()
assertNotNull(b.getInfo());
assertEquals(b.getInfo().getIdNumber(), 100);
assertEquals(b.getInfo().getName(), "Some Unit Info");
}
单元测试的想法是练习您的代码。 调用您的方法,然后断言结果是您期望的。 一旦有了对所有代码的良好单元测试基础,您就可以放心地对其进行修改,因为您知道测试会告诉您何时破坏某些内容。
保持测试小而简单,不要做太多。 只需进行设置,调用一个方法并确保结果正确即可。 然后编写一个新测试,然后执行其他操作。 不要编写执行5种不同功能的测试。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.