fix #1954 . Start updating API tests, beginning with challenges. Use

test to fix "challenge updates not updating users' tasks"
This commit is contained in:
Tyler Renelle
2014-01-03 00:00:27 -07:00
parent ae080fd474
commit 2c1eb955ac
4 changed files with 113 additions and 115 deletions

View File

@@ -5,7 +5,6 @@
"main": "./src/server.js", "main": "./src/server.js",
"dependencies": { "dependencies": {
"habitrpg-shared": "git://github.com/HabitRPG/habitrpg-shared#develop", "habitrpg-shared": "git://github.com/HabitRPG/habitrpg-shared#develop",
"derby-auth": "git://github.com/lefnire/derby-auth#master",
"connect-mongo": "*", "connect-mongo": "*",
"passport-facebook": "~1.0.0", "passport-facebook": "~1.0.0",
"express": "*", "express": "*",
@@ -16,9 +15,7 @@
"coffee-script": "*", "coffee-script": "*",
"nconf": "*", "nconf": "*",
"icalendar": "git://github.com/lefnire/node-icalendar#master", "icalendar": "git://github.com/lefnire/node-icalendar#master",
"superagent": "~0.12.4",
"resolve": "~0.2.3", "resolve": "~0.2.3",
"expect.js": "~0.2.0",
"lodash": "~2.2.1", "lodash": "~2.2.1",
"async": "~0.2.9", "async": "~0.2.9",
"optimist": "~0.5.2", "optimist": "~0.5.2",
@@ -80,6 +77,9 @@
"mocha": "~1.12.1", "mocha": "~1.12.1",
"karma-mocha": "~0.1.0", "karma-mocha": "~0.1.0",
"csv": "~0.3.6", "csv": "~0.3.6",
"mongoskin": "~0.6.1" "mongoskin": "~0.6.1",
"expect.js": "~0.2.0",
"superagent": "~0.15.7",
"superagent-defaults": "~0.1.5"
} }
} }

View File

@@ -128,6 +128,7 @@ api.create = function(req, res){
waterfall = waterfall.concat([ waterfall = waterfall.concat([
function(cb) { // if we're dealing with prize above, arguemnts will be `group, numRows, cb` - else `cb` function(cb) { // if we're dealing with prize above, arguemnts will be `group, numRows, cb` - else `cb`
req.body.leader = user._id;
var chal = new Challenge(req.body); // FIXME sanitize var chal = new Challenge(req.body); // FIXME sanitize
chal.members.push(user._id); chal.members.push(user._id);
chal.save(cb) chal.save(cb)

View File

@@ -58,13 +58,13 @@ function syncableAttrs(task) {
* Compare whether any changes have been made to tasks. If so, we'll want to sync those changes to subscribers * Compare whether any changes have been made to tasks. If so, we'll want to sync those changes to subscribers
*/ */
function comparableData(obj) { function comparableData(obj) {
return ( return JSON.stringify(
_.chain(obj.habits.concat(obj.dailys).concat(obj.todos).concat(obj.rewards)) _(obj.habits.concat(obj.dailys).concat(obj.todos).concat(obj.rewards))
.sortBy('id') // we don't want to update if they're sort-order is different .sortBy('id') // we don't want to update if they're sort-order is different
.transform(function(result, task){ .transform(function(result, task){
result.push(syncableAttrs(task)); result.push(syncableAttrs(task));
})) })
.toString(); // for comparing arrays easily .value())
} }
ChallengeSchema.methods.isOutdated = function(newData) { ChallengeSchema.methods.isOutdated = function(newData) {

View File

@@ -1,12 +1,14 @@
_ = require 'lodash' _ = require 'lodash'
request = require 'superagent'
expect = require 'expect.js' expect = require 'expect.js'
require 'coffee-script' require 'coffee-script'
utils = require 'derby-auth/utils'
async = require 'async' async = require 'async'
superagentDefaults = require 'superagent-defaults'
request = superagentDefaults()
conf = require("nconf") conf = require("nconf")
conf.argv().env().file({file: __dirname + '../config.json'}).defaults conf.argv().env().file({file: __dirname + '../config.json'}).defaults
conf.set('port','1337')
# Override normal ENV values with nconf ENV values (ENV values are used the same way without nconf) # Override normal ENV values with nconf ENV values (ENV values are used the same way without nconf)
#FIXME can't get nconf file above to load... #FIXME can't get nconf file above to load...
@@ -15,31 +17,34 @@ process.env.FACEBOOK_KEY = conf.get("FACEBOOK_KEY")
process.env.FACEBOOK_SECRET = conf.get("FACEBOOK_SECRET") process.env.FACEBOOK_SECRET = conf.get("FACEBOOK_SECRET")
process.env.NODE_DB_URI = 'mongodb://localhost/habitrpg' process.env.NODE_DB_URI = 'mongodb://localhost/habitrpg'
User = require('../src/models/user').model
Group = require('../src/models/group').model
Challenge = require('../src/models/challenge').model
app = require '../src/server'
## monkey-patch expect.js for better diffs on mocha ## monkey-patch expect.js for better diffs on mocha
## see: https://github.com/LearnBoost/expect.js/pull/34 ## see: https://github.com/LearnBoost/expect.js/pull/34
#origBe = expect.Assertion::be
origBe = expect.Assertion::be #expect.Assertion::be = expect.Assertion::equal = (obj) ->
expect.Assertion::be = expect.Assertion::equal = (obj) -> # @_expected = obj
@_expected = obj # origBe.call this, obj
origBe.call this, obj
# Custom modules # Custom modules
helpers = require 'habitrpg-shared/script/helpers' shared = require 'habitrpg-shared'
###### Helpers & Variables ###### ###### Helpers & Variables ######
model = null model = null
uuid = null uuid = null
taskPath = null taskPath = null
baseURL = 'http://localhost:1337/api/v1' baseURL = 'http://localhost:3000/api/v2'
### ###
expect().eql expects object keys to be in the correct order, this sorts that out expect().eql expects object keys to be in the correct order, this sorts that out
### ###
expectUserEqual = (u1, u2) -> expectUserEqual = (u1, u2) ->
[u1, u2] = _.map [u1, u2], (obj) -> [u1, u2] = _.map [u1, u2], (obj) ->
'update__ stats.toNextLevel stats.maxHealth __v'.split(' ').forEach (path) -> 'update__ stats.toNextLevel stats.maxHealth __v'.split(' ').forEach (path) ->
helpers.dotSet path, null, obj helpers.dotSet path, null, obj
@@ -54,30 +59,28 @@ expectSameValues = (obj1, obj2, paths) ->
_.each paths, (k) -> _.each paths, (k) ->
expect(helpers.dotGet(k,obj1)).to.eql helpers.dotGet(k,obj2) expect(helpers.dotGet(k,obj1)).to.eql helpers.dotGet(k,obj2)
expectCode = (res, code) ->
expect(res.body.err).to.be undefined
expect(res.statusCode).to.be code
###### Specs ###### ###### Specs ######
describe 'API', -> describe 'API', ->
server = null server = null
store = null
model = null
user = null user = null
uid = null _id = null
token = null apiToken = null
username = null username = null
password = null password = null
###
Function for registring new users, so we can futz with data
###
registerNewUser = (cb) -> registerNewUser = (cb) ->
randomID = model.id() randomID = shared.uuid()
password = randomID password = randomID
params = params =
username: randomID username: randomID
password: randomID password: randomID
confirmPassword: randomID confirmPassword: randomID
email: "#{randomID}@gmail.com" email: "#{randomID}@gmail.com"
request.post("#{baseURL}/register") request.post("#{baseURL}/register")
.set('Accept', 'application/json') .set('Accept', 'application/json')
.send(params) .send(params)
@@ -85,18 +88,12 @@ describe 'API', ->
cb(res.body) cb(res.body)
before (done) -> before (done) ->
server = require '../lib/server' server = require '../src/server'
server.listen '1337', '0.0.0.0', -> # nasty hack, make a cb-compatible export of server
store = server.habitStore setTimeout done, 2000
#store.flush()
model = store.createModel()
# nasty hack, why isn't server.listen callback fired when server is completely up?
setTimeout done, 2000
describe 'Without token or user id', -> describe 'Without token or user id', ->
it.skip '/api/v2/status', (done) ->
it '/api/v1/status', (done) ->
request.get("#{baseURL}/status") request.get("#{baseURL}/status")
.set('Accept', 'application/json') .set('Accept', 'application/json')
.end (res) -> .end (res) ->
@@ -104,7 +101,7 @@ describe 'API', ->
expect(res.body.status).to.be 'up' expect(res.body.status).to.be 'up'
done() done()
it '/api/v1/user', (done) -> it.skip '/api/v2/user', (done) ->
request.get("#{baseURL}/user") request.get("#{baseURL}/user")
.set('Accept', 'application/json') .set('Accept', 'application/json')
.end (res) -> .end (res) ->
@@ -112,32 +109,80 @@ describe 'API', ->
expect(res.body.err).to.be 'You must include a token and uid (user id) in your request' expect(res.body.err).to.be 'You must include a token and uid (user id) in your request'
done() done()
describe 'With token and user id', -> describe.only 'With token and user id', ->
params = null params = null
currentUser = null currentUser = null
before (done) -> before (done) ->
registerNewUser (_res) -> registerNewUser (_res) ->
# console.log _res #console.log _res
[uid, token, username] = [_res.id, _res.apiToken, _res.auth.local.username] [_id, apiToken, username] = [_res.id, _res.apiToken, _res.auth.local.username]
model.query('users').withIdAndToken(uid, token).fetch (err, _user) -> User.findOne {_id,apiToken}, (err, _user) ->
console.error {err} if err console.error {err} if err
user = _user user = _user
params = params =
title: 'Title' title: 'Title'
text: 'Text' text: 'Text'
type: 'habit' type: 'habit'
request
.set('Accept', 'application/json')
.set('X-API-User', _id)
.set('X-API-Key', apiToken)
done() done()
beforeEach -> beforeEach (done) ->
currentUser = user.get() User.findById _id, (err,_user) ->
currentUser = _user
done()
###### Groups ######
describe.only 'Groups', ->
group = undefined
it 'Creates a group', (done) ->
request.post("#{baseURL}/groups")
.send({name:"TestGroup", type:"party"})
.end (res) ->
expectCode res, 200
group = res.body
done()
describe 'Challenges', ->
challenge = undefined
it 'Creates a challenge', (done) ->
request.post("#{baseURL}/challenges")
.send({
group:group._id
dailys: [{type:'daily',text:'Challenge Daily'}]
todos: [], rewards: [], habits: []
})
.end (res) ->
expectCode res, 200
async.parallel [
(cb) -> User.findById _id, cb
(cb) -> Challenge.findById res.body._id, cb
], (err, results) ->
[_user,challenge] = [results[0],results[1]]
expect(_user.dailys[_user.dailys.length-1].text).to.be('Challenge Daily')
done()
it 'Change challenge daily', (done) ->
challenge.dailys[0].text = 'Updated Daily'
request.post("#{baseURL}/challenges/#{challenge._id}")
.send(challenge)
.end (res) ->
setTimeout ->
User.findById _id, (err,_user) ->
expectCode res, 200
expect(_user.dailys[_user.dailys.length-1].text).to.be('Updated Daily')
done()
, 500 # we have to wait a while for users' tasks to be updated, called async on server
#FIXME figure out how to compare the objects #FIXME figure out how to compare the objects
it.skip 'GET /api/v1/user', (done) -> it.skip 'GET /api/v1/user', (done) ->
request.get("#{baseURL}/user") request.get("#{baseURL}/user")
.set('Accept', 'application/json')
.set('X-API-User', currentUser.id)
.set('X-API-Key', currentUser.apiToken)
.end (res) -> .end (res) ->
expect(res.body.err).to.be undefined expect(res.body.err).to.be undefined
expect(res.statusCode).to.be 200 expect(res.statusCode).to.be 200
@@ -150,23 +195,17 @@ describe 'API', ->
expectUserEqual(res.body, self) expectUserEqual(res.body, self)
done() done()
it 'GET /api/v1/user/task/:id', (done) -> it.skip 'GET /api/v1/user/task/:id', (done) ->
tid = _.pluck(currentUser.tasks, 'id')[0] tid = _.pluck(currentUser.tasks, 'id')[0]
request.get("#{baseURL}/user/task/#{tid}") request.get("#{baseURL}/user/task/#{tid}")
.set('Accept', 'application/json')
.set('X-API-User', currentUser.id)
.set('X-API-Key', currentUser.apiToken)
.end (res) -> .end (res) ->
expect(res.body.err).to.be undefined expect(res.body.err).to.be undefined
expect(res.statusCode).to.be 200 expect(res.statusCode).to.be 200
expect(res.body).to.eql currentUser.tasks[tid] expect(res.body).to.eql currentUser.tasks[tid]
done() done()
it 'POST /api/v1/user/task', (done) -> it.skip 'POST /api/v1/user/task', (done) ->
request.post("#{baseURL}/user/task") request.post("#{baseURL}/user/task")
.set('Accept', 'application/json')
.set('X-API-User', currentUser.id)
.set('X-API-Key', currentUser.apiToken)
.send(params) .send(params)
.end (res) -> .end (res) ->
query = model.query('users').withIdAndToken(currentUser.id, currentUser.apiToken) query = model.query('users').withIdAndToken(currentUser.id, currentUser.apiToken)
@@ -181,20 +220,14 @@ describe 'API', ->
it.skip 'POST /api/v1/user/task (without type)', (done) -> it.skip 'POST /api/v1/user/task (without type)', (done) ->
request.post("#{baseURL}/user/task") request.post("#{baseURL}/user/task")
.set('Accept', 'application/json')
.set('X-API-User', currentUser.id)
.set('X-API-Key', currentUser.apiToken)
.send({}) .send({})
.end (res) -> .end (res) ->
expect(res.body.err).to.be 'type must be habit, todo, daily, or reward' expect(res.body.err).to.be 'type must be habit, todo, daily, or reward'
expect(res.statusCode).to.be 400 expect(res.statusCode).to.be 400
done() done()
it 'POST /api/v1/user/task (only type)', (done) -> it.skip 'POST /api/v1/user/task (only type)', (done) ->
request.post("#{baseURL}/user/task") request.post("#{baseURL}/user/task")
.set('Accept', 'application/json')
.set('X-API-User', currentUser.id)
.set('X-API-Key', currentUser.apiToken)
.send(type: 'habit') .send(type: 'habit')
.end (res) -> .end (res) ->
query = model.query('users').withIdAndToken(currentUser.id, currentUser.apiToken) query = model.query('users').withIdAndToken(currentUser.id, currentUser.apiToken)
@@ -208,12 +241,9 @@ describe 'API', ->
expect(user.get().tasks[res.body.id].value).to.be.equal(0) expect(user.get().tasks[res.body.id].value).to.be.equal(0)
done() done()
it 'PUT /api/v1/user/task/:id', (done) -> it.skip 'PUT /api/v1/user/task/:id', (done) ->
tid = _.pluck(currentUser.tasks, 'id')[0] tid = _.pluck(currentUser.tasks, 'id')[0]
request.put("#{baseURL}/user/task/#{tid}") request.put("#{baseURL}/user/task/#{tid}")
.set('Accept', 'application/json')
.set('X-API-User', currentUser.id)
.set('X-API-Key', currentUser.apiToken)
.send(text: 'bye') .send(text: 'bye')
.end (res) -> .end (res) ->
expect(res.body.err).to.be undefined expect(res.body.err).to.be undefined
@@ -227,9 +257,6 @@ describe 'API', ->
tid = _.pluck(currentUser.tasks, 'id')[1] tid = _.pluck(currentUser.tasks, 'id')[1]
type = if currentUser.tasks[tid].type is 'habit' then 'daily' else 'habit' type = if currentUser.tasks[tid].type is 'habit' then 'daily' else 'habit'
request.put("#{baseURL}/user/task/#{tid}") request.put("#{baseURL}/user/task/#{tid}")
.set('Accept', 'application/json')
.set('X-API-User', currentUser.id)
.set('X-API-Key', currentUser.apiToken)
.send(type: type, text: 'fishman') .send(type: type, text: 'fishman')
.end (res) -> .end (res) ->
expect(res.body.err).to.be undefined expect(res.body.err).to.be undefined
@@ -238,12 +265,9 @@ describe 'API', ->
expect(res.body).to.eql currentUser.tasks[tid] expect(res.body).to.eql currentUser.tasks[tid]
done() done()
it 'PUT /api/v1/user/task/:id (update notes)', (done) -> it.skip 'PUT /api/v1/user/task/:id (update notes)', (done) ->
tid = _.pluck(currentUser.tasks, 'id')[2] tid = _.pluck(currentUser.tasks, 'id')[2]
request.put("#{baseURL}/user/task/#{tid}") request.put("#{baseURL}/user/task/#{tid}")
.set('Accept', 'application/json')
.set('X-API-User', currentUser.id)
.set('X-API-Key', currentUser.apiToken)
.send(text: 'hi',notes:'foobar matey') .send(text: 'hi',notes:'foobar matey')
.end (res) -> .end (res) ->
expect(res.body.err).to.be undefined expect(res.body.err).to.be undefined
@@ -253,11 +277,8 @@ describe 'API', ->
expect(res.body).to.eql currentUser.tasks[tid] expect(res.body).to.eql currentUser.tasks[tid]
done() done()
it 'GET /api/v1/user/tasks', (done) -> it.skip 'GET /api/v1/user/tasks', (done) ->
request.get("#{baseURL}/user/tasks") request.get("#{baseURL}/user/tasks")
.set('Accept', 'application/json')
.set('X-API-User', currentUser.id)
.set('X-API-Key', currentUser.apiToken)
.end (res) -> .end (res) ->
query = model.query('users').withIdAndToken(currentUser.id, currentUser.apiToken) query = model.query('users').withIdAndToken(currentUser.id, currentUser.apiToken)
query.fetch (err, user) -> query.fetch (err, user) ->
@@ -275,11 +296,8 @@ describe 'API', ->
expect(_.difference(_.pluck(res.body,'id'), _.pluck(tasks,'id')).length).to.equal 0 expect(_.difference(_.pluck(res.body,'id'), _.pluck(tasks,'id')).length).to.equal 0
done() done()
it 'GET /api/v1/user/tasks (todos)', (done) -> it.skip 'GET /api/v1/user/tasks (todos)', (done) ->
request.get("#{baseURL}/user/tasks") request.get("#{baseURL}/user/tasks")
.set('Accept', 'application/json')
.set('X-API-User', currentUser.id)
.set('X-API-Key', currentUser.apiToken)
.query(type:'todo') .query(type:'todo')
.end (res) -> .end (res) ->
query = model.query('users').withIdAndToken(currentUser.id, currentUser.apiToken) query = model.query('users').withIdAndToken(currentUser.id, currentUser.apiToken)
@@ -295,12 +313,9 @@ describe 'API', ->
expect(_.difference(_.pluck(res.body,'id'), _.pluck(tasks,'id')).length).to.equal 0 expect(_.difference(_.pluck(res.body,'id'), _.pluck(tasks,'id')).length).to.equal 0
done() done()
it 'DELETE /api/v1/user/task/:id', (done) -> it.skip 'DELETE /api/v1/user/task/:id', (done) ->
tid = currentUser.habitIds[2] tid = currentUser.habitIds[2]
request.del("#{baseURL}/user/task/#{tid}") request.del("#{baseURL}/user/task/#{tid}")
.set('Accept', 'application/json')
.set('X-API-User', currentUser.id)
.set('X-API-Key', currentUser.apiToken)
.end (res) -> .end (res) ->
expect(res.body.err).to.be undefined expect(res.body.err).to.be undefined
expect(res.statusCode).to.be 204 expect(res.statusCode).to.be 204
@@ -310,23 +325,17 @@ describe 'API', ->
expect(user.get("tasks.#{tid}")).to.be undefined expect(user.get("tasks.#{tid}")).to.be undefined
done() done()
it 'DELETE /api/v1/user/task/:id (no task found)', (done) -> it.skip 'DELETE /api/v1/user/task/:id (no task found)', (done) ->
tid = "adsfasdfjunkshouldntbeatask" tid = "adsfasdfjunkshouldntbeatask"
request.del("#{baseURL}/user/task/#{tid}") request.del("#{baseURL}/user/task/#{tid}")
.set('Accept', 'application/json')
.set('X-API-User', currentUser.id)
.set('X-API-Key', currentUser.apiToken)
.end (res) -> .end (res) ->
expect(res.statusCode).to.be 400 expect(res.statusCode).to.be 400
expect(res.body.err).to.be 'No task found.' expect(res.body.err).to.be 'No task found.'
done() done()
it 'POST /api/v1/user/task/:id/up (habit)', (done) -> it.skip 'POST /api/v1/user/task/:id/up (habit)', (done) ->
tid = currentUser.habitIds[0] tid = currentUser.habitIds[0]
request.post("#{baseURL}/user/task/#{tid}/up") request.post("#{baseURL}/user/task/#{tid}/up")
.set('Accept', 'application/json')
.set('X-API-User', currentUser.id)
.set('X-API-Key', currentUser.apiToken)
.send({}) .send({})
.end (res) -> .end (res) ->
expect(res.body.err).to.be undefined expect(res.body.err).to.be undefined
@@ -334,12 +343,9 @@ describe 'API', ->
expect(res.body).to.eql { gp: 1, exp: 7.5, lvl: 1, hp: 50, delta: 1 } expect(res.body).to.eql { gp: 1, exp: 7.5, lvl: 1, hp: 50, delta: 1 }
done() done()
it 'POST /api/v1/user/task/:id/up (daily)', (done) -> it.skip 'POST /api/v1/user/task/:id/up (daily)', (done) ->
tid = currentUser.dailyIds[0] tid = currentUser.dailyIds[0]
request.post("#{baseURL}/user/task/#{tid}/up") request.post("#{baseURL}/user/task/#{tid}/up")
.set('Accept', 'application/json')
.set('X-API-User', currentUser.id)
.set('X-API-Key', currentUser.apiToken)
.send({}) .send({})
.end (res) -> .end (res) ->
expect(res.body.err).to.be undefined expect(res.body.err).to.be undefined
@@ -350,7 +356,7 @@ describe 'API', ->
expect(user.get("tasks.#{tid}.completed")).to.be true expect(user.get("tasks.#{tid}.completed")).to.be true
done() done()
it 'POST /api/v1/user/task (array)', (done) -> it.skip 'POST /api/v1/user/task (array)', (done) ->
habitId = currentUser.habitIds[0] habitId = currentUser.habitIds[0]
dailyId = currentUser.dailyIds[0] dailyId = currentUser.dailyIds[0]
arr = [{ arr = [{
@@ -366,9 +372,6 @@ describe 'API', ->
}] }]
request.post("#{baseURL}/user/tasks") request.post("#{baseURL}/user/tasks")
.set('Accept', 'application/json')
.set('X-API-User', currentUser.id)
.set('X-API-Key', currentUser.apiToken)
.send(arr) .send(arr)
.end (res) -> .end (res) ->
expect(res.body.err).to.be undefined expect(res.body.err).to.be undefined
@@ -387,7 +390,7 @@ describe 'API', ->
expectSameValues user.get("tasks.#{res.body[1].id}"), {id: res.body[1].id, text: 'new task', notes: 'notes!'}, ['id','text','notes'] expectSameValues user.get("tasks.#{res.body[1].id}"), {id: res.body[1].id, text: 'new task', notes: 'notes!'}, ['id','text','notes']
done() done()
it 'PUT /api/v1/user (bad path)', (done) -> it.skip 'PUT /api/v1/user (bad path)', (done) ->
# These updates should not save, as per the API changes # These updates should not save, as per the API changes
userUpdates = userUpdates =
stats: hp: 30 stats: hp: 30
@@ -398,16 +401,13 @@ describe 'API', ->
}] }]
request.put("#{baseURL}/user") request.put("#{baseURL}/user")
.set('Accept', 'application/json')
.set('X-API-User', currentUser.id)
.set('X-API-Key', currentUser.apiToken)
.send(userUpdates) .send(userUpdates)
.end (res) -> .end (res) ->
expect(res.body.err).to.be.ok() expect(res.body.err).to.be.ok()
expect(res.statusCode).to.be 500 expect(res.statusCode).to.be 500
done() done()
it 'PUT /api/v1/user', (done) -> it.skip 'PUT /api/v1/user', (done) ->
userBefore = {} userBefore = {}
query = model.query('users').withIdAndToken(currentUser.id, currentUser.apiToken) query = model.query('users').withIdAndToken(currentUser.id, currentUser.apiToken)
query.fetch (err, user) -> query.fetch (err, user) ->
@@ -422,9 +422,6 @@ describe 'API', ->
updates["tasks.#{habitId}.notes"] = 'note2' updates["tasks.#{habitId}.notes"] = 'note2'
request.put("#{baseURL}/user") request.put("#{baseURL}/user")
.set('Accept', 'application/json')
.set('X-API-User', currentUser.id)
.set('X-API-Key', currentUser.apiToken)
.send(updates) .send(updates)
.end (res) -> .end (res) ->
expect(res.body.err).to.be undefined expect(res.body.err).to.be undefined
@@ -438,7 +435,7 @@ describe 'API', ->
changesWereMade user.get() changesWereMade user.get()
done() done()
it 'POST /api/v1/user/auth/local', (done) -> it.skip 'POST /api/v1/user/auth/local', (done) ->
userAuth = {username, password} userAuth = {username, password}
request.post("#{baseURL}/user/auth/local") request.post("#{baseURL}/user/auth/local")
.set('Accept', 'application/json') .set('Accept', 'application/json')
@@ -450,8 +447,8 @@ describe 'API', ->
expect(res.body.token).to.be currentUser.apiToken expect(res.body.token).to.be currentUser.apiToken
done() done()
it 'POST /api/v1/user/auth/facebook', (done) -> it.skip 'POST /api/v1/user/auth/facebook', (done) ->
id = model.id() id = shared.uuid()
userAuth = facebook_id: 12345, name: 'Tyler Renelle', email: 'x@y.com' userAuth = facebook_id: 12345, name: 'Tyler Renelle', email: 'x@y.com'
newUser = helpers.newUser(true) newUser = helpers.newUser(true)
newUser.id = id newUser.id = id
@@ -471,7 +468,7 @@ describe 'API', ->
#expect(res.body.token).to.be newUser.apiToken #expect(res.body.token).to.be newUser.apiToken
done() done()
it 'POST /api/v1/batch-update (handles corrupt values)', (done) -> it.skip 'POST /api/v1/batch-update (handles corrupt values)', (done) ->
registerNewUser (_res) -> registerNewUser (_res) ->
model.set '_userId', _res.id model.set '_userId', _res.id
model.session = {userId:_res.id} model.session = {userId:_res.id}
@@ -502,7 +499,7 @@ describe 'API', ->
console.log {stats:res.body.stats, tasks:res.body.tasks} console.log {stats:res.body.stats, tasks:res.body.tasks}
done() done()
it 'POST /api/v1/batch-update', (done) -> it.skip 'POST /api/v1/batch-update', (done) ->
userBefore = _.cloneDeep(currentUser) userBefore = _.cloneDeep(currentUser)
habits = _.where currentUser.tasks, {type: 'habit'} habits = _.where currentUser.tasks, {type: 'habit'}