Integration testing transactions and optimistic locking with Spring and JUnit

I did some badness today.

I wanted an integration test to check to see if my @Transactional method actually did rollback on an optimistic lock failure. It’s a pretty business critical method so I wanted to be sure that the whole @Transactional and @Version annotation voodoo actually works.

The approach I took was to inject, what I called a “slowRepository” into the object with the @Transactional method. The slowRepository is just a mockito mock of the object which “answers” (using “thenAnswer”) to the “findBy…” with some custom code.

The idea is that at some point during the @Transactional method the slowRepository is called and the “answer” code is invoked. In the test, the answer code follows along the lines of:

1. Grab the data it requires from the (not slow) repository (the repository the slowRepository is mocking)
2. Switch back the slowRepository for the not slow repository
3. Invoke the @Transactional method again on a separate thread
4. Sleep for a bit
5. Wake up and return the data from step 1

The @Transactional call on the separate thread completes and commits before slowRepository wakes up. When it does, slowRepository returns stale data and the @Transactional method then fails accordingly.

The problem I encountered was using the setters for my @Autowired dependencies on the bean with the @Transactional method. I needed to use the setters so that I could switch in and out the slowRepository, but couldn’t because Spring AOP proxies are implementations of an interface, not subclasses (by default – yes I realise you can get Spring to proxy the target class using CGLIB). I found this blog post which explains how to get at the target object behind a Spring proxy. I converted it to Scala:

…which is pretty ninja.

13,549 thoughts on “Integration testing transactions and optimistic locking with Spring and JUnit

  1. Hi there Dear, are you actually visiting this web page on a regular basis, if so afterward you will
    absolutely get good experience.

  2. It’s a pity you don’t have a donate button! I’d certainly donate to this superb blog!

    I suppose for now i’ll settle for bookmarking and adding your RSS
    feed to my Google account. I look forward to new updates and will talk about
    this site with my Facebook group. Chat soon!

  3. Right now it looks like WordPress is the best blogging platform out there right now.
    (from what I’ve read) Is that what you are using on your
    blog?

  4. Коллеги, отличный структурированный гид по SEO. Автор последовательно разбирает фундамент (техническая исправность, Core Web Vitals, индексация), семантику и кластеризацию запросов, контент с доказательством экспертизы (E-E-A-T), внешние факторы и локальное SEO. Отдельно радует раздел про аналитику и управление на основе данных. Для системного подхода — самое то: https://planetaunity.ru/prodvizhenie-sajtov-polnyj-gid-po-seo/

  5. Howdy! This article couldn’t be written any better!
    Reading through this post reminds me of my previous roommate!
    He continually kept talking about this. I am going to send this post
    to him. Pretty sure he’ll have a very good read. Many thanks for sharing!

  6. I absolutely love your blog and find a lot of
    your post’s to be precisely what I’m looking for.

    Would you offer guest writers to write content for yourself?
    I wouldn’t mind writing a post or elaborating on a number of
    the subjects you write regarding here. Again, awesome web
    site!

  7. I was suggested this blog by my cousin. I’m not sure whether this post is written by him as nobody else know
    such detailed about my difficulty. You are wonderful!
    Thanks!

  8. It’s great that you are getting ideas from this piece of writing as well as from our discussion made at
    this place.

  9. pokie machine laws canada, advanced roulette uk and new zealandn online pokies for real money, or best online
    poker in united states

    Also visit my website craps wrong betting strategy [Avery]

  10. These are really impressive ideas in concerning blogging. You have touched some fastidious points here.
    Any way keep up wrinting.

  11. Your style is unique in comparison to other people I have read stuff from.
    Thanks for posting when you have the opportunity, Guess I will just bookmark
    this site.

  12. Informasi lebih lanjut dapat ditemukan di Demo Zeus Olympus 1000 Kebijakan Cookie & Teknologi Serupa atau di Privacy Policy. View your profile 3 pola rahasia gates of olympus wd 5 juta Jika Anda sudah melakukannya, barang Anda belum sampai, atau tidak sesuai deskripsi, Anda dapat melaporkannya ke Demo Zeus Olympus 1000 dengan membuka kasus. View your profile pola otomatis gates of gatotkaca max win This website is using a security service to protect itself from online attacks. The action you just performed triggered the security solution. There are several actions that could trigger this block including submitting a certain word or phrase, a SQL command or malformed data. View your profile Demo Zeus Olympus 1000 menggunakan cookie dan teknologi serupa untuk memberi Anda pengalaman yang lebih baik, memungkinkan hal-hal seperti:
    https://www.scorehero.com/forum/viewtopic.php?p=1834626#1834626
    This website is using a security service to protect itself from online attacks. The action you just performed triggered the security solution. There are several actions that could trigger this block including submitting a certain word or phrase, a SQL command or malformed data. Jam Gacor: 05.55 – 08.25 WIB 17.50 – 20.40 WIB Jam Gacor: 05.55 – 08.25 WIB 17.50 – 20.40 WIB Karena sistem WINSLOT menggunakan teknologi AI Pattern Detector yang membaca pola kemenangan tiap permainan secara real-time. Data RTP harian diambil langsung dari provider seperti Pragmatic Play dan PGSoft, memastikan peluang menang lebih akurat dan konsisten setiap hari. Itulah kenapa banyak pemain menyebut WINSLOT sebagai situs slot gacor pasti WD. This website is using a security service to protect itself from online attacks. The action you just performed triggered the security solution. There are several actions that could trigger this block including submitting a certain word or phrase, a SQL command or malformed data.

Leave a Reply

Your email address will not be published. Required fields are marked *

You may use these HTML tags and attributes: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <strike> <strong>