Finished tests

This commit is contained in:
Benjamin Barreto 2020-10-22 11:51:01 +02:00
parent cd6ad78810
commit f2ffd56269
2 changed files with 127 additions and 11 deletions

View File

@ -78,7 +78,7 @@ export class RegularItem extends Item {
* @returns {Number}
*/
getDepreciationRate () {
return this.sellIn < 0 ? this.depreciationRate * 2 : this.depreciationRate
return this.sellIn <= 0 ? this.depreciationRate * 2 : this.depreciationRate
}
/**
@ -121,7 +121,7 @@ export class ConcertPass extends RegularItem {
*/
getDepreciationRate () {
// "Quality drops to 0 after the concert"
if (this.sellIn < 0) {
if (this.sellIn <= 0) {
return this.quality
}
@ -146,15 +146,6 @@ export class AgedCheese extends RegularItem {
// "Aged Brie" actually increases in Quality the older it gets
this.depreciationRate = -1
}
/**
* Calculates the depreciation rate of an aged cheese, which should be inverted (appreciation).
* For cheese, the legacy logic shows 0 sellIn is inclusive when determining the acceleration of
* the appreciation rate (twice as fast past its "sellIn" date).
*/
getDepreciationRate () {
return this.sellIn <= 0 ? this.depreciationRate * 2 : this.depreciationRate
}
}
export class LegendaryItem extends RegularItem {

View File

@ -3,6 +3,8 @@ import {
RegularItem,
ConcertPass,
AgedCheese,
LegendaryItem,
ConjuredItem,
Shop,
ShopV2
} from '../src/gilded_rose'
@ -27,12 +29,67 @@ describe('Shop', function () {
for (let day = 0; day < 100; day++) {
gildedRose.items.forEach((itemV1, index) => {
const itemV2 = gildedRoseV2.items[index]
expect(itemV1.name).toEqual(itemV2.name)
expect(itemV1.sellIn).toEqual(itemV2.sellIn)
expect(itemV1.quality).toEqual(itemV2.quality)
})
gildedRose.updateQuality()
gildedRoseV2.updateQuality()
}
})
it('should initialize with an empty array when no items are provided', () => {
const gildedRose = new Shop()
expect(gildedRose.items.length).toEqual(0)
})
})
describe('ShopV2', () => {
it('should properly handle ConjuredItem', () => {
const mockProps = {
name: 'Conjured Mana Cake',
sellIn: 3,
quality: 6
}
const gildedRoseV2 = new ShopV2([new Item(mockProps.name, mockProps.sellIn, mockProps.quality)])
const conjuredItem = gildedRoseV2.items[0]
expect(conjuredItem.name).toEqual(mockProps.name)
expect(conjuredItem.sellIn).toEqual(mockProps.sellIn)
expect(conjuredItem.quality).toEqual(mockProps.quality)
for (let day = 0; day < 5; day++) {
expect(conjuredItem.sellIn).toEqual(mockProps.sellIn - day)
const qualityModifier = day * conjuredItem.depreciationRate
const expectedQuality = mockProps.quality - (qualityModifier)
if (expectedQuality > 0) {
expect(conjuredItem.quality).toEqual(expectedQuality)
} else {
expect(conjuredItem.quality).toEqual(0)
}
gildedRoseV2.updateQuality()
}
})
it('should initialize with an empty array when no items are provided', () => {
const gildedRoseV2 = new ShopV2()
expect(gildedRoseV2.items.length).toEqual(0)
})
})
describe('Item', () => {
it('should initialize with a name, sellIn, and quality properties', () => {
const mockProperties = {
name: 'Mock RegularItem',
sellIn: 5,
quality: 25
}
const mockItem = new Item(mockProperties.name, mockProperties.sellIn, mockProperties.quality)
expect(mockItem.name).toEqual(mockProperties.name)
expect(mockItem.sellIn).toEqual(mockProperties.sellIn)
expect(mockItem.quality).toEqual(mockProperties.quality)
})
})
describe('RegularItem', () => {
@ -179,6 +236,32 @@ describe('ConcertPass', () => {
mockConcertPass.updateQuality()
expect(mockConcertPass.quality).toEqual(0)
})
describe('ConcertPass.getDepreciationRate', () => {
it('should return "quality" when sellIn < 0', () => {
const mockConcertPass = new ConcertPass({ ...mockProperties, sellIn: -1 })
expect(mockConcertPass.getDepreciationRate()).toEqual(mockConcertPass.quality)
})
it('should return depreciationRate * 3 when sellIn <= 5', () => {
const mockConcertPass = new ConcertPass({ ...mockProperties, sellIn: 5 })
expect(mockConcertPass.getDepreciationRate()).toEqual(mockConcertPass.depreciationRate * 3)
mockConcertPass.sellIn = 4
expect(mockConcertPass.getDepreciationRate()).toEqual(mockConcertPass.depreciationRate * 3)
})
it('should return depreciationRate * 2 when sellIn <= 10', () => {
const mockConcertPass = new ConcertPass({ ...mockProperties, sellIn: 10 })
expect(mockConcertPass.getDepreciationRate()).toEqual(mockConcertPass.depreciationRate * 2)
mockConcertPass.sellIn = 9
expect(mockConcertPass.getDepreciationRate()).toEqual(mockConcertPass.depreciationRate * 2)
})
it('should return a normal depreciationRate when sellIn > 10', () => {
const mockConcertPass = new ConcertPass({ ...mockProperties, sellIn: 11 })
expect(mockConcertPass.getDepreciationRate()).toEqual(mockConcertPass.depreciationRate)
})
})
})
describe('AgedCheese', () => {
@ -215,3 +298,45 @@ describe('AgedCheese', () => {
})
})
})
describe('LegendaryItem', () => {
const mockProperties = {
name: 'Mock LegendaryItem',
sellIn: 5,
quality: 80
}
it('should be initialized with a depreciation rate equal to zero', () => {
const mockLegendaryItem = new LegendaryItem({ ...mockProperties })
expect(mockLegendaryItem.depreciationRate).toEqual(0)
})
it('should remain the same when the quality is updated', () => {
const mockLegendaryItem = new LegendaryItem({ ...mockProperties })
mockLegendaryItem.updateQuality()
expect(mockLegendaryItem.quality).toEqual(mockProperties.quality)
expect(mockLegendaryItem.sellIn).toEqual(mockProperties.sellIn)
})
describe('LegendaryItem.isQualityValid', () => {
it('should return true only if quality is exactly 80', () => {
const mockLegendaryItem = new LegendaryItem({ ...mockProperties })
expect(mockLegendaryItem.isQualityValid('')).toBeFalsy()
expect(mockLegendaryItem.isQualityValid(50)).toBeFalsy()
expect(mockLegendaryItem.isQualityValid(80)).toBeTruthy()
})
})
})
describe('ConjuredItem', () => {
const mockProperties = {
name: 'Mock Item',
sellIn: 5,
quality: 25
}
it('should be initialized with a depreciation rate twice as large as a RegularItem', () => {
const mockRegularItem = new RegularItem({ ...mockProperties })
const mockConjuredItem = new ConjuredItem({ ...mockProperties })
expect(mockConjuredItem.depreciationRate).toEqual(mockRegularItem.depreciationRate * 2)
})
})