issue #333 factory kit pattern introduced

This commit is contained in:
Kamil Pietruszka
2016-01-17 13:45:33 +01:00
parent bd82387fc1
commit 10bbf988ea
15 changed files with 255 additions and 57 deletions

View File

@ -0,0 +1,15 @@
package com.iluwatar.factorykit;
public class App {
public static void main(String[] args) {
WeaponFactory factory = WeaponFactory.factory(builder -> {
builder.add(WeaponType.SWORD, Sword::new);
builder.add(WeaponType.AXE, Axe::new);
builder.add(WeaponType.SPEAR, Spear::new);
builder.add(WeaponType.BOW, Bow::new);
});
Weapon axe = factory.create(WeaponType.AXE);
System.out.println(axe);
}
}

View File

@ -0,0 +1,7 @@
package com.iluwatar.factorykit;
public class Axe implements Weapon {
@Override public String toString() {
return "Axe{}";
}
}

View File

@ -0,0 +1,7 @@
package com.iluwatar.factorykit;
/**
* Created by crossy on 2016-01-16.
*/
public class Bow implements Weapon {
}

View File

@ -0,0 +1,7 @@
package com.iluwatar.factorykit;
import java.util.function.Supplier;
public interface Builder {
void add(WeaponType name, Supplier<Weapon> supplier);
}

View File

@ -0,0 +1,7 @@
package com.iluwatar.factorykit;
public class Spear implements Weapon {
@Override public String toString() {
return "Spear{}";
}
}

View File

@ -0,0 +1,7 @@
package com.iluwatar.factorykit;
public class Sword implements Weapon {
@Override public String toString() {
return "Sword{}";
}
}

View File

@ -0,0 +1,4 @@
package com.iluwatar.factorykit;
public interface Weapon {
}

View File

@ -0,0 +1,16 @@
package com.iluwatar.factorykit;
import java.util.HashMap;
import java.util.function.Consumer;
import java.util.function.Supplier;
public interface WeaponFactory {
Weapon create(WeaponType name);
static WeaponFactory factory(Consumer<Builder> consumer) {
HashMap<WeaponType, Supplier<Weapon>> map = new HashMap<>();
consumer.accept(map::put);
return name -> map.get(name).get();
}
}

View File

@ -0,0 +1,8 @@
package com.iluwatar.factorykit;
/**
* Created by crossy on 2016-01-16.
*/
public enum WeaponType {
SWORD, AXE, BOW, SPEAR
}

View File

@ -0,0 +1,13 @@
package com.iluwatar.factorykit.app;
import com.iluwatar.factorykit.App;
import org.junit.Test;
public class AppTest {
@Test public void test() {
String[] args = {};
App.main(args);
}
}

View File

@ -0,0 +1,58 @@
package com.iluwatar.factorykit.factorykit;
import com.iluwatar.factorykit.*;
import org.junit.Before;
import org.junit.Test;
import static org.junit.Assert.assertTrue;
/**
* Created by crossy on 2016-01-16.
*/
public class FactoryKitTest {
private WeaponFactory factory;
@Before public void init() {
factory = WeaponFactory.factory(builder -> {
builder.add(WeaponType.SPEAR, Spear::new);
builder.add(WeaponType.AXE, Axe::new);
builder.add(WeaponType.SWORD, Sword::new);
});
}
/**
* Testing {@link WeaponFactory} to produce a SPEAR asserting that the Weapon is an instance of {@link Spear}
*/
@Test public void testSpearWeapon() {
Weapon weapon = factory.create(WeaponType.SPEAR);
verifyWeapon(weapon, Spear.class);
}
/**
* Testing {@link WeaponFactory} to produce a AXE asserting that the Weapon is an instance of {@link Axe}
*/
@Test public void testAxeWeapon() {
Weapon weapon = factory.create(WeaponType.AXE);
verifyWeapon(weapon, Axe.class);
}
/**
* Testing {@link WeaponFactory} to produce a SWORD asserting that the Weapon is an instance of {@link Sword}
*/
@Test public void testWeapon() {
Weapon weapon = factory.create(WeaponType.SWORD);
verifyWeapon(weapon, Sword.class);
}
/**
* This method asserts that the weapon object that is passed is an instance of the clazz
*
* @param weapon weapon object which is to be verified
* @param clazz expected class of the weapon
*/
private void verifyWeapon(Weapon weapon, Class clazz) {
assertTrue("Weapon must be an object of: " + clazz.getName(), clazz.isInstance(weapon));
}
}