実現したいこと
タイトルの通りですが、やりたいこととしては Spring boot のアプリケーションで db アクセスのあるクラスをテストしたいです。
ターゲットのクラスでは Specification を使っており、以下の様に使用します。
Java
1ReservationsSpecification specification = new TestSpecification(); 2Specification spec = Specification.where(specification.nameContain("タナカ")) 3 4List<TestEntity> user = target.findAll(query);
上記の TestSpecification クラスの nameContain は以下の様になっており、likeを使っています。
Java
1public Specification nameContain(String searchName) { 2 return searchName == null ? null : (root, query, builder) -> builder.like(root.get("name"), 3searchName + "%"); 4}
テストでは DbSetup と h2 database を使っていて
h2の設定が以下です。
yaml
1spring: 2 datasource: 3 driverClassName: org.h2.Driver 4 url: jdbc:h2:mem:testoracledb;MODE=Oracle;DB_CLOSE_DELAY=-1;INIT=CREATE SCHEMA IF NOT EXISTS TEST 5 username: username 6 password: password 7 h2.console.enabled: true
DbSetup では以下の様にデータを insert しています。
Java
1private final Operation INSERT_DATA = Operations.insertInto("TEST.SAMPLE") 2 .row() 3 .column("MANAGE_NO", "1") 4 .column("NAME","タナカタロウ")
単体テストではなく実際の Oracle の DB で実行した際には問題なく like で取得できています。
また、likeではなく以下のように equal による検索の場合は問題なく動きます。
Java
1public Specification nameContain(String searchName) { 2 return searchName == null ? null : (root, query, builder) -> builder.equal(root.get("name"), 3searchName); 4}
なぜ h2 で like の場合のみうまく取得できないか分からず非常に困っています。
何か原因お分かりになる方いましたらご教示いただけますと幸いです。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。