mirror of
https://github.com/emilybache/GildedRose-Refactoring-Kata.git
synced 2026-02-16 06:51:27 +00:00
Refactroring completed: 4 methods extracted to update each item indivdaully. Additionally, unit test added to handle most and edge cases
This commit is contained in:
parent
baaada9449
commit
608f8ddb58
@ -12,6 +12,26 @@ class GildedRose {
|
|||||||
this.items = items;
|
this.items = items;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void updateQuality() {
|
||||||
|
for (Item item : this.items) {
|
||||||
|
// update each item individually
|
||||||
|
switch (item.name) {
|
||||||
|
case AGED_BRIE:
|
||||||
|
updateAgedBrie(item);
|
||||||
|
continue;
|
||||||
|
|
||||||
|
case BACKSTAGE_PASS:
|
||||||
|
updateBackStage(item);
|
||||||
|
continue;
|
||||||
|
case SULFURAS:
|
||||||
|
updateSulfuras(item);
|
||||||
|
continue;
|
||||||
|
default:
|
||||||
|
updateNormalItem(item);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public void updateAgedBrie(Item item) {
|
public void updateAgedBrie(Item item) {
|
||||||
|
|
||||||
@ -72,32 +92,6 @@ class GildedRose {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void updateQuality() {
|
|
||||||
for (Item item : this.items) {
|
|
||||||
|
|
||||||
// only sulfuras don't sell
|
|
||||||
// hence update sellin value for all items except sulfuras here
|
|
||||||
|
|
||||||
if (item.name != SULFURAS) {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
switch (item.name) {
|
|
||||||
case AGED_BRIE:
|
|
||||||
updateAgedBrie(item);
|
|
||||||
continue;
|
|
||||||
|
|
||||||
case BACKSTAGE_PASS:
|
|
||||||
updateBackStage(item);
|
|
||||||
continue;
|
|
||||||
case SULFURAS:
|
|
||||||
updateSulfuras(item);
|
|
||||||
continue;
|
|
||||||
default:
|
|
||||||
updateNormalItem(item);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user