Richtige Implementierung von Saldo und Dispokredit

main
Kai-Niklas Dippold 2022-10-28 14:38:53 +02:00
parent 118fae79ad
commit 0b7c978a1f
7 changed files with 111 additions and 57 deletions

View File

@ -11,18 +11,12 @@ public class Girokonto extends Konto implements Serializable {
} }
public boolean überweise(Girokonto ziel, long betrag, String zweck) { public boolean überweise(Girokonto ziel, long betrag, String zweck) {
if (super.getKontostand() - betrag >= 0) { if (stand + dispo - betrag >= 0) {
this.auszahlen(betrag, zweck, "Überweisungsausgang", super.getInhaber()); this.auszahlen(betrag, zweck, "Überweisungsausgang", super.getInhaber());
ziel.einzahlen(betrag, zweck, "Überweisungseingang", super.getInhaber()); ziel.einzahlen(betrag, zweck, "Überweisungseingang", super.getInhaber());
return true; return true;
} else if (super.getKontostand() + dispo - betrag >= 0) {
dispo = dispo - betrag + super.getKontostand();
this.auszahlen(super.getKontostand(), zweck, "Überweisungsausgang", super.getInhaber()); // wenn dispo
// verwendet
// wird ist
// kontostand 0
ziel.einzahlen(betrag, zweck, "Überweisungseingang", super.getInhaber());
} }
return false; return false;
@ -30,16 +24,13 @@ public class Girokonto extends Konto implements Serializable {
@Override @Override
public boolean auszahlen(long betrag, String zweck, String art, String auftraggeber) { public boolean auszahlen(long betrag, String zweck, String art, String auftraggeber) {
if (stand - betrag >= 0) { if (stand + dispo - betrag >= 0) {
stand = stand - betrag; stand = stand - betrag;
getKontobw().add(new Kontobewegung(betrag * -1, zweck, art, auftraggeber)); kontobewegungen.add(new Kontobewegung(betrag * -1, zweck, art, auftraggeber));
return true; return true;
} else if (stand + dispo - betrag >= 0) {
dispo = dispo - betrag + super.getKontostand();
stand = 0;
getKontobw().add(new Kontobewegung(betrag * -1, zweck, art, auftraggeber));
} }
return false; return false;

View File

@ -0,0 +1,54 @@
package de.hs_mannheim.informatik.bank.domain;
import static org.junit.Assert.assertEquals;
import org.junit.jupiter.api.Test;
class GirokontoTest {
@Test
void überweiseTest() {
Girokonto k = new Girokonto("Müller", 0);
Girokonto k2 = new Girokonto("Mayer", 1);
k.einzahlen(100, "Test", "Einzahlung", "JUnit");
k.überweise(k2, 50, "Test");
assertEquals(50, k.stand);
assertEquals(50, k2.stand);
}
@Test
void überweiseTestDispo() {
Girokonto k = new Girokonto("Müller", 0);
Girokonto k2 = new Girokonto("Mayer", 1);
k.einzahlen(10, "Test", "Einzahlung", "JUnit");
k.überweise(k2, 510, "Test");
assertEquals(-500, k.stand);
assertEquals(510, k2.stand);
k.überweise(k2, 501, "JUnit"); // wird nicht überwiesen da dispo nur bis 1000 geht
assertEquals(-500, k.stand);
assertEquals(510, k2.stand);
}
@Test
void auszahlenTest() {
Girokonto k = new Girokonto("Müller", 0);
k.einzahlen(10, "Test", "Einzahlung", "JUnit");
k.auszahlen(5, "Test", "Auszahlung", "JUnit");
assertEquals(5, k.stand);
k.auszahlen(15, "Test", "Auszahlung", "JUnit");
assertEquals(-10, k.stand);
k.auszahlen(991, "Überzug", "Auszahlung", "JUnit");
assertEquals(-10, k.stand);
}
}

View File

@ -8,7 +8,7 @@ public class Konto implements Serializable {
protected long stand = 0; protected long stand = 0;
private String inhaber; private String inhaber;
private ArrayList<Kontobewegung> kontobewegungen; protected ArrayList<Kontobewegung> kontobewegungen;
public Konto(String inhaber, int kontozähler) { public Konto(String inhaber, int kontozähler) {
nummer = 1000 + kontozähler; nummer = 1000 + kontozähler;
@ -70,11 +70,13 @@ public class Konto implements Serializable {
public String[] getSaldo() { public String[] getSaldo() {
String[] saldo = new String[11]; String[] saldo = new String[11];
long saldobetrag = 0;
for (int i = 10; i > 0; i--) { for (int i = 10; i > 0; i--) {
saldo[i - 1] = kontobewegungen.get(kontobewegungen.size() - i).toString(); saldo[i - 1] = kontobewegungen.get(kontobewegungen.size() - i).toString();
saldobetrag = saldobetrag + kontobewegungen.get(kontobewegungen.size() - i).getBetrag();
} }
saldo[10] = "Kontostand: " + stand; saldo[10] = "Saldo: " + saldobetrag;
return saldo; return saldo;
} }

View File

@ -1,6 +1,10 @@
package de.hs_mannheim.informatik.bank.domain; package de.hs_mannheim.informatik.bank.domain;
import static org.junit.jupiter.api.Assertions.*; import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.jupiter.api.Assertions.assertFalse;
import static org.junit.jupiter.api.Assertions.assertNotEquals;
import static org.junit.jupiter.api.Assertions.assertNotNull;
import static org.junit.jupiter.api.Assertions.assertTrue;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
@ -32,43 +36,30 @@ class KontoTest {
assertEquals(50, k2.getKontostand()); assertEquals(50, k2.getKontostand());
} }
@Test
void dispoTest() {
Girokonto k = new Girokonto("Müller", 0);
Girokonto k2 = new Girokonto("Mayer", 0);
k.einzahlen(100, "Test", "Einzahlung", "JUnit");
k.überweise(k2, 200, "Test");
assertEquals(900, k.getDispo());
assertEquals(0, k.getKontostand());
assertEquals(200, k2.getKontostand());
}
@Test @Test
void saldoTest() { void saldoTest() {
Girokonto k = new Girokonto("Müller", 0); Konto k = new Konto("Müller", 0);
k.einzahlen(100, "Test", "Einzahlung", "JUnit"); k.einzahlen(1, "Test", "Einzahlung", "JUnit");
k.einzahlen(100, "Test", "Einzahlung", "JUnit"); k.einzahlen(2, "Test", "Einzahlung", "JUnit");
k.einzahlen(100, "Test", "Einzahlung", "JUnit"); k.einzahlen(3, "Test", "Einzahlung", "JUnit");
k.einzahlen(100, "Test", "Einzahlung", "JUnit"); k.einzahlen(4, "Test", "Einzahlung", "JUnit");
k.einzahlen(100, "Test", "Einzahlung", "JUnit"); k.einzahlen(5, "Test", "Einzahlung", "JUnit");
k.einzahlen(100, "Test", "Einzahlung", "JUnit"); k.einzahlen(6, "Test", "Einzahlung", "JUnit");
k.einzahlen(100, "Test", "Einzahlung", "JUnit"); k.einzahlen(7, "Test", "Einzahlung", "JUnit");
k.einzahlen(100, "Test", "Einzahlung", "JUnit"); k.einzahlen(8, "Test", "Einzahlung", "JUnit");
k.einzahlen(100, "Test", "Einzahlung", "JUnit"); k.einzahlen(9, "Test", "Einzahlung", "JUnit");
k.einzahlen(100, "Test", "Einzahlung", "JUnit"); k.einzahlen(10, "Test", "Einzahlung", "JUnit");
k.einzahlen(100, "Test", "Einzahlung", "JUnit"); k.auszahlen(11, "Test", "Einzahlung", "JUnit");
k.einzahlen(100, "Test", "Einzahlung", "JUnit"); k.einzahlen(12, "Test", "Einzahlung", "JUnit");
k.einzahlen(100, "Test", "Einzahlung", "JUnit"); k.einzahlen(13, "Test", "Einzahlung", "JUnit");
k.einzahlen(100, "Test", "Einzahlung", "JUnit"); k.einzahlen(14, "Test", "Einzahlung", "JUnit");
k.einzahlen(100, "Test", "Einzahlung", "JUnit"); k.einzahlen(15, "Test", "Einzahlung", "JUnit");
k.einzahlen(100, "Test", "Einzahlung", "JUnit"); k.einzahlen(16, "Test", "Einzahlung", "JUnit");
k.einzahlen(100, "Test", "Einzahlung", "JUnit"); k.einzahlen(17, "Test", "Einzahlung", "JUnit");
k.einzahlen(100, "Test", "Einzahlung", "JUnit"); k.einzahlen(18, "Test", "Einzahlung", "JUnit");
assertNotNull(k.getSaldo()); assertNotNull(k.getSaldo());
String[] saldo = k.getSaldo(); String[] saldo = k.getSaldo();
assertEquals("Kontostand: 1800", saldo[10]); assertEquals("Saldo: 113", saldo[10]);
} }
} }

View File

@ -9,13 +9,13 @@ public class Kontobewegung implements Serializable {
private String betreff; private String betreff;
private String art; private String art;
private String auftraggeber; private String auftraggeber;
public Kontobewegung(long betrag, String betreff, String art, String auftraggeber) { public Kontobewegung(long betrag, String betreff, String art, String auftraggeber) {
this.betrag = betrag; this.betrag = betrag;
this.betreff = betreff; this.betreff = betreff;
this.art = art; this.art = art;
this.auftraggeber = auftraggeber; this.auftraggeber = auftraggeber;
this.datum = new Date(); this.datum = new Date();
} }
@ -24,5 +24,9 @@ public class Kontobewegung implements Serializable {
return "Kontobewegung [betrag=" + betrag + ", datum=" + datum + ", betreff=" + betreff + ", art=" + art return "Kontobewegung [betrag=" + betrag + ", datum=" + datum + ", betreff=" + betreff + ", art=" + art
+ ", auftraggeber=" + auftraggeber + "]"; + ", auftraggeber=" + auftraggeber + "]";
} }
public long getBetrag() {
return betrag;
}
} }

View File

@ -3,13 +3,12 @@ package de.hs_mannheim.informatik.bank.facade;
import static org.junit.jupiter.api.Assertions.assertEquals; import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.jupiter.api.Assertions.assertNotNull; import static org.junit.jupiter.api.Assertions.assertNotNull;
import java.io.*; import java.io.File;
import de.hs_mannheim.informatik.bank.infrastructure.Persistenz;
import de.hs_mannheim.informatik.bank.ui.*;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
import de.hs_mannheim.informatik.bank.ui.UI;
class SystemTest { class SystemTest {
@Test @Test

View File

@ -26,6 +26,7 @@ public class UI {
System.out.println("4 -> Geld auszahlen"); System.out.println("4 -> Geld auszahlen");
System.out.println("5 -> Kontoauszug drucken"); System.out.println("5 -> Kontoauszug drucken");
System.out.println("6 -> Überweisung beauftragen"); System.out.println("6 -> Überweisung beauftragen");
System.out.println("7 -> Saldo ausgeben");
System.out.println("9 -> Beenden"); System.out.println("9 -> Beenden");
System.out.println(); System.out.println();
@ -54,6 +55,8 @@ public class UI {
case 6: case 6:
überweisungBeauftragen(); überweisungBeauftragen();
break; break;
case 7:
case 9: case 9:
break mainloop; break mainloop;
} }
@ -180,4 +183,14 @@ public class UI {
return bs.printSaldo(kontonummer); return bs.printSaldo(kontonummer);
} }
private void SaldoAusgeben() {
System.out.print("Bitte die gewünschte Kontonummer für das Saldo eingeben: ");
int kontonummer = Integer.parseInt(sc.nextLine());
for (String s : printSaldo(kontonummer)) {
System.out.println(s);
}
}
} }