kunde eunbau
parent
28f3210988
commit
8bd294616c
|
@ -7,27 +7,26 @@ import java.util.HashMap;
|
||||||
public class Bank implements Serializable {
|
public class Bank implements Serializable {
|
||||||
private String name;
|
private String name;
|
||||||
private HashMap<Integer, Konto> konten = new HashMap<>();
|
private HashMap<Integer, Konto> konten = new HashMap<>();
|
||||||
private HashMap<Integer, String> kunden = new HashMap<>();
|
private HashMap<Integer, Kunde> kunden = new HashMap<>();
|
||||||
|
|
||||||
private int kontozähler;
|
private int kontozähler;
|
||||||
|
|
||||||
|
|
||||||
public Bank(String name) {
|
public Bank(String name) {
|
||||||
this.name = name;
|
this.name = name;
|
||||||
this.kontozähler = -1;
|
this.kontozähler = -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
public int addKonto(String vorname, String nachname, int alter, String wohnort, int auswahl) {
|
public int addKonto(String vorname, String nachname, int alter, String wohnort, int auswahl) {
|
||||||
Konto k;
|
Konto k;
|
||||||
|
|
||||||
if (auswahl == 1)
|
if (auswahl == 1)
|
||||||
k = new Konto(vorname, nachname, alter, wohnort, auswahl, ++kontozähler);
|
k = new Konto(vorname, nachname, alter, ++kontozähler);
|
||||||
else
|
else
|
||||||
k = new Girokonto(vorname, nachname, alter, wohnort, auswahl, ++kontozähler);
|
k = new Girokonto(vorname, nachname, alter, ++kontozähler);
|
||||||
|
addKunde(k, wohnort);
|
||||||
konten.put(k.getKontonummer(), k);
|
konten.put(k.getKontonummer(), k);
|
||||||
kunden.put(k.getKontonummer(), (vorname + " "+ nachname));
|
|
||||||
|
|
||||||
return k.getKontonummer();
|
return k.getKontonummer();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -43,8 +42,14 @@ public class Bank implements Serializable {
|
||||||
return konten.get(kontonummer);
|
return konten.get(kontonummer);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Collection<String> getKundenliste() {
|
public Collection<Kunde> getKundenliste() {
|
||||||
return kunden.values();
|
return kunden.values();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void addKunde(Konto k, String wohnort) {
|
||||||
|
Kunde ku = new Kunde(k, wohnort);
|
||||||
|
kunden.put(k.getKontonummer(), ku);
|
||||||
|
ku.addKontoZuKunde(k.getKontonummer());
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,8 +5,8 @@ import java.io.Serializable;
|
||||||
public class Depot extends Konto implements Serializable {
|
public class Depot extends Konto implements Serializable {
|
||||||
|
|
||||||
public Depot(String vorname, String nachname, int alter, String wohnort, int auswahl, int kontozähler) {
|
public Depot(String vorname, String nachname, int alter, String wohnort, int auswahl, int kontozähler) {
|
||||||
super(vorname, nachname, alter, wohnort, auswahl, kontozähler);
|
super(vorname, nachname, alter, auswahl);
|
||||||
// TODO Auto-generated constructor stub
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,8 +5,8 @@ import java.io.Serializable;
|
||||||
public class Girokonto extends Konto implements Serializable {
|
public class Girokonto extends Konto implements Serializable {
|
||||||
private long dispo = 100000;
|
private long dispo = 100000;
|
||||||
|
|
||||||
public Girokonto(String vorname , String nachname, int alter, String wohnort, int auswahl, int kontozähler) {
|
public Girokonto(String vorname , String nachname, int alter, int auswahl) {
|
||||||
super(vorname, nachname, alter, wohnort, auswahl, kontozähler);
|
super(vorname, nachname, alter, auswahl);
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean überweise(Girokonto ziel, long betrag, String zweck) {
|
public boolean überweise(Girokonto ziel, long betrag, String zweck) {
|
||||||
|
|
|
@ -10,7 +10,7 @@ class GirokontoTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
void testÜberziehung() {
|
void testÜberziehung() {
|
||||||
Konto k = new Girokonto("Müller", null, 0, null, 0, 0);
|
Konto k = new Girokonto("Müller", null, 0, 0);
|
||||||
k.einzahlen(10000, "Test", "Einzahlung", "JUnit");
|
k.einzahlen(10000, "Test", "Einzahlung", "JUnit");
|
||||||
|
|
||||||
assertTrue(k.auszahlen(20000, "Test", "Einzahlung", "JUnit"));
|
assertTrue(k.auszahlen(20000, "Test", "Einzahlung", "JUnit"));
|
||||||
|
|
|
@ -7,15 +7,20 @@ public class Konto implements Serializable {
|
||||||
private int nummer;
|
private int nummer;
|
||||||
protected long stand = 0;
|
protected long stand = 0;
|
||||||
private String inhaber;
|
private String inhaber;
|
||||||
private Kunde ku;
|
private String vorname;
|
||||||
|
private String nachname;
|
||||||
|
private int alter;
|
||||||
|
|
||||||
protected ArrayList<Kontobewegung> kontobewegungen;
|
protected ArrayList<Kontobewegung> kontobewegungen;
|
||||||
|
|
||||||
public Konto(String vorname, String nachname, int alter, String wohnort, int auswahl, int kontozähler) {
|
public Konto(String vorname, String nachname, int alter, int kontozähler) {
|
||||||
nummer = 1000 + kontozähler;
|
nummer = 1000 + kontozähler;
|
||||||
this.inhaber = vorname+" "+nachname;
|
this.inhaber = vorname+" "+nachname;
|
||||||
|
this.vorname = vorname;
|
||||||
|
this.nachname = nachname;
|
||||||
|
this.alter = alter;
|
||||||
|
|
||||||
this.kontobewegungen = new ArrayList<>();
|
this.kontobewegungen = new ArrayList<>();
|
||||||
this.ku = new Kunde(vorname, nachname, alter, wohnort, nummer);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -75,4 +80,19 @@ public class Konto implements Serializable {
|
||||||
return saldo;
|
return saldo;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String getVorname() {
|
||||||
|
// TODO Auto-generated method stub
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getNachname() {
|
||||||
|
// TODO Auto-generated method stub
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getAlter() {
|
||||||
|
// TODO Auto-generated method stub
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,7 +8,7 @@ class KontoTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
void testKontoBasics() {
|
void testKontoBasics() {
|
||||||
Konto k = new Konto("Müller", null, 0, null, 0, 0);
|
Konto k = new Konto("Müller", null, 0, 0);
|
||||||
assertEquals("Müller", k.getInhaber());
|
assertEquals("Müller", k.getInhaber());
|
||||||
assertEquals(1000, k.getKontonummer());
|
assertEquals(1000, k.getKontonummer());
|
||||||
assertEquals(0, k.getKontostand());
|
assertEquals(0, k.getKontostand());
|
||||||
|
@ -16,12 +16,12 @@ class KontoTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
void testKontoEinUndAuszahlungUndSaldo() {
|
void testKontoEinUndAuszahlungUndSaldo() {
|
||||||
Konto k = new Konto("Müller", null, 0, null, 0, 0);
|
Konto k = new Konto("Müller", null, 0, 0);
|
||||||
Konto k2 = new Konto("Mayer", null, 1, null, 0, 0);
|
Konto k2 = new Konto("Mayer", null, 1, 0);
|
||||||
testKontoEinUndAuszahlungUndSaldo(k, k2);
|
testKontoEinUndAuszahlungUndSaldo(k, k2);
|
||||||
|
|
||||||
k = new Girokonto("Müller", null, 0, null, 0, 0);
|
k = new Girokonto("Müller", null, 0, 0);
|
||||||
k2 = new Girokonto("Mayer", null, 1, null, 0, 0);
|
k2 = new Girokonto("Mayer", null, 1, 0);
|
||||||
testKontoEinUndAuszahlungUndSaldo(k, k2);
|
testKontoEinUndAuszahlungUndSaldo(k, k2);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -49,7 +49,7 @@ class KontoTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
void testKeineÜberziehungFürSparkonten() {
|
void testKeineÜberziehungFürSparkonten() {
|
||||||
Konto k = new Konto("Müller", null, 0, null, 0, 0);
|
Konto k = new Konto("Müller", null, 0, 0);
|
||||||
k.einzahlen(100, "Test", "Einzahlung", "JUnit");
|
k.einzahlen(100, "Test", "Einzahlung", "JUnit");
|
||||||
assertFalse(k.auszahlen(500, "Test", "Auszahlung", "JUnit"));
|
assertFalse(k.auszahlen(500, "Test", "Auszahlung", "JUnit"));
|
||||||
|
|
||||||
|
|
|
@ -2,30 +2,46 @@ package de.hs_mannheim.informatik.bank.domain;
|
||||||
|
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
public class Kunde implements Serializable {
|
public class Kunde implements Serializable {
|
||||||
private final String vorname;
|
private String vorname;
|
||||||
private String nachname;
|
private String nachname;
|
||||||
private int alter;
|
private final int alter;
|
||||||
private String wohnort;
|
private String wohnort;
|
||||||
|
private int id;
|
||||||
|
|
||||||
private int kontonummer;
|
private ArrayList<Integer> kAmount = new ArrayList<>();
|
||||||
|
|
||||||
public Kunde(String vorname, String nachname, int alter, String wohnort, int kontonummer) {
|
|
||||||
this.vorname = vorname;
|
// public Kunde(String vorname, String nachname, int alter, String wohnort, int kontonummer) {
|
||||||
this.nachname = nachname;
|
// this.vorname = vorname;
|
||||||
this.alter = alter;
|
// this.nachname = nachname;
|
||||||
|
// this.alter = alter;
|
||||||
|
// this.wohnort = wohnort;
|
||||||
|
// this.kontonummer = kontonummer;
|
||||||
|
//
|
||||||
|
// }
|
||||||
|
public Kunde(Konto k, String Wohnort) {
|
||||||
|
this.vorname = k.getVorname();
|
||||||
|
this.nachname = k.getNachname();
|
||||||
|
this.alter = k.getAlter();
|
||||||
this.wohnort = wohnort;
|
this.wohnort = wohnort;
|
||||||
this.kontonummer = kontonummer;
|
|
||||||
|
|
||||||
}
|
}
|
||||||
public String getFullName(String vorname, String nachname) {
|
|
||||||
return vorname+" "+nachname;
|
|
||||||
|
public void addKontoZuKunde(int kontonummer) {
|
||||||
|
kAmount.add(kontonummer);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return "Konto2 testlauf kunden " + kontonummer + " " + vorname +" "+ nachname + " "+ wohnort+ " ]";
|
return "Kundendurchlauf " + id + " " + vorname +" "+ nachname + " "+ wohnort+ " und soviele konten"+kAmount+" ]";
|
||||||
|
|
||||||
|
}
|
||||||
|
public ArrayList <Integer> getKontenamount() {
|
||||||
|
return kAmount;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -5,6 +5,7 @@ import java.util.Collection;
|
||||||
import de.hs_mannheim.informatik.bank.domain.Bank;
|
import de.hs_mannheim.informatik.bank.domain.Bank;
|
||||||
import de.hs_mannheim.informatik.bank.domain.Girokonto;
|
import de.hs_mannheim.informatik.bank.domain.Girokonto;
|
||||||
import de.hs_mannheim.informatik.bank.domain.Konto;
|
import de.hs_mannheim.informatik.bank.domain.Konto;
|
||||||
|
import de.hs_mannheim.informatik.bank.domain.Kunde;
|
||||||
import de.hs_mannheim.informatik.bank.infrastructure.Persistenz;
|
import de.hs_mannheim.informatik.bank.infrastructure.Persistenz;
|
||||||
|
|
||||||
public class Banksystem {
|
public class Banksystem {
|
||||||
|
@ -19,7 +20,6 @@ public class Banksystem {
|
||||||
|
|
||||||
public int kontoAnlegen(String vorname, String nachname, int alter, String wohnort, int auswahl) throws Exception {
|
public int kontoAnlegen(String vorname, String nachname, int alter, String wohnort, int auswahl) throws Exception {
|
||||||
int kontonummer = bank.addKonto(vorname, nachname, alter, wohnort, auswahl);
|
int kontonummer = bank.addKonto(vorname, nachname, alter, wohnort, auswahl);
|
||||||
|
|
||||||
Persistenz.speichereBankDaten(this.bank, bank.getName());
|
Persistenz.speichereBankDaten(this.bank, bank.getName());
|
||||||
|
|
||||||
return kontonummer;
|
return kontonummer;
|
||||||
|
@ -41,12 +41,18 @@ public class Banksystem {
|
||||||
return bank.getName();
|
return bank.getName();
|
||||||
}
|
}
|
||||||
|
|
||||||
public long geldEinzahlen(int kontonummer, long betrag) throws Exception {
|
public long geldEinzahlen(int kontonummer, long betrag) {
|
||||||
Konto konto = bank.findeKonto(kontonummer);
|
Konto konto = bank.findeKonto(kontonummer);
|
||||||
konto.einzahlen(betrag, "Einzahlung am Schalter", "Einzahlung", konto.getInhaber());
|
try {
|
||||||
|
konto.einzahlen(betrag, "Einzahlung am Schalter", "Einzahlung", konto.getInhaber());
|
||||||
|
|
||||||
|
Persistenz.speichereBankDaten(this.bank, bank.getName());
|
||||||
|
} catch (Exception e) {
|
||||||
|
System.err.println("Einzahlung fehlgeschlagen");
|
||||||
|
System.out.println("Einzahlung nicht registriert");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
Persistenz.speichereBankDaten(this.bank, bank.getName());
|
|
||||||
|
|
||||||
return konto.getKontostand();
|
return konto.getKontostand();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -93,11 +99,11 @@ public class Banksystem {
|
||||||
}
|
}
|
||||||
|
|
||||||
public String[] getKundenliste() {
|
public String[] getKundenliste() {
|
||||||
Collection<String> kunden = bank.getKundenliste();
|
Collection<Kunde> kunden = bank.getKundenliste();
|
||||||
String[] liste = new String[kunden.size()];
|
String[] liste = new String[kunden.size()];
|
||||||
|
|
||||||
int i = 0;
|
int i = 0;
|
||||||
for (String k : kunden) {
|
for (Kunde k : kunden) {
|
||||||
liste[i++] = k.toString();
|
liste[i++] = k.toString();
|
||||||
}
|
}
|
||||||
return liste;
|
return liste;
|
||||||
|
|
|
@ -1,7 +1,9 @@
|
||||||
package de.hs_mannheim.informatik.bank.ui;
|
package de.hs_mannheim.informatik.bank.ui;
|
||||||
|
|
||||||
|
import java.util.Collection;
|
||||||
import java.util.Scanner;
|
import java.util.Scanner;
|
||||||
|
|
||||||
|
import de.hs_mannheim.informatik.bank.domain.Konto;
|
||||||
import de.hs_mannheim.informatik.bank.facade.Banksystem;
|
import de.hs_mannheim.informatik.bank.facade.Banksystem;
|
||||||
|
|
||||||
public class UI {
|
public class UI {
|
||||||
|
@ -20,7 +22,7 @@ public class UI {
|
||||||
while (true) {
|
while (true) {
|
||||||
System.out.println();
|
System.out.println();
|
||||||
System.out.println("--------");
|
System.out.println("--------");
|
||||||
System.out.println("Hauptmenü");
|
System.out.println("Hauptmenü");
|
||||||
System.out.println("1 -> Konten anzeigen");
|
System.out.println("1 -> Konten anzeigen");
|
||||||
System.out.println("2 -> Konto anlegen");
|
System.out.println("2 -> Konto anlegen");
|
||||||
System.out.println("3 -> Geld einzahlen");
|
System.out.println("3 -> Geld einzahlen");
|
||||||
|
@ -40,9 +42,7 @@ public class UI {
|
||||||
try {
|
try {
|
||||||
switch(input) {
|
switch(input) {
|
||||||
case 1: kontenAnzeigen(); break;
|
case 1: kontenAnzeigen(); break;
|
||||||
case 2:
|
case 2: kontoAnlegen(); break;
|
||||||
kontoAnlegen();
|
|
||||||
break;
|
|
||||||
case 3: geldEinzahlen(); break;
|
case 3: geldEinzahlen(); break;
|
||||||
case 4: geldAuszahlen(); break;
|
case 4: geldAuszahlen(); break;
|
||||||
case 5: kontoauszugDrucken(); break;
|
case 5: kontoauszugDrucken(); break;
|
||||||
|
@ -107,7 +107,7 @@ public class UI {
|
||||||
System.out.println("Konto mit der Nummer " + kontonummer + " neu angelegt.");
|
System.out.println("Konto mit der Nummer " + kontonummer + " neu angelegt.");
|
||||||
}
|
}
|
||||||
|
|
||||||
private void geldEinzahlen() throws Exception {
|
private void geldEinzahlen() {
|
||||||
int kontonummer = 0;
|
int kontonummer = 0;
|
||||||
System.out.println("Geld einzahlen");
|
System.out.println("Geld einzahlen");
|
||||||
System.out.println("Wie einzahlen? 1-> Kontonummer; 2-> Vorname Nachname");
|
System.out.println("Wie einzahlen? 1-> Kontonummer; 2-> Vorname Nachname");
|
||||||
|
|
Loading…
Reference in New Issue