質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Spring Boot

Spring Bootは、Javaのフレームワークの一つ。Springプロジェクトが提供する様々なフレームワークを統合した、アプリケーションを高速で開発するために設計されたフレームワークです。

Q&A

0回答

1021閲覧

ユニットテストでTransactionAwareDataSourceProxyを利用すると、delete/save後にflush()を必要とするようになった。また例外が消えなくなった

chu-mi

総合スコア0

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Spring Boot

Spring Bootは、Javaのフレームワークの一つ。Springプロジェクトが提供する様々なフレームワークを統合した、アプリケーションを高速で開発するために設計されたフレームワークです。

0グッド

0クリップ

投稿2021/10/21 05:59

編集2021/10/21 06:03

前提・実現したいこと

元々のユニットテストはDBの内容がテスト用のものへ書き換わってしまうことから、
今回DBの値を変更しないようにDataSourceをTransactionAwareDataSourceProxyでラップして書き換えない様にしようとしました。

@RunWith(SpringJUnit4ClassRunner.class) @TestExecutionListeners({DependencyInjectionTestExecutionListener.class, TransactionDbUnitTestExecutionListener.class}) @Transactional @Rollback @SpringBootTest(classes = {TestConfig.class}) public class TestClass extends DataSourceBasedDBTestCase { @Autowired DataSource datasource; protected DataSource getDataSource() { //brefore //return datasource; //after return new TransactionAwareDataSourceProxy(datasource); } }

問題その1

そうすると今まで jpaRepositoryをimplementsしたクラスのsave()やdelete()の後に flush()を書かなくてもDB処理されていたものがされなくなりました。

repository.deleteAll(); // repository.flush(); これは元々書いていなかったが、書かないと後のsave()でエラーになるようになってしまった。 ~~snip~~ // deleteAll()が処理されておらず一意制約違反等が発生する repository.save(object);

問題その2

また、わざとDataIntegrityViolationExceptionを発生させてその後にデータ取得をしようとした場合、
リポジトリにアクセスするだけで再度DataIntegrityViolationExceptionが呼びされるようになってしまいます。

try { repository.save(object); } catch (Exception e) { // 一意制約違反でエラーになることを確認 } // アクセスすると上記と同様のエラーが再度発生する repository.findById(id);

TransactionAwareDataSourceProxyを利用しつつ、これらの問題を解決する方法はありますでしょうか?
よろしくお願いします。

  • flush()を書かなくてもDB操作が実行されること。
  • SQL操作で例外発生後は普通にDB操作を行えること。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問