How Do I write unit tests for a Confluence server plugin with caching?


We have a small Confluence plugin that includes a macro that is inserted repeatedly into pages, so I decided to cache the values. I am following this tutorial how-do-i-cache-data-in-a-plugin and it worked as expected.

The project already had unit tests, which now no longer run. Usually we use Mockito to mock up the missing objects that are provided by the Confluence instance (PageManager, EntityManager, etc) and we write Mockito.when().thenReturn() for them.

But now after adding the CacheManager to the implementation, I can't see how to mock these objects up, and I can't simply ignore them from the test...

public BlablaImpl(CacheManager cacheManager) {
    cache = cacheManager.getCache(
            Blabla.class.getName() + ".cache",
            new BlablaCacheLoader(),
            new CacheSettingsBuilder().expireAfterAccess(24, TimeUnit.HOURS).build());  
  private class BlaBlaCacheLoader implements CacheLoader<String, String>{
    public String load(@NotNull String thingToBeCached) {
            return getUncachedBlabla(thingToBeCached);
//... calls elsewhere...
return cache.get("bla");

I need to mock cacheManager so the test can call getCache(). CacheManager's constructor depends on an inner CacheLoader class that I cannot even reach from the test (nor turn into an outer class). And I need to mock the cache object so I can call cache.get(), but Cache is a whole interface, that'll take a while. laugh

cache = new Cache(...); // ??
  Blabla.class.getName() + ".cache",         
  new BlablaImpl().new BlablaCacheLoader(),  // ???
  new CacheSettingsBuilder().build())        

Am I missing something obvious here how to write these tests?

1 answer

Maybe the answer is... if I depend on so many objects in a unit test, then it's no longer a unit test, but an integration test. And I should not be using JUnit/Mockito for it...

Suggest an answer

Log in or Sign up to answer
Atlassian Community Anniversary

Happy Anniversary, Atlassian Community!

This community is celebrating its one-year anniversary and Atlassian co-founder Mike Cannon-Brookes has all the feels.

Read more
Community showcase
Bridget Sauer
Published Thursday in Marketplace Apps

Calling all developers––You're invited to Atlas Camp 2018

 Atlas Camp   is our developer event which will take place in Barcelona, Spain  from the 6th -7th of   September . This is a great opportunity to meet other developers and get n...

260 views 0 6
Read article

Atlassian User Groups

Connect with like-minded Atlassian users at free events near you!

Find a group

Connect with like-minded Atlassian users at free events near you!

Find my local user group

Unfortunately there are no AUG chapters near you at the moment.

Start an AUG

You're one step closer to meeting fellow Atlassian users at your local meet up. Learn more about AUGs

Groups near you