From 2b7dd4ea8895093320be63b3849063578ee3ae9d Mon Sep 17 00:00:00 2001 From: Hedwig Date: Tue, 4 Oct 2022 00:42:44 +0200 Subject: [PATCH] Finished System --- Bank-Beispiel/.classpath | 21 +++--- .../informatik/bank/domain/Bank.java | 33 +++++++-- .../informatik/bank/domain/Konto.java | 15 ++++- .../informatik/bank/domain/TestKonto.java | 41 ++++++++++++ .../informatik/bank/facade/Banksystem.java | 27 +++++--- .../bank/facade/TestBanksystem.java | 23 +++++++ .../de/hs_mannheim/informatik/bank/ui/UI.java | 67 ++++++++++++++----- 7 files changed, 183 insertions(+), 44 deletions(-) create mode 100644 Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/TestKonto.java create mode 100644 Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/TestBanksystem.java diff --git a/Bank-Beispiel/.classpath b/Bank-Beispiel/.classpath index 57bca72..9e73c62 100644 --- a/Bank-Beispiel/.classpath +++ b/Bank-Beispiel/.classpath @@ -1,10 +1,11 @@ - - - - - - - - - - + + + + + + + + + + + diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Bank.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Bank.java index 0b66d3d..d5f5963 100644 --- a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Bank.java +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Bank.java @@ -6,21 +6,44 @@ import java.util.HashMap; public class Bank { private String name; private HashMap konten = new HashMap<>(); - + public Bank(String name) { this.name = name; } - + public void addKonto(Konto k) { konten.put(k.getKontonummer(), k); } - + public String getName() { return name; } - + public Collection getKontenliste() { return konten.values(); } - + + public long einzahlen(int kontonummer, long einzahlung) { + + if (konten.get(kontonummer) != null) { + long altStand = konten.get(kontonummer).getStand(); + if (einzahlung > 0) { + konten.get(kontonummer).setStand(altStand += einzahlung); + // Ausgabe + System.out.println("Ihr aktueller Kontostand betraegt " + konten.get(kontonummer).getStand()); + } else { + System.out.println("Der einzuzahlende Geldbetrag muss mindesten 1 Euro betragen!"); + System.out.println("Bitte versuchen Sie es mit einem geeigneten Geldbetrag erneut."); + } + } else { + System.out.println("Diese Kontonummer konnte in unserem System nicht gefunden werden!"); + System.out.println("Bitte Eingabe wiederholen."); + } + return konten.get(kontonummer).getStand(); + } + + public long kontoAnzeigen(int kontonummer) { + return konten.get(kontonummer).getStand(); + } + } 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 654d503..1da1391 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 @@ -2,7 +2,7 @@ package de.hs_mannheim.informatik.bank.domain; public class Konto { private static int kontozähler = 0; - + private int nummer; private long stand = 0; private String inhaber; @@ -11,7 +11,7 @@ public class Konto { nummer = 1000 + kontozähler++; this.inhaber = inhaber; } - + public int getKontonummer() { return nummer; } @@ -20,5 +20,14 @@ public class Konto { public String toString() { return "Konto [nummer=" + nummer + ", inhaber=" + inhaber + "]"; } - + + public long getStand() { + return stand; + } + + public void setStand(long stand) { + this.stand = stand; + + } + } diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/TestKonto.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/TestKonto.java new file mode 100644 index 0000000..ae5f013 --- /dev/null +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/TestKonto.java @@ -0,0 +1,41 @@ +package de.hs_mannheim.informatik.bank.domain; + +import org.junit.Assert; +import org.junit.jupiter.api.Test; + +class TestKonto { + + Bank bank = new Bank("Volksbank"); + Konto konto = new Konto("Smith"); + + @Test + void testEinzahlen() { + + bank.addKonto(konto); + bank.einzahlen(konto.getKontonummer(), 1000); + + Assert.assertEquals(1000, konto.getStand()); + + } + + @Test + void testInferiorLimit() { + + bank.addKonto(konto); + bank.einzahlen(konto.getKontonummer(), -100); + + Assert.assertEquals(0, konto.getStand()); + + } + + @Test + void testUpperLimit() { + + bank.addKonto(konto); + bank.einzahlen(konto.getKontonummer(), 10001); + + Assert.assertEquals(10001, konto.getStand()); + + } + +} 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 821c2a9..3672307 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 @@ -7,31 +7,42 @@ import de.hs_mannheim.informatik.bank.domain.Konto; public class Banksystem { private Bank bank; - + public Banksystem(String bankname) { this.bank = new Bank(bankname); } - + public int kontoAnlegen(String name) { Konto k = new Konto(name); bank.addKonto(k); - + return k.getKontonummer(); } - + public String[] getKontenliste() { Collection konten = bank.getKontenliste(); String[] liste = new String[konten.size()]; - + int i = 0; for (Konto k : konten) { - liste[i++] = k.toString(); + liste[i++] = k.toString(); } - + return liste; } - + public String getBankname() { return bank.getName(); } + + public long einzahlen(int kontonummer, long einzahlung) { + + return bank.einzahlen(kontonummer, einzahlung); + + } + + public long kontoAnzeigen(int kontonummer) { + return bank.kontoAnzeigen(kontonummer); + } + } diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/TestBanksystem.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/TestBanksystem.java new file mode 100644 index 0000000..3d40e6b --- /dev/null +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/TestBanksystem.java @@ -0,0 +1,23 @@ +package de.hs_mannheim.informatik.bank.facade; + +import org.junit.Assert; +import org.junit.jupiter.api.Test; + +class TestBanksystem { + + Banksystem bs = new Banksystem("Volksbank"); + int kn = bs.kontoAnlegen("Smith"); + + @Test + void testNegativeNumbers() { + + Assert.assertEquals(0, bs.einzahlen(kn, -100)); + } + + @Test + void testEinzahlen() { + + Assert.assertEquals(1000, bs.einzahlen(kn, 1000)); + } + +} 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 d6eb6e9..b01e073 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 @@ -16,32 +16,44 @@ public class UI { private void hauptmenü() { System.out.println("Willkommen bei der " + bs.getBankname() + "!"); - mainloop: - while (true) { - System.out.println(); - System.out.println("--------"); - System.out.println("Hauptmenü"); - System.out.println("1 -> Konten anzeigen"); - System.out.println("2 -> Konto anlegen"); - System.out.println("9 -> Beenden"); - System.out.println(); + mainloop: while (true) { + System.out.println(); + System.out.println("--------"); + System.out.println("Hauptmenue"); + System.out.println("1 -> Konten anzeigen"); + System.out.println("2 -> Konto anlegen"); + System.out.println("3 -> Geld einzahlen"); + System.out.println("4 -> Kontostand anzeigen"); + System.out.println("9 -> Beenden"); + System.out.println(); - System.out.print("> "); - int input = Integer.parseInt(sc.nextLine()); - System.out.println(); + System.out.print("> "); + int input = Integer.parseInt(sc.nextLine()); + System.out.println(); - switch(input) { - case 1: kontenAnzeigen(); break; - case 2: kontoAnlegen(); break; - case 9: break mainloop; - } + switch (input) { + case 1: + kontenAnzeigen(); + break; + case 2: + kontoAnlegen(); + break; + case 3: + einzahlen(); + break; + case 4: + kontoAnzeigen(); + break; + case 9: + break mainloop; } + } System.out.println("Auf Wiedersehen!"); } // hauptmenü - private void kontenAnzeigen() { + private void kontenAnzeigen() { String[] konten = bs.getKontenliste(); if (konten.length > 0) { System.out.println("Folgende Konten sind aktuell verfügbar:"); @@ -61,4 +73,23 @@ public class UI { System.out.println("Konto mit der Nummer " + kontonummer + " neu angelegt."); } + private void einzahlen() { + System.out.println("Bitte geben Sie den Betrag zum einzahlen ein: "); + long Betrag = Long.parseLong(sc.nextLine()); + + System.out.println("Bitte bestaetigen Sie ihre Kontonummer: "); + int kontonummer = Integer.parseInt(sc.nextLine()); + + bs.einzahlen(kontonummer, Betrag); + + } + + public void kontoAnzeigen() { + System.out.println("Bitte Ihre Kontonummer eingeben: "); + int nummer = Integer.parseInt(sc.nextLine()); + + System.out.println("Ihr aktueller Kontostand betraegt: " + bs.kontoAnzeigen(nummer) + " Euro"); + + } + }