Skip to content

Commit 512bbe4

Browse files
committed
Fix ElevenLabs auto-configuration
Signed-off-by: Pawel Potaczala <[email protected]>
1 parent 37b1fd0 commit 512bbe4

File tree

4 files changed

+34
-9
lines changed

4 files changed

+34
-9
lines changed

auto-configurations/models/spring-ai-autoconfigure-model-elevenlabs/src/main/java/org/springframework/ai/model/elevenlabs/autoconfigure/ElevenLabsAutoConfiguration.java

Lines changed: 0 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -45,8 +45,6 @@
4545
@EnableConfigurationProperties({ ElevenLabsSpeechProperties.class, ElevenLabsConnectionProperties.class })
4646
@ConditionalOnProperty(prefix = ElevenLabsSpeechProperties.CONFIG_PREFIX, name = "enabled", havingValue = "true",
4747
matchIfMissing = true)
48-
@ImportAutoConfiguration(classes = { SpringAiRetryAutoConfiguration.class, RestClientAutoConfiguration.class,
49-
WebClientAutoConfiguration.class })
5048
public class ElevenLabsAutoConfiguration {
5149

5250
@Bean

auto-configurations/models/spring-ai-autoconfigure-model-elevenlabs/src/test/java/org/springframework/ai/model/elevenlabs/autoconfigure/ElevenLabsAutoConfigurationIT.java

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -40,7 +40,7 @@ public class ElevenLabsAutoConfigurationIT {
4040

4141
private final ApplicationContextRunner contextRunner = new ApplicationContextRunner()
4242
.withPropertyValues("spring.ai.elevenlabs.api-key=" + System.getenv("ELEVEN_LABS_API_KEY"))
43-
.withConfiguration(AutoConfigurations.of(ElevenLabsAutoConfiguration.class));
43+
.withConfiguration(ElevenLabsITUtil.elevenLabsAutoConfig(ElevenLabsAutoConfiguration.class));
4444

4545
@Test
4646
void speech() {
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,28 @@
1+
package org.springframework.ai.model.elevenlabs.autoconfigure;
2+
3+
import org.springframework.ai.retry.autoconfigure.SpringAiRetryAutoConfiguration;
4+
import org.springframework.boot.autoconfigure.AutoConfigurations;
5+
import org.springframework.boot.autoconfigure.web.client.RestClientAutoConfiguration;
6+
import org.springframework.boot.autoconfigure.web.reactive.function.client.WebClientAutoConfiguration;
7+
8+
/**
9+
* Utility class for VertexAI integration tests.
10+
*
11+
* @author Pawel Potaczala
12+
*/
13+
public final class ElevenLabsITUtil {
14+
15+
private ElevenLabsITUtil() {
16+
}
17+
18+
public static AutoConfigurations elevenLabsAutoConfig(Class<?>... additionalAutoConfigurations) {
19+
Class<?>[] dependencies = new Class[] { SpringAiRetryAutoConfiguration.class,
20+
RestClientAutoConfiguration.class, WebClientAutoConfiguration.class };
21+
Class<?>[] allAutoConfigurations = new Class[dependencies.length + additionalAutoConfigurations.length];
22+
System.arraycopy(dependencies, 0, allAutoConfigurations, 0, dependencies.length);
23+
System.arraycopy(additionalAutoConfigurations, 0, allAutoConfigurations, dependencies.length,
24+
additionalAutoConfigurations.length);
25+
26+
return AutoConfigurations.of(allAutoConfigurations);
27+
}
28+
}

auto-configurations/models/spring-ai-autoconfigure-model-elevenlabs/src/test/java/org/springframework/ai/model/elevenlabs/autoconfigure/ElevenLabsPropertiesTests.java

Lines changed: 5 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -20,7 +20,6 @@
2020

2121
import org.springframework.ai.elevenlabs.ElevenLabsTextToSpeechModel;
2222
import org.springframework.ai.elevenlabs.api.ElevenLabsApi;
23-
import org.springframework.boot.autoconfigure.AutoConfigurations;
2423
import org.springframework.boot.test.context.runner.ApplicationContextRunner;
2524

2625
import static org.assertj.core.api.Assertions.assertThat;
@@ -47,7 +46,7 @@ public void connectionProperties() {
4746
"spring.ai.elevenlabs.tts.options.voice-settings.use-speaker-boost=false",
4847
"spring.ai.elevenlabs.tts.options.voice-settings.speed=1.5"
4948
// @formatter:on
50-
).withConfiguration(AutoConfigurations.of(ElevenLabsAutoConfiguration.class)).run(context -> {
49+
).withConfiguration(ElevenLabsITUtil.elevenLabsAutoConfig(ElevenLabsAutoConfiguration.class)).run(context -> {
5150
var speechProperties = context.getBean(ElevenLabsSpeechProperties.class);
5251
var connectionProperties = context.getBean(ElevenLabsConnectionProperties.class);
5352

@@ -87,7 +86,7 @@ public void speechOptionsTest() {
8786
"spring.ai.elevenlabs.tts.options.apply-text-normalization=ON",
8887
"spring.ai.elevenlabs.tts.options.apply-language-text-normalization=true"
8988
// @formatter:on
90-
).withConfiguration(AutoConfigurations.of(ElevenLabsAutoConfiguration.class)).run(context -> {
89+
).withConfiguration(ElevenLabsITUtil.elevenLabsAutoConfig(ElevenLabsAutoConfiguration.class)).run(context -> {
9190
var speechProperties = context.getBean(ElevenLabsSpeechProperties.class);
9291

9392
assertThat(speechProperties.getOptions().getModelId()).isEqualTo("custom-model");
@@ -114,7 +113,7 @@ public void speechActivation() {
114113

115114
// It is enabled by default
116115
new ApplicationContextRunner().withPropertyValues("spring.ai.elevenlabs.api-key=YOUR_API_KEY")
117-
.withConfiguration(AutoConfigurations.of(ElevenLabsAutoConfiguration.class))
116+
.withConfiguration(ElevenLabsITUtil.elevenLabsAutoConfig(ElevenLabsAutoConfiguration.class))
118117
.run(context -> {
119118
assertThat(context.getBeansOfType(ElevenLabsSpeechProperties.class)).isNotEmpty();
120119
assertThat(context.getBeansOfType(ElevenLabsTextToSpeechModel.class)).isNotEmpty();
@@ -123,7 +122,7 @@ public void speechActivation() {
123122
// Explicitly enable the text-to-speech autoconfiguration.
124123
new ApplicationContextRunner()
125124
.withPropertyValues("spring.ai.elevenlabs.api-key=YOUR_API_KEY", "spring.ai.elevenlabs.tts.enabled=true")
126-
.withConfiguration(AutoConfigurations.of(ElevenLabsAutoConfiguration.class))
125+
.withConfiguration(ElevenLabsITUtil.elevenLabsAutoConfig(ElevenLabsAutoConfiguration.class))
127126
.run(context -> {
128127
assertThat(context.getBeansOfType(ElevenLabsSpeechProperties.class)).isNotEmpty();
129128
assertThat(context.getBeansOfType(ElevenLabsTextToSpeechModel.class)).isNotEmpty();
@@ -132,7 +131,7 @@ public void speechActivation() {
132131
// Explicitly disable the text-to-speech autoconfiguration.
133132
new ApplicationContextRunner()
134133
.withPropertyValues("spring.ai.elevenlabs.api-key=YOUR_API_KEY", "spring.ai.elevenlabs.tts.enabled=false")
135-
.withConfiguration(AutoConfigurations.of(ElevenLabsAutoConfiguration.class))
134+
.withConfiguration(ElevenLabsITUtil.elevenLabsAutoConfig(ElevenLabsAutoConfiguration.class))
136135
.run(context -> {
137136
assertThat(context.getBeansOfType(ElevenLabsSpeechProperties.class)).isEmpty();
138137
assertThat(context.getBeansOfType(ElevenLabsTextToSpeechModel.class)).isEmpty();

0 commit comments

Comments
 (0)