Skip to content

Commit

Permalink
Add cache-simple smoke test
Browse files Browse the repository at this point in the history
See gh-40
  • Loading branch information
mhalbritter committed Aug 9, 2022
1 parent 6a2d8a2 commit 451eaf2
Show file tree
Hide file tree
Showing 10 changed files with 118 additions and 0 deletions.
1 change: 1 addition & 0 deletions cache-simple/README.adoc
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Tests if caching with ConcurrentHashMap works
16 changes: 16 additions & 0 deletions cache-simple/build.gradle
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
plugins {
id 'java'
id 'org.springframework.boot'
id 'org.springframework.aot.smoke-test'
id 'org.graalvm.buildtools.native'
}

dependencies {
implementation(platform(org.springframework.boot.gradle.plugin.SpringBootPlugin.BOM_COORDINATES))
implementation("org.springframework.boot:spring-boot-starter-cache")

testImplementation("org.springframework.boot:spring-boot-starter-test")

aotTestImplementation(project(":aot-smoke-test-support"))
aotTestImplementation("org.awaitility:awaitility:4.2.0")
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
package com.example.cache.simple;

import java.time.Duration;

import org.awaitility.Awaitility;
import org.junit.jupiter.api.Test;

import org.springframework.aot.smoketest.support.assertj.AssertableOutput;
import org.springframework.aot.smoketest.support.junit.AotSmokeTest;

import static org.assertj.core.api.Assertions.assertThat;

@AotSmokeTest
class CacheSimpleApplicationAotTests {

@Test
void methodIsCached(AssertableOutput output) {
Awaitility.await().atMost(Duration.ofSeconds(10)).untilAsserted(() -> {
assertThat(output).hasSingleLineContaining("invoke: 1").hasNoLinesContaining("invoke: 2");
});
}

}
21 changes: 21 additions & 0 deletions cache-simple/src/main/java/com/example/cache/simple/CLR.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
package com.example.cache.simple;

import org.springframework.boot.CommandLineRunner;
import org.springframework.stereotype.Component;

@Component
class CLR implements CommandLineRunner {

private final TestService testService;

public CLR(TestService testService) {
this.testService = testService;
}

@Override
public void run(String... args) {
this.testService.invoke();
this.testService.invoke();
}

}
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
package com.example.cache.simple;

import org.springframework.cache.annotation.EnableCaching;
import org.springframework.context.annotation.Configuration;

@Configuration(proxyBeanMethods = false)
@EnableCaching
class CacheConfiguration {

}
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
package com.example.cache.simple;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class CacheSimpleApplication {

public static void main(String[] args) throws InterruptedException {
SpringApplication.run(CacheSimpleApplication.class, args);
Thread.currentThread().join(); // To be able to measure memory consumption
}

}
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
package com.example.cache.simple;

import org.springframework.cache.annotation.Cacheable;
import org.springframework.stereotype.Service;

@Service
class TestService {

private int counter = 1;

@Cacheable(cacheNames = "invoke")
public void invoke() {
System.out.printf("invoke: %d%n", this.counter);
this.counter++;
}

}
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
package com.example.cache.simple;

import org.junit.jupiter.api.Test;

import org.springframework.boot.test.context.SpringBootTest;

@SpringBootTest
class CacheSimpleApplicationTests {

@Test
void contextLoads() {
}

}
1 change: 1 addition & 0 deletions ci/smoke-tests.yml
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ smoke_tests:
- cache-cache2k
- cache-caffeine
- cache-hazelcast
- cache-simple
- cloud-function-web
- cloud-function-webflux
- cloud-task
Expand Down
1 change: 1 addition & 0 deletions settings.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@ include "batch"
include "cache-cache2k"
include "cache-caffeine"
include "cache-hazelcast"
include "cache-simple"
include "cloud-function-web"
include "cloud-function-webflux"
include "cloud-task"
Expand Down

0 comments on commit 451eaf2

Please sign in to comment.