mirror of
https://github.com/tiennm99/java-design-patterns.git
synced 2026-05-16 02:59:21 +00:00
deps: Refactor dependencies (#3224)
* remove spring dep move junit, logging, mockito under dep mgmt * upgrade anti-corruption-layer deps * async method invocation * balking, bloc * bridge to bytecode * caching * callback - cqrs * component - health check * hexagonal - metadata mapping * rest of the patterns * remove checkstyle, take spotless into use
This commit is contained in:
+74
-81
@@ -1,81 +1,74 @@
|
||||
/*
|
||||
* This project is licensed under the MIT license. Module model-view-viewmodel is using ZK framework licensed under LGPL (see lgpl-3.0.txt).
|
||||
*
|
||||
* The MIT License
|
||||
* Copyright © 2014-2022 Ilkka Seppälä
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
* of this software and associated documentation files (the "Software"), to deal
|
||||
* in the Software without restriction, including without limitation the rights
|
||||
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
* copies of the Software, and to permit persons to whom the Software is
|
||||
* furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in
|
||||
* all copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||
* THE SOFTWARE.
|
||||
*/
|
||||
package com.iluwatar.dependency.injection;
|
||||
|
||||
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||
|
||||
import com.iluwatar.dependency.injection.utils.InMemoryAppender;
|
||||
import java.util.List;
|
||||
import org.junit.jupiter.api.AfterEach;
|
||||
import org.junit.jupiter.api.BeforeEach;
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
||||
|
||||
/**
|
||||
* AdvancedSorceressTest
|
||||
*
|
||||
*/
|
||||
|
||||
class AdvancedSorceressTest {
|
||||
|
||||
private InMemoryAppender appender;
|
||||
|
||||
@BeforeEach
|
||||
void setUp() {
|
||||
appender = new InMemoryAppender(Tobacco.class);
|
||||
}
|
||||
|
||||
@AfterEach
|
||||
void tearDown() {
|
||||
appender.stop();
|
||||
}
|
||||
|
||||
/**
|
||||
* Test if the {@link AdvancedSorceress} smokes whatever instance of {@link Tobacco} is passed to
|
||||
* her through the setter's parameter
|
||||
*/
|
||||
@Test
|
||||
void testSmokeEveryThing() {
|
||||
|
||||
List<Tobacco> tobaccos = List.of(
|
||||
new OldTobyTobacco(),
|
||||
new RivendellTobacco(),
|
||||
new SecondBreakfastTobacco()
|
||||
);
|
||||
|
||||
// Verify if the sorceress is smoking the correct tobacco ...
|
||||
tobaccos.forEach(tobacco -> {
|
||||
final var advancedSorceress = new AdvancedSorceress();
|
||||
advancedSorceress.setTobacco(tobacco);
|
||||
advancedSorceress.smoke();
|
||||
String lastMessage = appender.getLastMessage();
|
||||
assertEquals("AdvancedSorceress smoking " + tobacco.getClass().getSimpleName(), lastMessage);
|
||||
});
|
||||
|
||||
// ... and nothing else is happening.
|
||||
assertEquals(tobaccos.size(), appender.getLogSize());
|
||||
|
||||
}
|
||||
}
|
||||
/*
|
||||
* This project is licensed under the MIT license. Module model-view-viewmodel is using ZK framework licensed under LGPL (see lgpl-3.0.txt).
|
||||
*
|
||||
* The MIT License
|
||||
* Copyright © 2014-2022 Ilkka Seppälä
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
* of this software and associated documentation files (the "Software"), to deal
|
||||
* in the Software without restriction, including without limitation the rights
|
||||
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
* copies of the Software, and to permit persons to whom the Software is
|
||||
* furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in
|
||||
* all copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||
* THE SOFTWARE.
|
||||
*/
|
||||
package com.iluwatar.dependency.injection;
|
||||
|
||||
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||
|
||||
import com.iluwatar.dependency.injection.utils.InMemoryAppender;
|
||||
import java.util.List;
|
||||
import org.junit.jupiter.api.AfterEach;
|
||||
import org.junit.jupiter.api.BeforeEach;
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
||||
/** AdvancedSorceressTest */
|
||||
class AdvancedSorceressTest {
|
||||
|
||||
private InMemoryAppender appender;
|
||||
|
||||
@BeforeEach
|
||||
void setUp() {
|
||||
appender = new InMemoryAppender(Tobacco.class);
|
||||
}
|
||||
|
||||
@AfterEach
|
||||
void tearDown() {
|
||||
appender.stop();
|
||||
}
|
||||
|
||||
/**
|
||||
* Test if the {@link AdvancedSorceress} smokes whatever instance of {@link Tobacco} is passed to
|
||||
* her through the setter's parameter
|
||||
*/
|
||||
@Test
|
||||
void testSmokeEveryThing() {
|
||||
|
||||
List<Tobacco> tobaccos =
|
||||
List.of(new OldTobyTobacco(), new RivendellTobacco(), new SecondBreakfastTobacco());
|
||||
|
||||
// Verify if the sorceress is smoking the correct tobacco ...
|
||||
tobaccos.forEach(
|
||||
tobacco -> {
|
||||
final var advancedSorceress = new AdvancedSorceress();
|
||||
advancedSorceress.setTobacco(tobacco);
|
||||
advancedSorceress.smoke();
|
||||
String lastMessage = appender.getLastMessage();
|
||||
assertEquals(
|
||||
"AdvancedSorceress smoking " + tobacco.getClass().getSimpleName(), lastMessage);
|
||||
});
|
||||
|
||||
// ... and nothing else is happening.
|
||||
assertEquals(tobaccos.size(), appender.getLogSize());
|
||||
}
|
||||
}
|
||||
|
||||
+10
-18
@@ -32,11 +32,7 @@ import org.junit.jupiter.api.AfterEach;
|
||||
import org.junit.jupiter.api.BeforeEach;
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
||||
|
||||
/**
|
||||
* AdvancedWizardTest
|
||||
*
|
||||
*/
|
||||
/** AdvancedWizardTest */
|
||||
class AdvancedWizardTest {
|
||||
|
||||
private InMemoryAppender appender;
|
||||
@@ -58,23 +54,19 @@ class AdvancedWizardTest {
|
||||
@Test
|
||||
void testSmokeEveryThing() {
|
||||
|
||||
List<Tobacco> tobaccos = List.of(
|
||||
new OldTobyTobacco(),
|
||||
new RivendellTobacco(),
|
||||
new SecondBreakfastTobacco()
|
||||
);
|
||||
List<Tobacco> tobaccos =
|
||||
List.of(new OldTobyTobacco(), new RivendellTobacco(), new SecondBreakfastTobacco());
|
||||
|
||||
// Verify if the wizard is smoking the correct tobacco ...
|
||||
tobaccos.forEach(tobacco -> {
|
||||
final AdvancedWizard advancedWizard = new AdvancedWizard(tobacco);
|
||||
advancedWizard.smoke();
|
||||
String lastMessage = appender.getLastMessage();
|
||||
assertEquals("AdvancedWizard smoking " + tobacco.getClass().getSimpleName(), lastMessage);
|
||||
});
|
||||
tobaccos.forEach(
|
||||
tobacco -> {
|
||||
final AdvancedWizard advancedWizard = new AdvancedWizard(tobacco);
|
||||
advancedWizard.smoke();
|
||||
String lastMessage = appender.getLastMessage();
|
||||
assertEquals("AdvancedWizard smoking " + tobacco.getClass().getSimpleName(), lastMessage);
|
||||
});
|
||||
|
||||
// ... and nothing else is happening.
|
||||
assertEquals(tobaccos.size(), appender.getLogSize());
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -24,23 +24,19 @@
|
||||
*/
|
||||
package com.iluwatar.dependency.injection;
|
||||
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
||||
import static org.junit.jupiter.api.Assertions.assertDoesNotThrow;
|
||||
|
||||
/**
|
||||
* Application test
|
||||
*/
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
||||
/** Application test */
|
||||
class AppTest {
|
||||
|
||||
/**
|
||||
* Issue: Add at least one assertion to this test case.
|
||||
* Solution: Inserted assertion to check whether the execution of the main method in {@link App#main(String[])}
|
||||
* throws an exception.
|
||||
* Issue: Add at least one assertion to this test case. Solution: Inserted assertion to check
|
||||
* whether the execution of the main method in {@link App#main(String[])} throws an exception.
|
||||
*/
|
||||
|
||||
@Test
|
||||
void shouldExecuteApplicationWithoutException() {
|
||||
assertDoesNotThrow(() -> App.main(new String[]{}));
|
||||
assertDoesNotThrow(() -> App.main(new String[] {}));
|
||||
}
|
||||
}
|
||||
|
||||
+27
-33
@@ -34,10 +34,7 @@ import org.junit.jupiter.api.AfterEach;
|
||||
import org.junit.jupiter.api.BeforeEach;
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
||||
/**
|
||||
* GuiceWizardTest
|
||||
*
|
||||
*/
|
||||
/** GuiceWizardTest */
|
||||
class GuiceWizardTest {
|
||||
|
||||
private InMemoryAppender appender;
|
||||
@@ -59,19 +56,17 @@ class GuiceWizardTest {
|
||||
@Test
|
||||
void testSmokeEveryThingThroughConstructor() {
|
||||
|
||||
List<Tobacco> tobaccos = List.of(
|
||||
new OldTobyTobacco(),
|
||||
new RivendellTobacco(),
|
||||
new SecondBreakfastTobacco()
|
||||
);
|
||||
List<Tobacco> tobaccos =
|
||||
List.of(new OldTobyTobacco(), new RivendellTobacco(), new SecondBreakfastTobacco());
|
||||
|
||||
// Verify if the wizard is smoking the correct tobacco ...
|
||||
tobaccos.forEach(tobacco -> {
|
||||
final GuiceWizard guiceWizard = new GuiceWizard(tobacco);
|
||||
guiceWizard.smoke();
|
||||
String lastMessage = appender.getLastMessage();
|
||||
assertEquals("GuiceWizard smoking " + tobacco.getClass().getSimpleName(), lastMessage);
|
||||
});
|
||||
tobaccos.forEach(
|
||||
tobacco -> {
|
||||
final GuiceWizard guiceWizard = new GuiceWizard(tobacco);
|
||||
guiceWizard.smoke();
|
||||
String lastMessage = appender.getLastMessage();
|
||||
assertEquals("GuiceWizard smoking " + tobacco.getClass().getSimpleName(), lastMessage);
|
||||
});
|
||||
|
||||
// ... and nothing else is happening.
|
||||
assertEquals(tobaccos.size(), appender.getLogSize());
|
||||
@@ -84,30 +79,29 @@ class GuiceWizardTest {
|
||||
@Test
|
||||
void testSmokeEveryThingThroughInjectionFramework() {
|
||||
|
||||
List<Class<? extends Tobacco>> tobaccos = List.of(
|
||||
OldTobyTobacco.class,
|
||||
RivendellTobacco.class,
|
||||
SecondBreakfastTobacco.class
|
||||
);
|
||||
List<Class<? extends Tobacco>> tobaccos =
|
||||
List.of(OldTobyTobacco.class, RivendellTobacco.class, SecondBreakfastTobacco.class);
|
||||
|
||||
// Configure the tobacco in the injection framework ...
|
||||
// ... and create a new wizard with it
|
||||
// Verify if the wizard is smoking the correct tobacco ...
|
||||
tobaccos.forEach(tobaccoClass -> {
|
||||
final var injector = Guice.createInjector(new AbstractModule() {
|
||||
@Override
|
||||
protected void configure() {
|
||||
bind(Tobacco.class).to(tobaccoClass);
|
||||
}
|
||||
});
|
||||
final var guiceWizard = injector.getInstance(GuiceWizard.class);
|
||||
guiceWizard.smoke();
|
||||
String lastMessage = appender.getLastMessage();
|
||||
assertEquals("GuiceWizard smoking " + tobaccoClass.getSimpleName(), lastMessage);
|
||||
});
|
||||
tobaccos.forEach(
|
||||
tobaccoClass -> {
|
||||
final var injector =
|
||||
Guice.createInjector(
|
||||
new AbstractModule() {
|
||||
@Override
|
||||
protected void configure() {
|
||||
bind(Tobacco.class).to(tobaccoClass);
|
||||
}
|
||||
});
|
||||
final var guiceWizard = injector.getInstance(GuiceWizard.class);
|
||||
guiceWizard.smoke();
|
||||
String lastMessage = appender.getLastMessage();
|
||||
assertEquals("GuiceWizard smoking " + tobaccoClass.getSimpleName(), lastMessage);
|
||||
});
|
||||
|
||||
// ... and nothing else is happening.
|
||||
assertEquals(tobaccos.size(), appender.getLogSize());
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
+1
-5
@@ -31,10 +31,7 @@ import org.junit.jupiter.api.AfterEach;
|
||||
import org.junit.jupiter.api.BeforeEach;
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
||||
/**
|
||||
* SimpleWizardTest
|
||||
*
|
||||
*/
|
||||
/** SimpleWizardTest */
|
||||
class SimpleWizardTest {
|
||||
|
||||
private InMemoryAppender appender;
|
||||
@@ -60,5 +57,4 @@ class SimpleWizardTest {
|
||||
assertEquals("SimpleWizard smoking OldTobyTobacco", appender.getLastMessage());
|
||||
assertEquals(1, appender.getLogSize());
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
+2
-5
@@ -27,14 +27,11 @@ package com.iluwatar.dependency.injection.utils;
|
||||
import ch.qos.logback.classic.Logger;
|
||||
import ch.qos.logback.classic.spi.ILoggingEvent;
|
||||
import ch.qos.logback.core.AppenderBase;
|
||||
import org.slf4j.LoggerFactory;
|
||||
import java.util.LinkedList;
|
||||
import java.util.List;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
|
||||
/**
|
||||
* InMemory Log Appender Util.
|
||||
*/
|
||||
/** InMemory Log Appender Util. */
|
||||
public class InMemoryAppender extends AppenderBase<ILoggingEvent> {
|
||||
|
||||
private final List<ILoggingEvent> log = new LinkedList<>();
|
||||
|
||||
Reference in New Issue
Block a user