mirror of
https://github.com/codeninjasllc/codecombat.git
synced 2025-01-07 05:02:23 -05:00
Merge branch 'master' into production
This commit is contained in:
commit
9bb2c4bdc1
3 changed files with 18 additions and 3 deletions
|
@ -98,9 +98,10 @@ module.exports.setup = (app) ->
|
||||||
app.get('/db/course_instance/:handle/course', mw.auth.checkLoggedIn(), mw.courseInstances.fetchCourse)
|
app.get('/db/course_instance/:handle/course', mw.auth.checkLoggedIn(), mw.courseInstances.fetchCourse)
|
||||||
|
|
||||||
EarnedAchievement = require '../models/EarnedAchievement'
|
EarnedAchievement = require '../models/EarnedAchievement'
|
||||||
app.post('/db/earned_achievement', mw.auth.checkLoggedIn(), mw.earnedAchievements.post)
|
app.post('/db/earned_achievement', mw.auth.checkHasUser(), mw.earnedAchievements.post)
|
||||||
|
|
||||||
Level = require '../models/Level'
|
Level = require '../models/Level'
|
||||||
|
app.post('/db/level/names', mw.named.names(Level))
|
||||||
app.post('/db/level/:handle', mw.auth.checkLoggedIn(), mw.versions.postNewVersion(Level, { hasPermissionsOrTranslations: 'artisan' })) # TODO: add /new-version to route like Article has
|
app.post('/db/level/:handle', mw.auth.checkLoggedIn(), mw.versions.postNewVersion(Level, { hasPermissionsOrTranslations: 'artisan' })) # TODO: add /new-version to route like Article has
|
||||||
app.get('/db/level/:handle/session', mw.auth.checkHasUser(), mw.levels.upsertSession)
|
app.get('/db/level/:handle/session', mw.auth.checkHasUser(), mw.levels.upsertSession)
|
||||||
|
|
||||||
|
|
|
@ -172,9 +172,10 @@ describe 'POST /db/earned_achievement', ->
|
||||||
eaURL = getURL('/db/earned_achievement')
|
eaURL = getURL('/db/earned_achievement')
|
||||||
|
|
||||||
it 'manually creates earned achievements for level achievements, which do not happen automatically', utils.wrap (done) ->
|
it 'manually creates earned achievements for level achievements, which do not happen automatically', utils.wrap (done) ->
|
||||||
|
user = yield utils.becomeAnonymous()
|
||||||
session = new LevelSession({
|
session = new LevelSession({
|
||||||
permissions: simplePermissions
|
permissions: simplePermissions
|
||||||
creator: @admin._id
|
creator: user._id
|
||||||
level: original: 'dungeon-arena'
|
level: original: 'dungeon-arena'
|
||||||
})
|
})
|
||||||
yield session.save()
|
yield session.save()
|
||||||
|
@ -184,7 +185,7 @@ describe 'POST /db/earned_achievement', ->
|
||||||
[res, body] = yield request.postAsync { url: eaURL, json }
|
[res, body] = yield request.postAsync { url: eaURL, json }
|
||||||
expect(res.statusCode).toBe(201)
|
expect(res.statusCode).toBe(201)
|
||||||
expect(body.achievement).toBe @unlockable.id
|
expect(body.achievement).toBe @unlockable.id
|
||||||
expect(body.user).toBe @admin.id
|
expect(body.user).toBe user.id
|
||||||
expect(body.notified).toBeFalsy()
|
expect(body.notified).toBeFalsy()
|
||||||
expect(body.earnedPoints).toBe unlockable.worth
|
expect(body.earnedPoints).toBe unlockable.worth
|
||||||
expect(body.achievedAmount).toBeUndefined()
|
expect(body.achievedAmount).toBeUndefined()
|
||||||
|
|
|
@ -230,3 +230,16 @@ describe 'GET /db/level/:handle/session', ->
|
||||||
[res, body] = yield request.getAsync { uri: @url, json: true }
|
[res, body] = yield request.getAsync { uri: @url, json: true }
|
||||||
expect(res.statusCode).toBe(200)
|
expect(res.statusCode).toBe(200)
|
||||||
done()
|
done()
|
||||||
|
|
||||||
|
|
||||||
|
describe 'POST /db/level/names', ->
|
||||||
|
|
||||||
|
it 'returns names of levels whose ids have been POSTed', utils.wrap (done) ->
|
||||||
|
levels = yield _.times(5, utils.makeLevel)
|
||||||
|
levelIDs = _.map(levels, (level) -> level.id)
|
||||||
|
[res, body] = yield request.postAsync { url: utils.getURL('/db/level/names'), json: { ids: levelIDs } }
|
||||||
|
expect(res.statusCode).toBe(200)
|
||||||
|
expect(res.body.length).toBe(5)
|
||||||
|
aLevel = levels[2]
|
||||||
|
expect(_.find(body, (l) -> l._id is aLevel.id).name).toBe(aLevel.get('name'))
|
||||||
|
done()
|
||||||
|
|
Loading…
Reference in a new issue