java - 使用 DB 对 Hibernate 进行单元测试,测试返回 nullpointerException

标签 java hibernate unit-testing spring-boot mockito

我用 ORM (Hibernate) 编写了 Rest Api,现在我想测试该服务逻辑。 我正在尝试模拟数据库的实体,但没有取得惊人的结果。 我的选择是使用 Mockito 来获得这个,但现在我对此产生了怀疑。 一般来说,我从我编写的测试中得到 NullPointerException 。我应该以另一种方式编写 Junit 测试(“模拟”数据库的不同方式)还是我不理解 Hibernate?

这是我的代码: 测试类

public class ItemServiceImplTest {

@Spy
private ItemServiceImplementation itemServImpl;

@Mock
private BasketRepository basketRepository;
@Mock
private ItemRepository itemRepository;
@Mock
private Basket basket;
@Spy
private Item item;

@Before
public void setupMock() {

    MockitoAnnotations.initMocks(this);
    itemServImpl = new ItemServiceImplementation();
    itemServImpl.setItemRepository(itemRepository);
    itemServImpl.setBasketRepository(basketRepository);

}


@Test
public void testShowBasket() {
    Iterable<Basket> element = basketRepository.findAll();

    when(itemServImpl.showBasket()).thenReturn(element);

    Iterable<Basket> elementOne = itemServImpl.showBasket();

    assertThat(elementOne, is(equalTo(element)));
}


@Test
public void testAddToBasketStringInt() {
    Item a = new Item("A", 40, 70, 3);
    Basket testObjOne = new Basket(3, 70, a);

    when(itemServImpl.addToBasket("A", 3)).thenReturn((Iterable<Basket>) basketRepository.save(testObjOne));

    Iterable<Basket> zzz = itemServImpl.addToBasket("A", 3);

    assertThat(zzz, is(equalTo(testObjOne)));
}

型号

@Entity
public class Item {

@Id
@GeneratedValue(strategy=GenerationType.AUTO)
private long id;
private String name;
private int price;
private int specialPrice;
private int qtyToDiscount;

public Item(){};



public Item(String name, int price, int specialPrice, int qtyToDiscount) {

    this.name = name;
    this.price = price;
    this.specialPrice = specialPrice;
    this.qtyToDiscount = qtyToDiscount;
}

@Entity
public class Basket {

@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private long orderId;
private int quantity;
private int cost;



@OneToOne
@JoinTable(name = "BASKET_ORDERS", joinColumns = { @JoinColumn(name = "ORDER_ID") }, inverseJoinColumns = { @JoinColumn(name = "ID") })
private Item item;

public Basket() {
}

public Basket(int quantity, int cost,Item items) {

    this.quantity = quantity;
    this.cost = cost;
    this.item = items;
}

服务

@Service("itemService")
@Transactional
public class ItemServiceImplementation implements ItemCRUDService, ItemCostService, ItemFindService {



public static final Logger logger = LoggerFactory.getLogger(ItemServiceImplementation.class);

@Autowired
public void setItemRepository(ItemRepository itemRepository) {
    this.itemRepository = itemRepository;
}
@Autowired
public void setBasketRepository(BasketRepository basketRepository) {
    this.basketRepository = basketRepository;
}

private BasketRepository basketRepository;

private ItemRepository itemRepository;


public Iterable<Basket> showBasket() {

    return basketRepository.findAll();
}


public Iterable<Basket> addToBasket(String name, int qty) {

        if (basketRepository.exists(itemRepository.findOne(findItem(name).getId()).getId())==false) { 

        logger.info("add to empty list");
        basketRepository.save(new Basket(qty, itemCost(name, qty), findItem(name)));
        logger.info("adding");
    }

    modifyOrder(findItem(name).getId(), qty);
    itemCost(name, qty);
    logger.info("modify");

    return showBasket();

}
public Item findItem(String name) {

    for (Item item : itemRepository.findAll()) {
        if (item.getName().equals(name)) {
            return item;
        }
    }
    return null;
}
public int itemCost(String name, int qty) {

    int price = 0;

    int modulo = qty % findItem(name).getSpecialPrice();

    price = findItem(name).getPrice() * modulo
            + findItem(name).getSpecialPrice() * ((qty - modulo) / `findItem(name).getSpecialPrice());`

    return price;

}

最佳答案

Should I wrote Junit tests in another way (different way to 'mock' that DB)

您没有提到您在生产中使用的数据库,但如果它是传统的基于 SQL 的数据库,那么您很可能可以使用 H2HSQL嵌入式数据库以其一种兼容性模式进行单元测试(如果您将嵌入式连接设置为默认 spring 配置文件的数据源,我发现这是最简单的方法)

关于java - 使用 DB 对 Hibernate 进行单元测试,测试返回 nullpointerException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46778265/

相关文章:

java - Hibernate 取消唯一化表中的列

java - Orika:从字符串映射到 SomeObjects 列表

java - 如何使用 jUnit 使用 java 配置类而不使用 XML 来测试 spring mvc 中的 DAO 实现方法

unit-testing - 无法在单元测试中运行远程功能

java - 如何将java中现有的源包(正在进行中,一些类未编译)使用到netbeans中

java - DB返回值是多个

java - 如何减少初始高度为 fill_parent 的 LinearLayout 的高度

java - MSSql 服务器 jpa 空间异常

java - 比较 hashmap 键中的 ArrayList

java - 使用 Oauth 和 Gdata 在 Java 中构建一个简单的应用程序