mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-18 23:27:26 +01:00
fix #1954 . Start updating API tests, beginning with challenges. Use
test to fix "challenge updates not updating users' tasks"
This commit is contained in:
@@ -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"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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)
|
||||||
|
|||||||
@@ -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) {
|
||||||
|
|||||||
@@ -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'}
|
||||||
|
|||||||
Reference in New Issue
Block a user