mirror of
https://github.com/Chocobozzz/PeerTube.git
synced 2025-02-25 18:55:32 -06:00
External auth can update user on login
This commit is contained in:
@@ -51,6 +51,7 @@ describe('Test external auth plugins', function () {
|
||||
|
||||
let kefkaAccessToken: string
|
||||
let kefkaRefreshToken: string
|
||||
let kefkaId: number
|
||||
|
||||
let externalAuthToken: string
|
||||
|
||||
@@ -184,6 +185,8 @@ describe('Test external auth plugins', function () {
|
||||
expect(body.adminFlags).to.equal(UserAdminFlag.BYPASS_VIDEO_AUTO_BLACKLIST)
|
||||
expect(body.videoQuota).to.equal(42000)
|
||||
expect(body.videoQuotaDaily).to.equal(42100)
|
||||
|
||||
kefkaId = body.id
|
||||
}
|
||||
})
|
||||
|
||||
@@ -246,6 +249,37 @@ describe('Test external auth plugins', function () {
|
||||
expect(body.role.id).to.equal(UserRole.USER)
|
||||
})
|
||||
|
||||
it('Should login Kefka and update the profile', async function () {
|
||||
{
|
||||
await server.users.update({ userId: kefkaId, videoQuota: 43000, videoQuotaDaily: 43100 })
|
||||
await server.users.updateMe({ token: kefkaAccessToken, displayName: 'kefka updated' })
|
||||
|
||||
const body = await server.users.getMyInfo({ token: kefkaAccessToken })
|
||||
expect(body.username).to.equal('kefka')
|
||||
expect(body.account.displayName).to.equal('kefka updated')
|
||||
expect(body.videoQuota).to.equal(43000)
|
||||
expect(body.videoQuotaDaily).to.equal(43100)
|
||||
}
|
||||
|
||||
{
|
||||
const res = await loginExternal({
|
||||
server,
|
||||
npmName: 'test-external-auth-one',
|
||||
authName: 'external-auth-2',
|
||||
username: 'kefka'
|
||||
})
|
||||
|
||||
kefkaAccessToken = res.access_token
|
||||
kefkaRefreshToken = res.refresh_token
|
||||
|
||||
const body = await server.users.getMyInfo({ token: kefkaAccessToken })
|
||||
expect(body.username).to.equal('kefka')
|
||||
expect(body.account.displayName).to.equal('Kefka Palazzo')
|
||||
expect(body.videoQuota).to.equal(42000)
|
||||
expect(body.videoQuotaDaily).to.equal(43100)
|
||||
}
|
||||
})
|
||||
|
||||
it('Should not update an external auth email', async function () {
|
||||
await server.users.updateMe({
|
||||
token: cyanAccessToken,
|
||||
|
||||
@@ -13,6 +13,7 @@ describe('Test id and pass auth plugins', function () {
|
||||
|
||||
let lagunaAccessToken: string
|
||||
let lagunaRefreshToken: string
|
||||
let lagunaId: number
|
||||
|
||||
before(async function () {
|
||||
this.timeout(30000)
|
||||
@@ -78,8 +79,10 @@ describe('Test id and pass auth plugins', function () {
|
||||
const body = await server.users.getMyInfo({ token: lagunaAccessToken })
|
||||
|
||||
expect(body.username).to.equal('laguna')
|
||||
expect(body.account.displayName).to.equal('laguna')
|
||||
expect(body.account.displayName).to.equal('Laguna Loire')
|
||||
expect(body.role.id).to.equal(UserRole.USER)
|
||||
|
||||
lagunaId = body.id
|
||||
}
|
||||
})
|
||||
|
||||
@@ -132,6 +135,33 @@ describe('Test id and pass auth plugins', function () {
|
||||
expect(body.role.id).to.equal(UserRole.MODERATOR)
|
||||
})
|
||||
|
||||
it('Should login Laguna and update the profile', async function () {
|
||||
{
|
||||
await server.users.update({ userId: lagunaId, videoQuota: 43000, videoQuotaDaily: 43100 })
|
||||
await server.users.updateMe({ token: lagunaAccessToken, displayName: 'laguna updated' })
|
||||
|
||||
const body = await server.users.getMyInfo({ token: lagunaAccessToken })
|
||||
expect(body.username).to.equal('laguna')
|
||||
expect(body.account.displayName).to.equal('laguna updated')
|
||||
expect(body.videoQuota).to.equal(43000)
|
||||
expect(body.videoQuotaDaily).to.equal(43100)
|
||||
}
|
||||
|
||||
{
|
||||
const body = await server.login.login({ user: { username: 'laguna', password: 'laguna password' } })
|
||||
lagunaAccessToken = body.access_token
|
||||
lagunaRefreshToken = body.refresh_token
|
||||
}
|
||||
|
||||
{
|
||||
const body = await server.users.getMyInfo({ token: lagunaAccessToken })
|
||||
expect(body.username).to.equal('laguna')
|
||||
expect(body.account.displayName).to.equal('Laguna Loire')
|
||||
expect(body.videoQuota).to.equal(42000)
|
||||
expect(body.videoQuotaDaily).to.equal(43100)
|
||||
}
|
||||
})
|
||||
|
||||
it('Should reject token of laguna by the plugin hook', async function () {
|
||||
this.timeout(10000)
|
||||
|
||||
@@ -147,7 +177,7 @@ describe('Test id and pass auth plugins', function () {
|
||||
await server.servers.waitUntilLog('valid username')
|
||||
|
||||
await command.login({ user: { username: 'kiros', password: 'kiros password' }, expectedStatus: HttpStatusCode.BAD_REQUEST_400 })
|
||||
await server.servers.waitUntilLog('valid display name')
|
||||
await server.servers.waitUntilLog('valid displayName')
|
||||
|
||||
await command.login({ user: { username: 'raine', password: 'raine password' }, expectedStatus: HttpStatusCode.BAD_REQUEST_400 })
|
||||
await server.servers.waitUntilLog('valid role')
|
||||
|
||||
Reference in New Issue
Block a user