Fertige PÜ2

main
kaimu 2022-10-25 14:14:05 +02:00
parent 666fd4909a
commit dcd4feb79d
7 changed files with 96 additions and 21 deletions

View File

@ -8,8 +8,8 @@ public class Girokonto extends Konto implements Serializable {
super(inhaber, kontozähler); super(inhaber, kontozähler);
} }
public boolean überweise(Girokonto ziel, long betrag, String zweck) { public boolean überweise(Girokonto ziel, long betrag, String zweck) {
if (super.getKontostand() - betrag >= 0) { if (super.getKontostand() - betrag >= -100000) {
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());
@ -19,6 +19,18 @@ public class Girokonto extends Konto implements Serializable {
return false; return false;
} }
public boolean auszahlen(long betrag, String zweck, String art, String auftraggeber) {
if (this.getKontostand() - betrag >= 100000) {
stand -= betrag;
kontobewegungen.add(new Kontobewegung(betrag * -1, zweck, art, auftraggeber));
return true;
}
return false;
}
@Override @Override
public String toString() { public String toString() {
return "Giro-" + super.toString(); return "Giro-" + super.toString();

View File

@ -5,10 +5,10 @@ import java.util.ArrayList;
public class Konto implements Serializable { public class Konto implements Serializable {
private int nummer; private int nummer;
private 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;
@ -33,6 +33,16 @@ public class Konto implements Serializable {
public long getKontostand() { public long getKontostand() {
return stand; return stand;
} }
public long berechneSaldo(int anzahlKontobewegungen) {
long saldo = 0;
for(int k = 0; k < anzahlKontobewegungen; k++) {
saldo += kontobewegungen.get(k).getBetrag();
}
return saldo;
}
public void einzahlen(long betrag, String zweck, String art, String auftraggeber) { public void einzahlen(long betrag, String zweck, String art, String auftraggeber) {
stand += betrag; stand += betrag;
@ -62,5 +72,5 @@ public class Konto implements Serializable {
return auflistung; return auflistung;
} }
} }

View File

@ -22,14 +22,14 @@ class KontoTest {
assertEquals("Mayer", k2.getInhaber()); assertEquals("Mayer", k2.getInhaber());
assertNotEquals(k.getKontonummer(), k2.getKontonummer()); assertNotEquals(k.getKontonummer(), k2.getKontonummer());
k2.einzahlen(100, "Test", "Einzahlung", "JUnit"); k.einzahlen(100, "Test", "Einzahlung", "JUnit");
assertEquals(100, k2.getKontostand()); assertEquals(100, k.getKontostand());
assertTrue(k2.auszahlen(50, "Test", "Auszahlung", "JUnit")); assertTrue(k.auszahlen(50, "Test", "Auszahlung", "JUnit"));
assertEquals(50, k2.getKontostand()); assertEquals(50, k.getKontostand());
assertFalse(k2.auszahlen(500, "Test", "Auszahlung", "JUnit")); assertFalse(k2.auszahlen(500, "Test", "Auszahlung", "JUnit"));
assertEquals(50, k2.getKontostand()); assertEquals(0, k2.getKontostand());
} }
} }

View File

@ -25,4 +25,9 @@ public class Kontobewegung implements Serializable {
+ ", auftraggeber=" + auftraggeber + "]"; + ", auftraggeber=" + auftraggeber + "]";
} }
public long getBetrag() {
return betrag;
}
} }

View File

@ -64,12 +64,12 @@ public class Banksystem {
return konto.getKontobewegungen(); return konto.getKontobewegungen();
} }
public boolean überweisungBeauftragen(int startkonto, int zielkonto, long betrag, String verwendungszweck) { public boolean überweisungBeauftragen(int startkonto, int zielkonto, long betrag, String verwendungszweck) {
Konto start = bank.findeKonto(startkonto); Konto start = bank.findeKonto(startkonto);
Konto ziel = bank.findeKonto(zielkonto); Konto ziel = bank.findeKonto(zielkonto);
if (start instanceof Girokonto && ziel instanceof Girokonto) { if (start instanceof Girokonto && ziel instanceof Girokonto) {
return ((Girokonto)start).überweise((Girokonto)ziel, betrag, verwendungszweck); return ((Girokonto)start).überweise((Girokonto)ziel, betrag, verwendungszweck);
} }
return false; return false;
@ -81,4 +81,9 @@ public class Banksystem {
return konto.getKontostand(); return konto.getKontostand();
} }
public long saldoAuszug(int kontonummer, int kontobewegungen) {
Konto konto = bank.findeKonto(kontonummer);
return konto.berechneSaldo(kontobewegungen);
}
} }

View File

@ -3,10 +3,13 @@ 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.File;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
class SystemTest { import de.hs_mannheim.informatik.bank.domain.Bank;
class SystemTest {
@Test @Test
void smokeTest() throws Exception { void smokeTest() throws Exception {
Banksystem bs = new Banksystem("Testsystem"); Banksystem bs = new Banksystem("Testsystem");
@ -15,5 +18,34 @@ class SystemTest {
assertEquals(0, bs.getKontenliste().length); assertEquals(0, bs.getKontenliste().length);
assertEquals("Testsystem", bs.getBankname()); assertEquals("Testsystem", bs.getBankname());
} }
void EinAuszahlenTest() throws Exception {
Banksystem bs = new Banksystem("Testsystem");
int kontonummer1 = bs.kontoAnlegen("TestKonto", 1);
int kontonummer2 = bs.kontoAnlegen("TestGirokonto",2);
assertEquals(500, bs.geldEinzahlen(kontonummer1, 500));
assertEquals(1000, bs.geldEinzahlen(kontonummer1, 500));
assertEquals(1500, bs.geldEinzahlen(kontonummer1, 500));
assertEquals(500, bs.geldEinzahlen(kontonummer2, 500));
assertEquals(1000, bs.geldEinzahlen(kontonummer2, 500));
assertEquals(1500, bs.geldEinzahlen(kontonummer2, 500));
assertEquals(1000, bs.geldAuszahlen(kontonummer1, 500));
assertEquals(500, bs.geldAuszahlen(kontonummer1, 500));
assertEquals(0, bs.geldAuszahlen(kontonummer1, 500));
assertEquals(1000, bs.geldAuszahlen(kontonummer2, 500));
assertEquals(500, bs.geldAuszahlen(kontonummer2, 500));
assertEquals(0, bs.geldAuszahlen(kontonummer2, 500));
}
void cleanup() throws Exception {
File file = new File("C:\\Users\\kaimu\\git\\Bank-System-PUE2\\Bank-Beispiel\\Testsysten-bank-data.ser");
file.delete();
}
} }

View File

@ -10,10 +10,10 @@ public class UI {
public UI(Banksystem bs) { public UI(Banksystem bs) {
this.bs = bs; this.bs = bs;
hauptmenü(); hauptmenü();
} }
private void hauptmenü() { private void hauptmenü() {
System.out.println("Willkommen bei der " + bs.getBankname() + "!"); System.out.println("Willkommen bei der " + bs.getBankname() + "!");
mainloop: mainloop:
@ -26,8 +26,8 @@ public class UI {
System.out.println("3 -> Geld einzahlen"); System.out.println("3 -> Geld einzahlen");
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 anzeigen");
System.out.println("9 -> Beenden"); System.out.println("9 -> Beenden");
System.out.println(); System.out.println();
@ -44,7 +44,8 @@ public class UI {
case 3: geldEinzahlen(); break; case 3: geldEinzahlen(); break;
case 4: geldAuszahlen(); break; case 4: geldAuszahlen(); break;
case 5: kontoauszugDrucken(); break; case 5: kontoauszugDrucken(); break;
case 6: überweisungBeauftragen(); break; case 6: überweisungBeauftragen(); break;
case 7: saldo(); break;
case 9: break mainloop; case 9: break mainloop;
} }
@ -128,7 +129,7 @@ public class UI {
System.out.println("Noch keine Kontobewegungen."); System.out.println("Noch keine Kontobewegungen.");
} }
private void überweisungBeauftragen() { private void überweisungBeauftragen() {
System.out.print("Bitte die Kontonummer des Ausgangskontos der Überweisung eingeben: "); System.out.print("Bitte die Kontonummer des Ausgangskontos der Überweisung eingeben: ");
int startkonto = Integer.parseInt(sc.nextLine()); int startkonto = Integer.parseInt(sc.nextLine());
@ -141,9 +142,19 @@ public class UI {
System.out.print("Bitte den Verwendungszweck eingeben: "); System.out.print("Bitte den Verwendungszweck eingeben: ");
String verwendungszweck = sc.nextLine(); String verwendungszweck = sc.nextLine();
boolean erfolgreich = bs.überweisungBeauftragen(startkonto, zielkonto, (long)(betrag * 100), verwendungszweck); boolean erfolgreich = bs.überweisungBeauftragen(startkonto, zielkonto, (long)(betrag * 100), verwendungszweck);
System.out.println("Überweisung" + ( (!erfolgreich) ? " nicht" : "") + " erfolgreich ausgeführt."); System.out.println("Überweisung" + ( (!erfolgreich) ? " nicht" : "") + " erfolgreich ausgeführt.");
} }
private void saldo() {
System.out.println("Bitte geben sie ihre Kontonummer ein: ");
int kontonummer = Integer.parseInt(sc.nextLine());
System.out.println("Geben sie die gewünschte Anzahl der Kontobewegungen ein");
int kontobewegungen = Integer.parseInt(sc.nextLine());
System.out.println("Ihr Saldo nach den ersten " + kontobewegungen + " Kontobewegungen beträgt:" + bs.saldoAuszug(kontonummer, kontobewegungen));
}
} }