mirror of
https://github.com/emilybache/GildedRose-Refactoring-Kata.git
synced 2026-02-15 22:41:30 +00:00
removing repeated code blocks
This commit is contained in:
parent
10dc87ecc8
commit
35f3f3d680
10
ruby/Dockerfile
Normal file
10
ruby/Dockerfile
Normal file
@ -0,0 +1,10 @@
|
||||
FROM ruby:2.6
|
||||
|
||||
RUN mkdir -p /app
|
||||
WORKDIR /app
|
||||
|
||||
RUN gem install bundler:2.1.4
|
||||
COPY Gemfile Gemfile.lock /app/
|
||||
RUN bundle install
|
||||
|
||||
COPY . /app
|
||||
@ -1,3 +1,7 @@
|
||||
source "https://rubygems.org"
|
||||
# frozen_string_literal: true
|
||||
|
||||
source 'https://rubygems.org'
|
||||
|
||||
gem 'rspec', '~> 3.0'
|
||||
|
||||
gem 'rubocop', '~> 1.15'
|
||||
|
||||
@ -1,7 +1,14 @@
|
||||
GEM
|
||||
remote: https://rubygems.org/
|
||||
specs:
|
||||
ast (2.4.2)
|
||||
diff-lcs (1.4.4)
|
||||
parallel (1.20.1)
|
||||
parser (3.0.1.1)
|
||||
ast (~> 2.4.1)
|
||||
rainbow (3.0.0)
|
||||
regexp_parser (2.1.1)
|
||||
rexml (3.2.5)
|
||||
rspec (3.10.0)
|
||||
rspec-core (~> 3.10.0)
|
||||
rspec-expectations (~> 3.10.0)
|
||||
@ -15,12 +22,26 @@ GEM
|
||||
diff-lcs (>= 1.2.0, < 2.0)
|
||||
rspec-support (~> 3.10.0)
|
||||
rspec-support (3.10.2)
|
||||
rubocop (1.15.0)
|
||||
parallel (~> 1.10)
|
||||
parser (>= 3.0.0.0)
|
||||
rainbow (>= 2.2.2, < 4.0)
|
||||
regexp_parser (>= 1.8, < 3.0)
|
||||
rexml
|
||||
rubocop-ast (>= 1.5.0, < 2.0)
|
||||
ruby-progressbar (~> 1.7)
|
||||
unicode-display_width (>= 1.4.0, < 3.0)
|
||||
rubocop-ast (1.6.0)
|
||||
parser (>= 3.0.1.1)
|
||||
ruby-progressbar (1.11.0)
|
||||
unicode-display_width (2.0.0)
|
||||
|
||||
PLATFORMS
|
||||
ruby
|
||||
|
||||
DEPENDENCIES
|
||||
rspec (~> 3.0)
|
||||
rubocop (~> 1.15)
|
||||
|
||||
BUNDLED WITH
|
||||
2.1.4
|
||||
|
||||
8
ruby/Makefile
Normal file
8
ruby/Makefile
Normal file
@ -0,0 +1,8 @@
|
||||
test:
|
||||
docker-compose up --build test
|
||||
|
||||
lint:
|
||||
docker-compose up --build lint
|
||||
|
||||
auto-correct:
|
||||
docker-compose up --build auto-correct
|
||||
13
ruby/README.md
Normal file
13
ruby/README.md
Normal file
@ -0,0 +1,13 @@
|
||||
## Guilded Rose
|
||||
Guio and Lenise's implementation for [guilded rose refactoring](https://github.com/emilybache/GildedRose-Refactoring-Kata#gilded-rose-refactoring-kata)
|
||||
|
||||
### Testing
|
||||
|
||||
`make test`
|
||||
|
||||
#### Linter - Rubocop
|
||||
|
||||
`make lint`
|
||||
|
||||
automatic fix detected offenses
|
||||
`make auto-correct`
|
||||
22
ruby/docker-compose.yml
Normal file
22
ruby/docker-compose.yml
Normal file
@ -0,0 +1,22 @@
|
||||
version: '2'
|
||||
services:
|
||||
base:
|
||||
build:
|
||||
context: .
|
||||
volumes:
|
||||
- .:/app
|
||||
|
||||
lint:
|
||||
extends:
|
||||
service: base
|
||||
command: rubocop
|
||||
|
||||
auto-correct:
|
||||
extends:
|
||||
service: base
|
||||
command: bundle exec rubocop --auto-correct
|
||||
|
||||
test:
|
||||
extends:
|
||||
service: base
|
||||
command: bundle exec rspec gilded_rose_spec.rb
|
||||
@ -1,45 +1,37 @@
|
||||
class GildedRose
|
||||
# frozen_string_literal: true
|
||||
|
||||
class GildedRose
|
||||
def initialize(items)
|
||||
@items = items
|
||||
end
|
||||
|
||||
def update_quality()
|
||||
def update_quality
|
||||
@items.each do |item|
|
||||
case item.name
|
||||
when "Sulfuras, Hand of Ragnaros"
|
||||
when "Backstage passes to a TAFKAL80ETC concert"
|
||||
if item.name.include?('Backstage passes')
|
||||
item.quality += 1 if item.sell_in > 10
|
||||
item.quality += 2 if item.sell_in <= 10 and item.sell_in > 5
|
||||
item.quality += 2 if (item.sell_in <= 10) && (item.sell_in > 5)
|
||||
item.quality += 3 if item.sell_in <= 5
|
||||
item.sell_in -= 1
|
||||
item.quality = 0 if item.sell_in < 0
|
||||
when "Aged Brie"
|
||||
item.sell_in -= 1
|
||||
if item.quality < 50
|
||||
if item.sell_in < 0
|
||||
item.quality += 2
|
||||
else
|
||||
item.quality += 1
|
||||
end
|
||||
end
|
||||
when /Conjured/
|
||||
item.sell_in -= 1
|
||||
if item.quality > 0
|
||||
item.quality -= 2
|
||||
item.quality -= 2 if item.sell_in < 0
|
||||
end
|
||||
else
|
||||
item.sell_in -= 1
|
||||
if item.quality > 0
|
||||
item.quality -= 1
|
||||
item.quality -= 1 if item.sell_in < 0
|
||||
item.quality = 0 if item.sell_in.negative?
|
||||
elsif !item.name.include?('Sulfuras')
|
||||
factor = 0
|
||||
factor = case item.name
|
||||
when 'Aged Brie'
|
||||
1
|
||||
when /Conjured/
|
||||
-2
|
||||
else
|
||||
-1
|
||||
end
|
||||
if (item.quality >= 0) && (item.quality <= 50)
|
||||
item.sell_in -= 1
|
||||
item.quality += factor
|
||||
item.quality += factor if item.sell_in.negative?
|
||||
end
|
||||
item.quality = 50 if item.quality > 50
|
||||
item.quality = 0 if item.quality.negative?
|
||||
end
|
||||
if item.quality < 0
|
||||
item.quality = 0
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
@ -52,7 +44,7 @@ class Item
|
||||
@quality = quality
|
||||
end
|
||||
|
||||
def to_s()
|
||||
def to_s
|
||||
"#{@name}, #{@sell_in}, #{@quality}"
|
||||
end
|
||||
end
|
||||
|
||||
@ -1,87 +1,87 @@
|
||||
require File.join(File.dirname(__FILE__), 'gilded_rose')
|
||||
# frozen_string_literal: true
|
||||
|
||||
require_relative File.join(File.dirname(__FILE__), 'gilded_rose')
|
||||
|
||||
describe GildedRose do
|
||||
|
||||
describe "#update_quality" do
|
||||
it "does not change the name" do
|
||||
items = [Item.new("foo", 0, 0)]
|
||||
GildedRose.new(items).update_quality()
|
||||
expect(items[0].name).to eq "foo"
|
||||
describe '#update_quality' do
|
||||
it 'does not change the name' do
|
||||
items = [Item.new('foo', 0, 0)]
|
||||
GildedRose.new(items).update_quality
|
||||
expect(items[0].name).to eq 'foo'
|
||||
end
|
||||
|
||||
it "degrades quality at double speed when sell by date has passed" do
|
||||
items = [Item.new("foo", 0, 10)]
|
||||
GildedRose.new(items).update_quality()
|
||||
it 'degrades quality at double speed when sell by date has passed' do
|
||||
items = [Item.new('foo', 0, 10)]
|
||||
GildedRose.new(items).update_quality
|
||||
expect(items[0].quality).to eq 8
|
||||
end
|
||||
|
||||
it "degrades quality at normal speed when sell by date hasn't passed" do
|
||||
items = [Item.new("foo", 1, 10)]
|
||||
GildedRose.new(items).update_quality()
|
||||
items = [Item.new('foo', 1, 10)]
|
||||
GildedRose.new(items).update_quality
|
||||
expect(items[0].quality).to eq 9
|
||||
end
|
||||
|
||||
it "does not decrease quality when it's zero" do
|
||||
items = [Item.new("foo", 1, 0)]
|
||||
GildedRose.new(items).update_quality()
|
||||
items = [Item.new('foo', 1, 0)]
|
||||
GildedRose.new(items).update_quality
|
||||
expect(items[0].quality).to eq 0
|
||||
end
|
||||
|
||||
it "increase quality by 1 when item is Aged Brie and sell by date hasn't passed" do
|
||||
items = [Item.new("Aged Brie", 1, 0)]
|
||||
GildedRose.new(items).update_quality()
|
||||
items = [Item.new('Aged Brie', 1, 0)]
|
||||
GildedRose.new(items).update_quality
|
||||
expect(items[0].quality).to eq 1
|
||||
end
|
||||
|
||||
it "increase quality by 2 when item is Aged Brie and sell by date has passed" do
|
||||
items = [Item.new("Aged Brie", 0, 0)]
|
||||
GildedRose.new(items).update_quality()
|
||||
it 'increase quality by 2 when item is Aged Brie and sell by date has passed' do
|
||||
items = [Item.new('Aged Brie', 0, 0)]
|
||||
GildedRose.new(items).update_quality
|
||||
expect(items[0].quality).to eq 2
|
||||
end
|
||||
|
||||
it "does not increase quality when it's already 50" do
|
||||
items = [Item.new("Aged Brie", 0, 50)]
|
||||
GildedRose.new(items).update_quality()
|
||||
items = [Item.new('Aged Brie', 0, 50)]
|
||||
GildedRose.new(items).update_quality
|
||||
expect(items[0].quality).to eq 50
|
||||
end
|
||||
|
||||
it "does not change quality and sell by date when it's a legendary item (Sulfuras)" do
|
||||
items = [Item.new("Sulfuras, Hand of Ragnaros", 0, 80)]
|
||||
GildedRose.new(items).update_quality()
|
||||
items = [Item.new('Sulfuras, Hand of Ragnaros', 0, 80)]
|
||||
GildedRose.new(items).update_quality
|
||||
expect(items[0].quality).to eq 80
|
||||
expect(items[0].sell_in).to eq 0
|
||||
end
|
||||
|
||||
it "increase quality by 1 when item is Backstage Passes and sell by date is bigger than 10" do
|
||||
items = [Item.new("Backstage passes to a TAFKAL80ETC concert", 11, 1)]
|
||||
GildedRose.new(items).update_quality()
|
||||
it 'increase quality by 1 when item is Backstage Passes and sell by date is bigger than 10' do
|
||||
items = [Item.new('Backstage passes to a TAFKAL80ETC concert', 11, 1)]
|
||||
GildedRose.new(items).update_quality
|
||||
expect(items[0].quality).to eq 2
|
||||
end
|
||||
|
||||
it "increase quality by 2 when item is Backstage Passes and sell by date is less or equal 10" do
|
||||
items = [Item.new("Backstage passes to a TAFKAL80ETC concert", 10, 1)]
|
||||
GildedRose.new(items).update_quality()
|
||||
|
||||
it 'increase quality by 2 when item is Backstage Passes and sell by date is less or equal 10' do
|
||||
items = [Item.new('Backstage passes to a TAFKAL80ETC concert', 10, 1)]
|
||||
GildedRose.new(items).update_quality
|
||||
expect(items[0].quality).to eq 3
|
||||
end
|
||||
|
||||
it "increase quality by 3 when item is Backstage Passes and sell by date is less or equal 5" do
|
||||
items = [Item.new("Backstage passes to a TAFKAL80ETC concert", 5, 1)]
|
||||
GildedRose.new(items).update_quality()
|
||||
it 'increase quality by 3 when item is Backstage Passes and sell by date is less or equal 5' do
|
||||
items = [Item.new('Backstage passes to a TAFKAL80ETC concert', 5, 1)]
|
||||
GildedRose.new(items).update_quality
|
||||
expect(items[0].quality).to eq 4
|
||||
end
|
||||
|
||||
it "sets quality to 0 when item is Backstage Passes and sell by date has passed" do
|
||||
items = [Item.new("Backstage passes to a TAFKAL80ETC concert", 0, 50)]
|
||||
GildedRose.new(items).update_quality()
|
||||
it 'sets quality to 0 when item is Backstage Passes and sell by date has passed' do
|
||||
items = [Item.new('Backstage passes to a TAFKAL80ETC concert', 0, 50)]
|
||||
GildedRose.new(items).update_quality
|
||||
expect(items[0].quality).to eq 0
|
||||
end
|
||||
|
||||
it "degrades quality twice as fast for Conjured items" do
|
||||
items = [Item.new("Conjured sword", 10, 50), Item.new("Conjured axe", 0, 50)]
|
||||
GildedRose.new(items).update_quality()
|
||||
it 'degrades quality twice as fast for Conjured items' do
|
||||
items = [Item.new('Conjured sword', 10, 50), Item.new('Conjured axe', 0, 50)]
|
||||
GildedRose.new(items).update_quality
|
||||
expect(items[0].quality).to eq 48
|
||||
expect(items[1].quality).to eq 46
|
||||
end
|
||||
end
|
||||
|
||||
end
|
||||
|
||||
Loading…
Reference in New Issue
Block a user