diff --git a/.classpath b/.classpath new file mode 100644 index 0000000..7b653a6 --- /dev/null +++ b/.classpath @@ -0,0 +1,7 @@ + + + + + + + diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..ae3c172 --- /dev/null +++ b/.gitignore @@ -0,0 +1 @@ +/bin/ diff --git a/.project b/.project new file mode 100644 index 0000000..acc7eb1 --- /dev/null +++ b/.project @@ -0,0 +1,17 @@ + + + Bank-System3 + + + + + + org.eclipse.jdt.core.javabuilder + + + + + + org.eclipse.jdt.core.javanature + + diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/Main.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/Main.java index 16a794f..35a26be 100644 --- a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/Main.java +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/Main.java @@ -8,6 +8,7 @@ public class Main { public static void main(String[] args) throws Exception { Banksystem bs = new Banksystem("Spaßkasse Mannheim"); UI ui = new UI(bs); + } } \ No newline at end of file diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Girokonto.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Girokonto.java index d9b1d77..8edee85 100644 --- a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Girokonto.java +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Girokonto.java @@ -8,7 +8,7 @@ public class Girokonto extends Konto implements Serializable { 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) { this.auszahlen(betrag, zweck, "Ãœberweisungsausgang", super.getInhaber()); ziel.einzahlen(betrag, zweck, "Ãœberweisungseingang", super.getInhaber()); @@ -23,5 +23,18 @@ public class Girokonto extends Konto implements Serializable { public String toString() { return "Giro-" + super.toString(); } + + public boolean auszahlenDispo(long betrag, String zweck, String art, String auftraggeber) { + + + if (super.getKontostand()- betrag >= -50000) { + stand -= betrag; + + kontobewegungen.add(new Kontobewegung(betrag * -1, zweck, art, auftraggeber)); + + return true; + } + return false; + } } diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Konto.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Konto.java index 31220e1..63abd1a 100644 --- a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Konto.java +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Konto.java @@ -5,7 +5,7 @@ import java.util.ArrayList; public class Konto implements Serializable { private int nummer; - private long stand = 0; + protected long stand = 0; private String inhaber; private ArrayList kontobewegungen; @@ -52,6 +52,8 @@ public class Konto implements Serializable { return false; } + + public String[] getKontobewegungen() { String[] auflistung = new String[kontobewegungen.size()]; @@ -62,5 +64,20 @@ public class Konto implements Serializable { return auflistung; } + + public long ermittleSaldo() { + + if(kontobewegungen.size()%2 == 0) { + System.out.println("Saldo beträgt"); + return stand; + } + + return 0; + + + + } + + } diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/KontoTest.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/KontoTest.java index 04e96ae..084c7c0 100644 --- a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/KontoTest.java +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/KontoTest.java @@ -1,9 +1,12 @@ package de.hs_mannheim.informatik.bank.domain; +import static org.junit.Assert.assertEquals; import static org.junit.jupiter.api.Assertions.*; import org.junit.jupiter.api.Test; +import de.hs_mannheim.informatik.bank.facade.Banksystem; + class KontoTest { @Test @@ -32,4 +35,25 @@ class KontoTest { assertEquals(50, k2.getKontostand()); } + @Test + void saldoTest() { + Konto k = new Konto("Müller", 0); + k.einzahlen(200, null, null, null); + k.einzahlen(200, null, null, null); + assertEquals(400, k.ermittleSaldo()); + } + + @Test + void visa() throws Exception { + + Banksystem bs = new Banksystem("Testsystem"); + + int konto1 = bs.kontoAnlegen("bolt", 2); + long betrag = bs.geldEinzahlen(konto1, 200); + boolean ergebnis = bs.geldAuszahlen(konto1, 300); + + assertEquals(-100, bs.getKontostand(konto1)); + } + + } diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/Banksystem.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/Banksystem.java index 5d72301..ddc7063 100644 --- a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/Banksystem.java +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/Banksystem.java @@ -19,7 +19,7 @@ public class Banksystem { public int kontoAnlegen(String name, int auswahl) throws Exception { int kontonummer = bank.addKonto(name, auswahl); - + Persistenz.speichereBankDaten(this.bank, bank.getName()); return kontonummer; @@ -31,7 +31,7 @@ public class Banksystem { int i = 0; for (Konto k : konten) { - liste[i++] = k.toString(); + liste[i++] = k.toString(); } return liste; @@ -46,16 +46,21 @@ public class Banksystem { konto.einzahlen(betrag, "Einzahlung am Schalter", "Einzahlung", konto.getInhaber()); Persistenz.speichereBankDaten(this.bank, bank.getName()); - + return konto.getKontostand(); } public boolean geldAuszahlen(int kontonummer, long betrag) throws Exception { Konto konto = bank.findeKonto(kontonummer); - + Persistenz.speichereBankDaten(this.bank, bank.getName()); - return konto.auszahlen(betrag, "Auszahlung am Schalter", "Auszahlung", konto.getInhaber()); + if (konto instanceof Girokonto) { + konto.auszahlenDispo(betrag, "Auszahlung am Schalter", "Auszahlung", getBankname()); + } else { + return konto.auszahlen(betrag, "Auszahlung am Schalter", "Auszahlung", konto.getInhaber()); + } + return false; } public String[] erstelleKontoauszug(int kontonummer) { @@ -64,21 +69,29 @@ public class Banksystem { 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 ziel = bank.findeKonto(zielkonto); 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; } public long getKontostand(int kontonummer) { + Konto konto = bank.findeKonto(kontonummer); return konto.getKontostand(); } + public long erstelleSaldo(int kontonummer) { + + Konto konto = bank.findeKonto(kontonummer); + return konto.ermittleSaldo(); + + } + } diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/SystemTest.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/SystemTest.java index 0ce5674..2a920b5 100644 --- a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/SystemTest.java +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/SystemTest.java @@ -1,19 +1,82 @@ package de.hs_mannheim.informatik.bank.facade; -import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.Assert.assertEquals; import static org.junit.jupiter.api.Assertions.assertNotNull; +import java.io.File; + +import org.junit.jupiter.api.AfterEach; import org.junit.jupiter.api.Test; +import de.hs_mannheim.informatik.bank.infrastructure.Persistenz; + class SystemTest { + String datei1 = "C:\\Users\\DaraS\\git\\Bank-System3\\Spaßkasse Mannheim-bank-data.ser"; + String datei2= "C:\\Users\\DaraS\\git\\Bank-System3\\Testsystem-bank-data.ser"; + +// @Test +// void smokeTest() throws Exception { +// Banksystem bs = new Banksystem("Testsystem"); +// +// assertNotNull(bs); +// assertEquals(0, bs.getKontenliste().length); +// assertEquals("Testsystem", bs.getBankname()); +// } + @Test - void smokeTest() throws Exception { + void testEinzahlungKonto() throws Exception { + Banksystem bs = new Banksystem("Testsystem"); + + int konto1 = bs.kontoAnlegen("dara", 1); + long betrag = bs.geldEinzahlen(konto1, 200); + + assertEquals(200, bs.getKontostand(konto1)); + } + + @Test + void testAuszahlungKonto() throws Exception { + + Banksystem bs = new Banksystem("Testsystem"); + + int konto2 = bs.kontoAnlegen("mark", 1); + long betrag = bs.geldEinzahlen(konto2, 300); + + boolean ergebnis = bs.geldAuszahlen(konto2, 300); + + assertEquals(0, bs.getKontostand(konto2)); + } + + @Test + void persistenz() throws Exception { + + Banksystem bs = new Banksystem("testtest"); assertNotNull(bs); assertEquals(0, bs.getKontenliste().length); - assertEquals("Testsystem", bs.getBankname()); + assertEquals("testtest", bs.getBankname()); + } + + @Test + void visa() throws Exception { + + Banksystem bs = new Banksystem("Testsystem"); + + int konto1 = bs.kontoAnlegen("bolt", 2); + long betrag = bs.geldEinzahlen(konto1, 200); + boolean ergebnis = bs.geldAuszahlen(konto1, 300); + + assertEquals(-100, bs.getKontostand(konto1)); + } + + + + @AfterEach + void löschen() { + File f = new File(datei2); + f.delete(); + } } diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/ui/UI.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/ui/UI.java index 001e321..130f3ff 100644 --- a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/ui/UI.java +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/ui/UI.java @@ -10,10 +10,10 @@ public class UI { public UI(Banksystem bs) { this.bs = bs; - hauptmenü(); + hauptmenü(); } - private void hauptmenü() { + private void hauptmenü() { System.out.println("Willkommen bei der " + bs.getBankname() + "!"); mainloop: @@ -26,7 +26,8 @@ public class UI { System.out.println("3 -> Geld einzahlen"); System.out.println("4 -> Geld auszahlen"); System.out.println("5 -> Kontoauszug drucken"); - System.out.println("6 -> Ãœberweisung beauftragen"); + System.out.println("6 -> Überweisung beauftragen"); + System.out.println("7 -> Saldo"); System.out.println("9 -> Beenden"); System.out.println(); @@ -44,7 +45,8 @@ public class UI { case 3: geldEinzahlen(); break; case 4: geldAuszahlen(); break; case 5: kontoauszugDrucken(); break; - case 6: überweisungBeauftragen(); break; + case 6: ÜberweisungBeauftragen(); break; + case 7: Saldo(); break; case 9: break mainloop; } @@ -58,6 +60,15 @@ public class UI { } // hauptmenü + private void Saldo() { + + System.out.print("Bitte die gewünschte Kontonummer eingeben: "); + int kontonummer = Integer.parseInt(sc.nextLine()); + System.out.println("Saldo ausgeben"); + System.out.println(bs.erstelleSaldo(kontonummer)); + + } + private void kontenAnzeigen() { String[] konten = bs.getKontenliste(); if (konten.length > 0) { @@ -128,7 +139,7 @@ public class UI { System.out.println("Noch keine Kontobewegungen."); } - private void überweisungBeauftragen() { + private void ÜberweisungBeauftragen() { System.out.print("Bitte die Kontonummer des Ausgangskontos der Ãœberweisung eingeben: "); int startkonto = Integer.parseInt(sc.nextLine()); @@ -141,7 +152,7 @@ public class UI { System.out.print("Bitte den Verwendungszweck eingeben: "); 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."); }