Updated some tests and addes Sulfuras item update service tests

This commit is contained in:
Daniel F 2023-07-11 21:42:05 +01:00
parent 44a4456e00
commit 807125a909
3 changed files with 82 additions and 8 deletions

View File

@ -14,7 +14,7 @@ func TestAgedBrieItemUpdateService_QualityBeforeSellIn(t *testing.T) {
) {
item := models.NewItem(&models.ItemModel{"Aged Brie", 5, 5})
agedBrieItemUpdateService.UpdateQuality(item)
assert.Equal(t, item.Model.Quality, 6)
assert.Equal(t, 6, item.Model.Quality)
})
}
@ -25,7 +25,7 @@ func TestAgedBrieItemUpdateService_QualityAfterSellIn0Days(t *testing.T) {
) {
item := models.NewItem(&models.ItemModel{"Aged Brie", 0, 5})
agedBrieItemUpdateService.UpdateQuality(item)
assert.Equal(t, item.Model.Quality, 7)
assert.Equal(t, 7, item.Model.Quality)
})
}
@ -36,7 +36,7 @@ func TestAgedBrieItemUpdateService_QualityAfterSellIn4Days(t *testing.T) {
) {
item := models.NewItem(&models.ItemModel{"Aged Brie", -4, 5})
agedBrieItemUpdateService.UpdateQuality(item)
assert.Equal(t, item.Model.Quality, 7)
assert.Equal(t, 7, item.Model.Quality)
})
}
@ -47,6 +47,17 @@ func TestAgedBrieItemUpdateService_QualityNotHigherThan50(t *testing.T) {
) {
item := models.NewItem(&models.ItemModel{"Aged Brie", -4, 50})
agedBrieItemUpdateService.UpdateQuality(item)
assert.Equal(t, item.Model.Quality, 50)
assert.Equal(t, 50, item.Model.Quality)
})
}
// sellIn date must decrease
func TestAgedBrieItemUpdateService_SellInIsDecreased(t *testing.T) {
runTestCase(t, func(
sulfurasItemUpdateService SulfurasItemUpdateService,
) {
item := models.NewItem(&models.ItemModel{"Aged Brie", 5, 5})
sulfurasItemUpdateService.UpdateQuality(item)
assert.Equal(t, 4, item.Model.SellIn)
})
}

View File

@ -14,7 +14,7 @@ func TestNormalItemUpdateService_QualityBeforeSellIn(t *testing.T) {
) {
item := models.NewItem(&models.ItemModel{"Random normal item", 5, 5})
normalItemUpdateService.UpdateQuality(item)
assert.Equal(t, item.Model.Quality, 4)
assert.Equal(t, 4, item.Model.Quality)
})
}
@ -25,7 +25,7 @@ func TestNormalItemUpdateService_QualityAfterSellIn0Days(t *testing.T) {
) {
item := models.NewItem(&models.ItemModel{"Random normal item", 0, 5})
normalItemUpdateService.UpdateQuality(item)
assert.Equal(t, item.Model.Quality, 3)
assert.Equal(t, 3, item.Model.Quality)
})
}
@ -36,7 +36,7 @@ func TestNormalItemUpdateService_QualityAfterSellIn4Days(t *testing.T) {
) {
item := models.NewItem(&models.ItemModel{"Random normal item", -4, 5})
normalItemUpdateService.UpdateQuality(item)
assert.Equal(t, item.Model.Quality, 3)
assert.Equal(t, 3, item.Model.Quality)
})
}
@ -47,6 +47,6 @@ func TestNormalItemUpdateService_QualityNotLowerThan0(t *testing.T) {
) {
item := models.NewItem(&models.ItemModel{"Random normal item", -4, 0})
normalItemUpdateService.UpdateQuality(item)
assert.Equal(t, item.Model.Quality, 0)
assert.Equal(t, 0, item.Model.Quality)
})
}

View File

@ -0,0 +1,63 @@
package services
import (
"testing"
"github.com/stretchr/testify/assert"
"github.com/emilybache/gildedrose-refactoring-kata/models"
)
// Sulfuras item quality is 80 before sellIn
func TestSulfurasItemUpdateService_QualityBeforeSellIn(t *testing.T) {
runTestCase(t, func(
sulfurasItemUpdateService SulfurasItemUpdateService,
) {
item := models.NewItem(&models.ItemModel{"Sulfuras, Hand of Ragnaros", 5, 5})
sulfurasItemUpdateService.UpdateQuality(item)
assert.Equal(t, 80, item.Model.Quality)
})
}
// Sulfuras item sellIn is immutable
func TestSulfurasItemUpdateService_SellInIsImmutable(t *testing.T) {
runTestCase(t, func(
sulfurasItemUpdateService SulfurasItemUpdateService,
) {
item := models.NewItem(&models.ItemModel{"Sulfuras, Hand of Ragnaros", 5, 5})
sulfurasItemUpdateService.UpdateQuality(item)
assert.Equal(t, 5, item.Model.SellIn)
})
}
// If the sellIn date has been passed, the Sulfuras item quality is still 80
func TestSulfurasItemUpdateService_QualityAfterSellIn0Days(t *testing.T) {
runTestCase(t, func(
sulfurasItemUpdateService SulfurasItemUpdateService,
) {
item := models.NewItem(&models.ItemModel{"Sulfuras, Hand of Ragnaros", 0, 5})
sulfurasItemUpdateService.UpdateQuality(item)
assert.Equal(t, 80, item.Model.Quality)
})
}
// If the sellIn date has been passed, the Sulfuras item quality is still 80
func TestSulfurasItemUpdateService_QualityAfterSellIn4Days(t *testing.T) {
runTestCase(t, func(
sulfurasItemUpdateService SulfurasItemUpdateService,
) {
item := models.NewItem(&models.ItemModel{"Sulfuras, Hand of Ragnaros", -4, 5})
sulfurasItemUpdateService.UpdateQuality(item)
assert.Equal(t, 80, item.Model.Quality)
})
}
// Sulfuras item negative sellIn is immutable
func TestSulfurasItemUpdateService_NegativeSellInIsImmutable(t *testing.T) {
runTestCase(t, func(
sulfurasItemUpdateService SulfurasItemUpdateService,
) {
item := models.NewItem(&models.ItemModel{"Sulfuras, Hand of Ragnaros", -4, 5})
sulfurasItemUpdateService.UpdateQuality(item)
assert.Equal(t, -4, item.Model.SellIn)
})
}