mirror of
https://github.com/emilybache/GildedRose-Refactoring-Kata.git
synced 2026-02-15 22:41:30 +00:00
120 lines
3.7 KiB
Ruby
120 lines
3.7 KiB
Ruby
require 'gilded_rose'
|
|
|
|
# rubocop:disable all
|
|
describe 'feature tests' do
|
|
let(:potato) { Item.new('potato', 15, 2) }
|
|
let(:sulfarus) { Item.new('Sulfuras, Hand of Ragnaros', 50, 80) }
|
|
|
|
it 'does not change the name' do
|
|
items = [Item.new('foo', 0, 0)]
|
|
GildedRose.update_quality(items)
|
|
expect(items[0].name).to eq 'foo'
|
|
end
|
|
|
|
describe 'non-special item input' do
|
|
it 'should decrese the quality of normal item' do
|
|
items = [potato]
|
|
GildedRose.update_quality(items)
|
|
expect(items.first.quality).to eq(1)
|
|
end
|
|
|
|
it 'should decrese the sellIn of normal item' do
|
|
items = [potato]
|
|
GildedRose.update_quality(items)
|
|
expect(items.first.sell_in).to eq(14)
|
|
end
|
|
|
|
it 'should decrease quality of normal items by 2 when sell_in date passes' do
|
|
items = [Item.new('old potato', -1, 20)]
|
|
GildedRose.update_quality(items)
|
|
expect(items.first.quality).to eq(18)
|
|
end
|
|
|
|
it 'should not decrease quality below 0' do
|
|
items = [Item.new('old potato', 0, 0)]
|
|
GildedRose.update_quality(items)
|
|
expect(items.first.quality).to eq(0)
|
|
end
|
|
end
|
|
|
|
describe 'Aged Brie input' do
|
|
it 'increases in quality as it ages' do
|
|
items = [Item.new('Aged Brie', 25, 45)]
|
|
GildedRose.update_quality(items)
|
|
expect(items.first.quality).to eq 46
|
|
end
|
|
|
|
it 'cannot increase in quality beyond 50' do
|
|
items = [Item.new('Aged Brie', 25, 50)]
|
|
GildedRose.update_quality(items)
|
|
expect(items.first.quality).to eq 50
|
|
end
|
|
it 'doubles the increase when sell_in below 1' do
|
|
items = [Item.new('Aged Brie', 0, 20)]
|
|
GildedRose.update_quality(items)
|
|
expect(items.first.quality).to eq 22
|
|
end
|
|
end
|
|
|
|
describe 'Sulfuras input' do
|
|
it 'does not change' do
|
|
items = [sulfarus]
|
|
GildedRose.update_quality(items)
|
|
expect(items[0].quality).to eq 80
|
|
expect(items[0].sell_in).to eq 50
|
|
end
|
|
end
|
|
|
|
describe 'backstage pass input' do
|
|
it 'increases in quality by one when sellIn is > 10 days' do
|
|
items = [Item.new('Backstage passes to a TAFKAL80ETC concert', 15, 20)]
|
|
GildedRose.update_quality(items)
|
|
expect(items.first.quality).to eq 21
|
|
end
|
|
|
|
it 'increases in quality by 2 when sellin < 10 days' do
|
|
items = [Item.new('Backstage passes to a TAFKAL80ETC concert', 9, 20)]
|
|
GildedRose.update_quality(items)
|
|
expect(items.first.quality).to eq 22
|
|
end
|
|
|
|
it 'increases by 3 when sellin < 5' do
|
|
items = [Item.new('Backstage passes to a TAFKAL80ETC concert', 4, 20)]
|
|
GildedRose.update_quality(items)
|
|
expect(items.first.quality).to eq 23
|
|
end
|
|
|
|
it 'decreases to 0 when sellin == 0' do
|
|
items = [Item.new('Backstage passes to a TAFKAL80ETC concert', 0, 20)]
|
|
GildedRose.update_quality(items)
|
|
expect(items.first.quality).to eq 0
|
|
end
|
|
end
|
|
|
|
describe 'conjured input' do
|
|
it 'should degrade twice as fast as normal items' do
|
|
items = [Item.new('Conjured Armour', 10, 15)]
|
|
GildedRose.update_quality(items)
|
|
expect(items.first.quality).to eq 13
|
|
end
|
|
|
|
it 'should not degrade past 0' do
|
|
items = [Item.new('Conjured Armour', 10, 1)]
|
|
GildedRose.update_quality(items)
|
|
expect(items.first.quality).to eq 0
|
|
end
|
|
|
|
it 'should degrade by 4 when sell in has passed' do
|
|
items = [Item.new('Conjured Armour', -1, 17)]
|
|
GildedRose.update_quality(items)
|
|
expect(items.first.quality).to eq 13
|
|
end
|
|
|
|
it 'still should not degrade past 0 when sell in has passed' do
|
|
items = [Item.new('Conjured Armour', -1, 3)]
|
|
GildedRose.update_quality(items)
|
|
expect(items.first.quality).to eq 0
|
|
end
|
|
end
|
|
end
|
|
# rubocop:enable all |