Skip to content

Commit

Permalink
Add cache-hazelcast 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 fe9cc53 commit ed0c208
Show file tree
Hide file tree
Showing 12 changed files with 128 additions and 0 deletions.
1 change: 1 addition & 0 deletions cache-hazelcast/README.adoc
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Tests if caching with Hazelcast works
17 changes: 17 additions & 0 deletions cache-hazelcast/build.gradle
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
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")
implementation("com.hazelcast:hazelcast-spring")

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.hazelcast;

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 CacheHazelcastApplicationAotTests {

@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-hazelcast/src/main/java/com/example/cache/hazelcast/CLR.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
package com.example.cache.hazelcast;

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.hazelcast;

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.hazelcast;

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

@SpringBootApplication
public class CacheHazelcastApplication {

public static void main(String[] args) throws InterruptedException {
SpringApplication.run(CacheHazelcastApplication.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.hazelcast;

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++;
}

}
1 change: 1 addition & 0 deletions cache-hazelcast/src/main/resources/application.properties
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
spring.cache.type=hazelcast
8 changes: 8 additions & 0 deletions cache-hazelcast/src/main/resources/hazelcast.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
hazelcast:
cluster-name: cache-hazelcast
network:
join:
auto-detection:
enabled: false
multicast:
enabled: false
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
package com.example.cache.hazelcast;

import org.junit.jupiter.api.Test;

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

@SpringBootTest
class CacheHazelcastApplicationTests {

@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 @@ -6,6 +6,7 @@ smoke_tests:
- aspect
- async
- batch
- cache-hazelcast
- 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 @@ -34,6 +34,7 @@ include "actuator-webmvc-mgmt-port"
include "aspect"
include "async"
include "batch"
include "cache-hazelcast"
include "cloud-function-web"
include "cloud-function-webflux"
include "cloud-task"
Expand Down

0 comments on commit ed0c208

Please sign in to comment.