mirror of
https://github.com/emilybache/GildedRose-Refactoring-Kata.git
synced 2026-02-15 14:31:28 +00:00
Finished AgedCheese tests
This commit is contained in:
parent
d1907e56a8
commit
cd6ad78810
3
js-jest/.gitignore
vendored
3
js-jest/.gitignore
vendored
@ -1,2 +1,3 @@
|
||||
/node_modules/
|
||||
.vscode
|
||||
.vscode
|
||||
coverage
|
||||
@ -1,12 +1,39 @@
|
||||
import { RegularItem } from '../src/gilded_rose'
|
||||
import {
|
||||
Item,
|
||||
RegularItem,
|
||||
ConcertPass,
|
||||
AgedCheese,
|
||||
Shop,
|
||||
ShopV2
|
||||
} from '../src/gilded_rose'
|
||||
|
||||
// describe('Gilded Rose', function () {
|
||||
// it('should foo', function () {
|
||||
// const gildedRose = new Shop([new Item('foo', 0, 0)])
|
||||
// const items = gildedRose.updateQuality()
|
||||
// expect(items[0].name).toBe('fixme')
|
||||
// })
|
||||
// })
|
||||
describe('Shop', function () {
|
||||
const mockItems = [
|
||||
new Item('+5 Dexterity Vest', 10, 20),
|
||||
new Item('Aged Brie', 2, 0),
|
||||
new Item('Elixir of the Mongoose', 5, 7),
|
||||
new Item('Sulfuras, Hand of Ragnaros', 0, 80),
|
||||
new Item('Sulfuras, Hand of Ragnaros', -1, 80),
|
||||
new Item('Backstage passes to a TAFKAL80ETC concert', 15, 20),
|
||||
new Item('Backstage passes to a TAFKAL80ETC concert', 10, 49),
|
||||
new Item('Backstage passes to a TAFKAL80ETC concert', 5, 49)
|
||||
]
|
||||
|
||||
// This test ensures the new logic matches the old one, until legacy code can be safely removed.
|
||||
it('results from Shop V1 and V2 should match after 100 iterations', () => {
|
||||
const gildedRose = new Shop(mockItems)
|
||||
const gildedRoseV2 = new ShopV2(mockItems)
|
||||
|
||||
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)
|
||||
})
|
||||
}
|
||||
})
|
||||
})
|
||||
|
||||
describe('RegularItem', () => {
|
||||
const mockProperties = {
|
||||
@ -33,7 +60,7 @@ describe('RegularItem', () => {
|
||||
})
|
||||
|
||||
it('[updateQuality] should decrement sellIn by 1 and quality by 1 when sellIn is >= 0', () => {
|
||||
const mockRegularItem = new RegularItem(mockProperties)
|
||||
const mockRegularItem = new RegularItem({ ...mockProperties })
|
||||
mockRegularItem.updateQuality()
|
||||
expect(mockRegularItem.quality).toEqual(mockProperties.quality - 1)
|
||||
})
|
||||
@ -49,4 +76,142 @@ describe('RegularItem', () => {
|
||||
mockRegularItem.updateQuality()
|
||||
expect(mockRegularItem.quality).toBeGreaterThanOrEqual(0)
|
||||
})
|
||||
|
||||
it('should never increment quality over 50', () => {
|
||||
const mockRegularItem = new RegularItem({ ...mockProperties, quality: 49 })
|
||||
mockRegularItem.depreciationRate = -1
|
||||
mockRegularItem.updateQuality()
|
||||
mockRegularItem.updateQuality()
|
||||
expect(mockRegularItem.quality).toEqual(50)
|
||||
})
|
||||
|
||||
describe('RegularItem.isNameValid', () => {
|
||||
it('should return true only if "name" is a non-empty string', () => {
|
||||
const mockRegularItem = new RegularItem({ ...mockProperties })
|
||||
expect(mockRegularItem.isNameValid('')).toBeFalsy()
|
||||
expect(mockRegularItem.isNameValid('mock name')).toBeTruthy()
|
||||
})
|
||||
})
|
||||
|
||||
describe('RegularItem.isSellInValid', () => {
|
||||
it('should return true only if "sellIn" is a number', () => {
|
||||
const mockRegularItem = new RegularItem({ ...mockProperties })
|
||||
expect(mockRegularItem.isSellInValid('')).toBeFalsy()
|
||||
expect(mockRegularItem.isSellInValid(-1)).toBeTruthy()
|
||||
expect(mockRegularItem.isSellInValid(0)).toBeTruthy()
|
||||
expect(mockRegularItem.isSellInValid(1)).toBeTruthy()
|
||||
})
|
||||
})
|
||||
|
||||
describe('RegularItem.isSellInValid', () => {
|
||||
it('should return true only if "quality" is a number, between 0 and 50', () => {
|
||||
const mockRegularItem = new RegularItem({ ...mockProperties })
|
||||
expect(mockRegularItem.isQualityValid(-1)).toBeFalsy()
|
||||
expect(mockRegularItem.isQualityValid(51)).toBeFalsy()
|
||||
expect(mockRegularItem.isQualityValid(0)).toBeTruthy()
|
||||
expect(mockRegularItem.isQualityValid(25)).toBeTruthy()
|
||||
expect(mockRegularItem.isQualityValid(50)).toBeTruthy()
|
||||
})
|
||||
})
|
||||
|
||||
describe('RegularItem.getDepreciationRate', () => {
|
||||
it('should return a normal depreciation rate when sellIn is >= 0', () => {
|
||||
const mockRegularItem = new RegularItem({ ...mockProperties })
|
||||
expect(mockRegularItem.getDepreciationRate()).toEqual(mockRegularItem.depreciationRate)
|
||||
})
|
||||
|
||||
it('should return a doubled depreciation rate when sellIn is < 0', () => {
|
||||
const mockRegularItem = new RegularItem({ ...mockProperties, sellIn: -1 })
|
||||
expect(mockRegularItem.getDepreciationRate()).toEqual(mockRegularItem.depreciationRate * 2)
|
||||
})
|
||||
})
|
||||
|
||||
describe('RegularItem.setQuality', () => {
|
||||
it('should set quality to whatever number is passed, unless it is over 50', () => {
|
||||
const mockRegularItem = new RegularItem({ ...mockProperties })
|
||||
mockRegularItem.setQuality(-1)
|
||||
expect(mockRegularItem.quality).toEqual(-1)
|
||||
mockRegularItem.setQuality(0)
|
||||
expect(mockRegularItem.quality).toEqual(0)
|
||||
mockRegularItem.setQuality(25)
|
||||
expect(mockRegularItem.quality).toEqual(25)
|
||||
mockRegularItem.setQuality(50)
|
||||
expect(mockRegularItem.quality).toEqual(50)
|
||||
mockRegularItem.setQuality(51)
|
||||
expect(mockRegularItem.quality).toEqual(50)
|
||||
})
|
||||
})
|
||||
})
|
||||
|
||||
describe('ConcertPass', () => {
|
||||
const mockProperties = {
|
||||
name: 'Mock ConcertPass',
|
||||
sellIn: 5,
|
||||
quality: 25
|
||||
}
|
||||
|
||||
it('should initialize with a negative depreciation rate (appreciation)', () => {
|
||||
const mockConcertPass = new ConcertPass(mockProperties)
|
||||
expect(mockConcertPass.depreciationRate).toBeLessThan(0)
|
||||
expect(mockConcertPass.depreciationRate).toEqual(-1)
|
||||
})
|
||||
|
||||
it('should appreciate at normal rate when sellIn is > 10', () => {
|
||||
const mockConcertPass = new ConcertPass({ ...mockProperties, sellIn: 11 })
|
||||
mockConcertPass.updateQuality()
|
||||
expect(mockConcertPass.quality).toEqual(mockProperties.quality + 1)
|
||||
})
|
||||
|
||||
it('should appreciate twice as fast when sellIn is <= 10', () => {
|
||||
const mockConcertPass = new ConcertPass({ ...mockProperties, sellIn: 10 })
|
||||
mockConcertPass.updateQuality()
|
||||
expect(mockConcertPass.quality).toEqual(mockProperties.quality + 2)
|
||||
})
|
||||
|
||||
it('should appreciate three times as fast when sellIn is <= 5', () => {
|
||||
const mockConcertPass = new ConcertPass({ ...mockProperties })
|
||||
mockConcertPass.updateQuality()
|
||||
expect(mockConcertPass.quality).toEqual(mockProperties.quality + 3)
|
||||
})
|
||||
|
||||
it('should have quality 0 when sellIn is < 0', () => {
|
||||
const mockConcertPass = new ConcertPass({ ...mockProperties, sellIn: -1 })
|
||||
mockConcertPass.updateQuality()
|
||||
expect(mockConcertPass.quality).toEqual(0)
|
||||
})
|
||||
})
|
||||
|
||||
describe('AgedCheese', () => {
|
||||
const mockProperties = {
|
||||
name: 'Mock AgedCheese',
|
||||
sellIn: 5,
|
||||
quality: 25
|
||||
}
|
||||
|
||||
it('should initialize with a negative depreciation rate (appreciation)', () => {
|
||||
const mockAgedCheese = new AgedCheese(mockProperties)
|
||||
expect(mockAgedCheese.depreciationRate).toBeLessThan(0)
|
||||
expect(mockAgedCheese.depreciationRate).toEqual(-1)
|
||||
})
|
||||
|
||||
it('should appreciate at normal rate when sellIn is > 0', () => {
|
||||
const mockAgedCheese = new AgedCheese({ ...mockProperties })
|
||||
mockAgedCheese.updateQuality()
|
||||
expect(mockAgedCheese.quality).toEqual(mockProperties.quality + 1)
|
||||
})
|
||||
|
||||
it('should appreciate twice as fast when sellIn is <= 0', () => {
|
||||
const mockAgedCheese = new AgedCheese({ ...mockProperties, sellIn: 0 })
|
||||
mockAgedCheese.updateQuality()
|
||||
expect(mockAgedCheese.quality).toEqual(mockProperties.quality + 2)
|
||||
})
|
||||
|
||||
describe('AgedCheese.getDepreciationRate', () => {
|
||||
it('should return a depreciation rate (appreciation) twice as large when sellIn <= 0', () => {
|
||||
const mockAgedCheese = new AgedCheese({ ...mockProperties, sellIn: 0 })
|
||||
expect(mockAgedCheese.getDepreciationRate()).toEqual(mockAgedCheese.depreciationRate * 2)
|
||||
mockAgedCheese.sellIn = -1
|
||||
expect(mockAgedCheese.getDepreciationRate()).toEqual(mockAgedCheese.depreciationRate * 2)
|
||||
})
|
||||
})
|
||||
})
|
||||
|
||||
Loading…
Reference in New Issue
Block a user