From 8a17d120c13cf207025db4118c5cab9b57f5e871 Mon Sep 17 00:00:00 2001 From: Scott Leberknight <174812+sleberknight@users.noreply.github.com> Date: Mon, 2 Sep 2024 15:30:09 -0400 Subject: [PATCH] Remove deprecated ErrorContextBuilder#buildWithDataStoreFactory (#409) Closes #375 --- .../dropwizard/error/ErrorContextBuilder.java | 22 ------ .../error/ErrorContextBuilderTest.java | 77 ------------------- 2 files changed, 99 deletions(-) diff --git a/src/main/java/org/kiwiproject/dropwizard/error/ErrorContextBuilder.java b/src/main/java/org/kiwiproject/dropwizard/error/ErrorContextBuilder.java index ad804c9..7bc436a 100644 --- a/src/main/java/org/kiwiproject/dropwizard/error/ErrorContextBuilder.java +++ b/src/main/java/org/kiwiproject/dropwizard/error/ErrorContextBuilder.java @@ -12,8 +12,6 @@ import lombok.extern.slf4j.Slf4j; import org.checkerframework.checker.nullness.qual.Nullable; import org.jdbi.v3.core.Jdbi; -import org.kiwiproject.base.KiwiDeprecated; -import org.kiwiproject.base.KiwiDeprecated.Severity; import org.kiwiproject.dropwizard.error.config.CleanupConfig; import org.kiwiproject.dropwizard.error.dao.ApplicationErrorDao; import org.kiwiproject.dropwizard.error.dao.ApplicationErrorJdbc; @@ -145,7 +143,6 @@ public ErrorContextBuilder serviceDetails(ServiceDetails serviceDetails) { * @return this builder * @implNote The builder implementations have default values; using this will override those defaults. * @see #buildInMemoryH2() - * @see #buildWithDataStoreFactory(DataSourceFactory) * @see #buildWithJdbi3(Jdbi) */ public ErrorContextBuilder dataStoreType(DataStoreType dataStoreType) { @@ -299,25 +296,6 @@ public ErrorContext buildInMemoryH2() { return newJdbi3ErrorContext(jdbi); } - /** - * Build an {@link ErrorContext} using given the {@code dataSourceFactory} that uses JDBI version 3. - * - * @param dataSourceFactory the Dropwizard {@link DataSourceFactory} - * @return a new {@link ErrorContext} instance - * @implNote If you do not invoke {@link #dataStoreType(DataStoreType)} prior to calling this method, this method - * will attempt to determine which {@link DataStoreType} it should use by calling - * {@link ApplicationErrorJdbc#dataStoreTypeOf(DataSourceFactory)}. - * @deprecated use {@link #buildWithJdbi3(DataSourceFactory)}. This will be removed in version 3.0.0. - */ - @Deprecated(since = "2.1.0", forRemoval = true) - @KiwiDeprecated(removeAt = "3.0.0", - reference = "https://github.com/kiwiproject/dropwizard-application-errors/issues/375", - usageSeverity = Severity.SEVERE, - replacedBy = "#buildWithJdbi3(DataSourceFactory)") - public ErrorContext buildWithDataStoreFactory(DataSourceFactory dataSourceFactory) { - return buildWithJdbi3(dataSourceFactory); - } - /** * Build an {@link ErrorContext} using given the {@code dataSourceFactory} that uses JDBI version 3. * diff --git a/src/test/java/org/kiwiproject/dropwizard/error/ErrorContextBuilderTest.java b/src/test/java/org/kiwiproject/dropwizard/error/ErrorContextBuilderTest.java index 25d0403..64e66d5 100644 --- a/src/test/java/org/kiwiproject/dropwizard/error/ErrorContextBuilderTest.java +++ b/src/test/java/org/kiwiproject/dropwizard/error/ErrorContextBuilderTest.java @@ -432,83 +432,6 @@ void shouldForce_NOT_SHARED_DataStoreType() { } } - @SuppressWarnings("deprecation") - @Nested - class BuildWithDataStoreFactory_Deprecated { - - private DataSourceFactory dataSourceFactory; - - @BeforeEach - void setUp() { - dataSourceFactory = ApplicationErrorJdbc.createInMemoryH2Database(); - } - - @Test - void shouldBuildJdbi3Context(SoftAssertions softly) { - var errorContext = ErrorContextBuilder.newInstance() - .environment(environment) - .serviceDetails(serviceDetails) - .buildWithDataStoreFactory(dataSourceFactory); - - softly.assertThat(errorContext).isExactlyInstanceOf(Jdbi3ErrorContext.class); - softly.assertThat(errorContext.errorDao()).isInstanceOf(Jdbi3ApplicationErrorDao.class); - } - - @Test - void shouldRegisterResources() { - ErrorContextBuilder.newInstance() - .environment(environment) - .serviceDetails(serviceDetails) - .buildWithDataStoreFactory(dataSourceFactory); - - verifyRegistersJerseyResources(); - } - - @Test - void shouldRegisterHealthCheck() { - ErrorContextBuilder.newInstance() - .environment(environment) - .serviceDetails(serviceDetails) - .buildWithDataStoreFactory(dataSourceFactory); - - verifyRegistersHealthChecks(); - } - - @Test - void shouldDetermineDataStoreTypeIfNotSet() { - var errorContext = ErrorContextBuilder.newInstance() - .environment(environment) - .serviceDetails(serviceDetails) - .buildWithDataStoreFactory(dataSourceFactory); - - assertThat(errorContext.dataStoreType()).isEqualTo(DataStoreType.NOT_SHARED); - } - - @Test - void shouldForce_NOT_SHARED_ForEmbeddedH2Databases() { - var errorContext = ErrorContextBuilder.newInstance() - .environment(environment) - .serviceDetails(serviceDetails) - .dataStoreType(DataStoreType.SHARED) - .buildWithDataStoreFactory(dataSourceFactory); - - assertThat(errorContext.dataStoreType()).isEqualTo(DataStoreType.NOT_SHARED); - } - - @Test - void shouldWorkWithPostgres(SoftAssertions softly) { - var postgresDataSourceFactory = newPostgresDataSourceFactory(); - - var errorContext = ErrorContextBuilder.newInstance() - .environment(environment) - .serviceDetails(serviceDetails) - .buildWithDataStoreFactory(postgresDataSourceFactory); - - softly.assertThat(errorContext.dataStoreType()).isEqualTo(DataStoreType.SHARED); - softly.assertThat(errorContext.errorDao()).isNotNull(); - } - } - @Nested class BuildWithJdbc_UsingDataStoreFactory {