diff --git a/.idea/misc.xml b/.idea/misc.xml
index 0792e77..2c7c084 100644
--- a/.idea/misc.xml
+++ b/.idea/misc.xml
@@ -1,6 +1,6 @@
-
+
\ No newline at end of file
diff --git a/RefactoringAssignment.iml b/RefactoringAssignment.iml
index 7e880ab..454125c 100644
--- a/RefactoringAssignment.iml
+++ b/RefactoringAssignment.iml
@@ -24,5 +24,15 @@
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/InsuranceCalculator.java b/src/InsuranceCalculator.java
index 558e0a0..516ca40 100644
--- a/src/InsuranceCalculator.java
+++ b/src/InsuranceCalculator.java
@@ -1,15 +1,21 @@
public class InsuranceCalculator {
-
+ private InsuranceStrategy strategy;
public double calculateInsurance(double income) {
+
if (income <= 10000) {
- return income*0.365;
- } else if (income <= 30000) {
- return (income-10000)*0.2+35600;
- } else if (income <= 60000) {
- return (income-30000)*0.1+76500;
+ strategy = new InsuranceStrategyLow();
+ return strategy.calculate(income);
+ } else if (income <= 36500) {
+ strategy = new InsuranceStrategyMedium();
+ return strategy.calculate(income);
+ } else if (income <= 70000) {
+ strategy = new InsuranceStrategyHigh();
+ return strategy.calculate(income);
} else {
- return (income-60000)*0.02+105600;
+ strategy = new InsuranceStrategyVeryHigh();
+ return strategy.calculate(income);
}
+
}
}
diff --git a/src/InsuranceStrategy.java b/src/InsuranceStrategy.java
new file mode 100644
index 0000000..084e03a
--- /dev/null
+++ b/src/InsuranceStrategy.java
@@ -0,0 +1,9 @@
+public abstract class InsuranceStrategy {
+ public double calculate(double income) {
+ return (income - getAdjustment()) * getWeight() + getConstant();
+ }
+
+ public abstract int getConstant();
+ public abstract double getWeight();
+ public abstract int getAdjustment();
+}
diff --git a/src/InsuranceStrategyHigh.java b/src/InsuranceStrategyHigh.java
new file mode 100644
index 0000000..ad6bdfa
--- /dev/null
+++ b/src/InsuranceStrategyHigh.java
@@ -0,0 +1,13 @@
+public class InsuranceStrategyHigh extends InsuranceStrategy {
+ public InsuranceStrategyHigh() { }
+ @Override
+ public int getConstant() { return 70000; }
+
+ @Override
+ public double getWeight() { return 0.18; }
+
+ @Override
+ public int getAdjustment() {
+ return 25000;
+ }
+}
diff --git a/src/InsuranceStrategyLow.java b/src/InsuranceStrategyLow.java
new file mode 100644
index 0000000..576e0df
--- /dev/null
+++ b/src/InsuranceStrategyLow.java
@@ -0,0 +1,16 @@
+public class InsuranceStrategyLow extends InsuranceStrategy {
+ public InsuranceStrategyLow() { }
+
+ @Override
+ public int getConstant() { return 30000; }
+
+ @Override
+ public double getWeight() {
+ return 0.36;
+ }
+
+ @Override
+ public int getAdjustment() {
+ return 5000;
+ }
+}
diff --git a/src/InsuranceStrategyMedium.java b/src/InsuranceStrategyMedium.java
new file mode 100644
index 0000000..f08fafe
--- /dev/null
+++ b/src/InsuranceStrategyMedium.java
@@ -0,0 +1,15 @@
+public class InsuranceStrategyMedium extends InsuranceStrategy {
+ public InsuranceStrategyMedium() { }
+ @Override
+ public int getConstant() { return 35600; }
+
+ @Override
+ public double getWeight() {
+ return 0.2;
+ }
+
+ @Override
+ public int getAdjustment() {
+ return 10000;
+ }
+}
diff --git a/src/InsuranceStrategyVeryHigh.java b/src/InsuranceStrategyVeryHigh.java
new file mode 100644
index 0000000..6bb4519
--- /dev/null
+++ b/src/InsuranceStrategyVeryHigh.java
@@ -0,0 +1,15 @@
+public class InsuranceStrategyVeryHigh extends InsuranceStrategy {
+ public InsuranceStrategyVeryHigh() { }
+ @Override
+ public int getConstant() {
+ return 105600;
+ }
+ @Override
+ public double getWeight() {
+ return 0.02;
+ }
+ @Override
+ public int getAdjustment() {
+ return 60000;
+ }
+}
diff --git a/test/InsuranceTest.java b/test/InsuranceTest.java
new file mode 100644
index 0000000..456c2db
--- /dev/null
+++ b/test/InsuranceTest.java
@@ -0,0 +1,29 @@
+import org.junit.Test;
+
+import static org.junit.Assert.*;
+public class InsuranceTest {
+ @Test
+ public void low() {
+ assertEquals(30000, insuranceFor(5000), 0.01);
+ }
+
+ @Test
+ public void medium() {
+ assertEquals(38600, insuranceFor(25000), 0.01);
+ }
+
+ @Test
+ public void high() {
+ assertEquals(74500, insuranceFor(50000), 0.01);
+ }
+
+ @Test
+ public void veryHigh() {
+ assertEquals(106400, insuranceFor(100_000), 0.01);
+ }
+
+ private double insuranceFor(double income) {
+ return new InsuranceCalculator().calculateInsurance(income);
+ }
+
+}