restructuring user test a bit

This commit is contained in:
Tyler Renelle 2012-09-24 11:36:44 -04:00
parent 90f30ac1f0
commit 163395829a

View file

@ -15,7 +15,7 @@ describe 'User', ->
model.set '_user', schema.newUserObject()
scoring.setModel model
it 'should set user defaults correctly', ->
it 'sets correct user defaults', ->
user = model.get '_user'
expect(user.stats).to.eql { money: 0, exp: 0, lvl: 1, hp: 50 }
expect(user.items).to.eql { itemsEnabled: false, armor: 0, weapon: 0, rerollsRemaining: 5 }
@ -28,72 +28,82 @@ describe 'User', ->
expect(_.size(user.rewardIds)).to.eql 2
##### Habits #####
describe 'Habits', ->
describe 'Tasks', ->
uuid = null
taskPath = null
beforeEach ->
# create a test task
user = model.get('_user')
uuid = derby.uuid()
taskPath = "_user.tasks.#{uuid}"
model.refList "_habitList", "_user.tasks", "_user.habitIds"
model.at('_habitList').push {type: 'habit', text: 'Habit', value: 0, up: true, down: true, id: uuid}
describe 'Habits', ->
it 'should have created the habit', ->
task = model.get(taskPath)
expect(task.text).to.eql 'Habit'
expect(task.value).to.eql 0
beforeEach ->
# create a test task
user = model.get('_user')
uuid = derby.uuid()
taskPath = "_user.tasks.#{uuid}"
model.refList "_habitList", "_user.tasks", "_user.habitIds"
model.at('_habitList').push {type: 'habit', text: 'Habit', value: 0, up: true, down: true, id: uuid}
it 'should make proper modifications when down-scored', ->
# Down-score the habit
[userBefore, taskBefore] = [model.get('_user'), model.get(taskPath)]
scoring.score({taskId:uuid, direction:'down'})
[userAfter, taskAfter] = [model.get('_user'), model.get(taskPath)]
it 'created the habit', ->
task = model.get(taskPath)
expect(task.text).to.eql 'Habit'
expect(task.value).to.eql 0
it 'made proper modifications when down-scored', ->
# Down-score the habit
[userBefore, taskBefore] = [model.get('_user'), model.get(taskPath)]
scoring.score({taskId:uuid, direction:'down'})
[userAfter, taskAfter] = [model.get('_user'), model.get(taskPath)]
# User should have lost HP
expect(userAfter.stats.hp).to.be.lessThan userBefore.stats.hp
# Exp, GP should stay the same
expect(userAfter.stats.money).to.eql userBefore.stats.money
expect(userAfter.stats.exp).to.eql userBefore.stats.exp
# Task should have gained in value
expect(taskAfter.value).to.be.greaterThan taskBefore.value
it 'made proper modifications when up-scored', ->
# Up-score the habit
[userBefore, taskBefore] = [model.get('_user'), model.get(taskPath)]
scoring.score(uuid, 'up')
[userAfter, taskAfter] = [model.get('_user'), model.get(taskPath)]
# User should have gained Exp, GP
expect(userAfter.stats.exp).to.be.greaterThan userBefore.stats.exp
expect(userAfter.stats.money).to.be.greaterThan userBefore.stats.money
# HP should not change
expect(userAfter.stats.hp).to.eql userBefore.stats.hp
# Task should have lost value
expect(taskAfter.value).to.be.lessThan taskBefore.value
it 'should not modify certain attributes given certain conditions'
# non up+down habits
# what else?
it 'should show "undo" notification if user unchecks completed daily'
# User should have lost HP
expect(userAfter.stats.hp).to.be.lessThan userBefore.stats.hp
# Exp, GP should stay the same
expect(userAfter.stats.money).to.eql userBefore.stats.money
expect(userAfter.stats.exp).to.eql userBefore.stats.exp
# Task should have gained in value
expect(taskAfter.value).to.be.greaterThan taskBefore.value
it 'should make proper modifications when up-scored', ->
# Up-score the habit
[userBefore, taskBefore] = [model.get('_user'), model.get(taskPath)]
scoring.score(uuid, 'up')
[userAfter, taskAfter] = [model.get('_user'), model.get(taskPath)]
# User should have gained Exp, GP
expect(userAfter.stats.exp).to.be.greaterThan userBefore.stats.exp
expect(userAfter.stats.money).to.be.greaterThan userBefore.stats.money
# HP should not change
expect(userAfter.stats.hp).to.eql userBefore.stats.hp
# Task should have lost value
expect(taskAfter.value).to.be.lessThan taskBefore.value
it 'should not modify certain attributes given certain conditions'
# non up+down habits
# what else?
describe 'Dailies', ->
#TODO clicking repeat dates on newly-created item doesn't refresh until you refresh the page
#TODO dates on dailies is having issues, possibility: date cusps? my saturday exempts were set to exempt at 8pm friday
#TODO refactor as user->habits, user->dailys, user->todos, user->rewards
describe 'Lvl & Items', ->
it 'modified damage based on lvl & armor'
it 'always decreases hp with damage, regardless of stats/items'
it 'always increases exp/gp with gain, regardless of stats/items'
describe 'Cron', ->
it 'should calculate cron based on difference between start-of-days, and not run in the middle of the day'
it 'should only run set operations once per task, even when daysPassed > 1'
# pass in daysPassed to score, multiply modification values by daysPassed before running set
it 'should only push a history point for lastCron, not each day in between'
# stop passing in tallyFor, let moment().sod().toDate() be handled in scoring.score()
it 'should modify damage based on lvl & armor'
it 'should always decrease hp with damage, regardless of stats/items'
it 'should always increase exp/gp with gain, regardless of stats/items'
it 'should calculate cron based on difference between start-of-days, and not run in the middle of the day'
it 'should show "undo" notification if user unchecks completed daily'
#TODO clicking repeat dates on newly-created item doesn't refresh until you refresh the page
#TODO pass in commit parameter to scoring func, if true save right away, otherwise return aggregated array so can save in the end (so total hp loss, etc)
#TODO refactor as user->habits, user->dailys, user->todos, user->rewards
#TODO dates on dailies is having issues, possibility: date cusps? my saturday exempts were set to exempt at 8pm friday
it 'should defer saving user modifications until, save as aggregate values'
# pass in commit parameter to scoring func, if true save right away, otherwise return aggregated array so can save in the end (so total hp loss, etc)
#### Require.js stuff, might be necessary to place in casper.coffee
it "doesn't setup dependent functions until their modules are loaded, require.js callback"