Add other tests to external auth
This commit is contained in:
parent
5ff523664f
commit
d253bfaaa5
|
@ -123,7 +123,7 @@ async function getUser (usernameOrEmail?: string, password?: string) {
|
||||||
|
|
||||||
const user = await UserModel.loadByUsernameOrEmail(usernameOrEmail)
|
const user = await UserModel.loadByUsernameOrEmail(usernameOrEmail)
|
||||||
// If we don't find the user, or if the user belongs to a plugin
|
// If we don't find the user, or if the user belongs to a plugin
|
||||||
if (!user || user.pluginAuth !== null) return null
|
if (!user || user.pluginAuth !== null || !password) return null
|
||||||
|
|
||||||
const passwordMatch = await user.isPasswordMatch(password)
|
const passwordMatch = await user.isPasswordMatch(password)
|
||||||
if (passwordMatch !== true) return null
|
if (passwordMatch !== true) return null
|
||||||
|
|
|
@ -17,6 +17,54 @@ async function register ({
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
const result = registerExternalAuth({
|
||||||
|
authName: 'external-auth-4',
|
||||||
|
authDisplayName: () => 'External Auth 4',
|
||||||
|
onAuthRequest: (req, res) => {
|
||||||
|
result.userAuthenticated({
|
||||||
|
req,
|
||||||
|
res,
|
||||||
|
username: 'kefka2',
|
||||||
|
email: 'kefka@example.com',
|
||||||
|
displayName: 'Kefka duplication'
|
||||||
|
})
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
const result = registerExternalAuth({
|
||||||
|
authName: 'external-auth-5',
|
||||||
|
authDisplayName: () => 'External Auth 5',
|
||||||
|
onAuthRequest: (req, res) => {
|
||||||
|
result.userAuthenticated({
|
||||||
|
req,
|
||||||
|
res,
|
||||||
|
username: 'kefka',
|
||||||
|
email: 'kefka@example.com',
|
||||||
|
displayName: 'Kefka duplication'
|
||||||
|
})
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
const result = registerExternalAuth({
|
||||||
|
authName: 'external-auth-6',
|
||||||
|
authDisplayName: () => 'External Auth 6',
|
||||||
|
onAuthRequest: (req, res) => {
|
||||||
|
result.userAuthenticated({
|
||||||
|
req,
|
||||||
|
res,
|
||||||
|
username: 'existing_user',
|
||||||
|
email: 'existing_user@example.com',
|
||||||
|
displayName: 'Existing user'
|
||||||
|
})
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
async function unregister () {
|
async function unregister () {
|
||||||
|
|
|
@ -18,7 +18,8 @@ import {
|
||||||
updateMyUser,
|
updateMyUser,
|
||||||
wait,
|
wait,
|
||||||
userLogin,
|
userLogin,
|
||||||
updatePluginSettings
|
updatePluginSettings,
|
||||||
|
createUser
|
||||||
} from '../../../shared/extra-utils'
|
} from '../../../shared/extra-utils'
|
||||||
import { cleanupTests, flushAndRunServer, ServerInfo, waitUntilLog } from '../../../shared/extra-utils/server/servers'
|
import { cleanupTests, flushAndRunServer, ServerInfo, waitUntilLog } from '../../../shared/extra-utils/server/servers'
|
||||||
|
|
||||||
|
@ -29,6 +30,7 @@ async function loginExternal (options: {
|
||||||
username: string
|
username: string
|
||||||
query?: any
|
query?: any
|
||||||
statusCodeExpected?: number
|
statusCodeExpected?: number
|
||||||
|
statusCodeExpectedStep2?: number
|
||||||
}) {
|
}) {
|
||||||
const res = await getExternalAuth({
|
const res = await getExternalAuth({
|
||||||
url: options.server.url,
|
url: options.server.url,
|
||||||
|
@ -47,7 +49,8 @@ async function loginExternal (options: {
|
||||||
const resLogin = await loginUsingExternalToken(
|
const resLogin = await loginUsingExternalToken(
|
||||||
options.server,
|
options.server,
|
||||||
options.username,
|
options.username,
|
||||||
externalAuthToken as string
|
externalAuthToken as string,
|
||||||
|
options.statusCodeExpectedStep2
|
||||||
)
|
)
|
||||||
|
|
||||||
return resLogin.body
|
return resLogin.body
|
||||||
|
@ -85,7 +88,7 @@ describe('Test external auth plugins', function () {
|
||||||
const config: ServerConfig = res.body
|
const config: ServerConfig = res.body
|
||||||
|
|
||||||
const auths = config.plugin.registeredExternalAuths
|
const auths = config.plugin.registeredExternalAuths
|
||||||
expect(auths).to.have.lengthOf(3)
|
expect(auths).to.have.lengthOf(6)
|
||||||
|
|
||||||
const auth2 = auths.find((a) => a.authName === 'external-auth-2')
|
const auth2 = auths.find((a) => a.authName === 'external-auth-2')
|
||||||
expect(auth2).to.exist
|
expect(auth2).to.exist
|
||||||
|
@ -288,7 +291,7 @@ describe('Test external auth plugins', function () {
|
||||||
const config: ServerConfig = res.body
|
const config: ServerConfig = res.body
|
||||||
|
|
||||||
const auths = config.plugin.registeredExternalAuths
|
const auths = config.plugin.registeredExternalAuths
|
||||||
expect(auths).to.have.lengthOf(2)
|
expect(auths).to.have.lengthOf(5)
|
||||||
|
|
||||||
const auth1 = auths.find(a => a.authName === 'external-auth-2')
|
const auth1 = auths.find(a => a.authName === 'external-auth-2')
|
||||||
expect(auth1).to.not.exist
|
expect(auth1).to.not.exist
|
||||||
|
@ -311,6 +314,45 @@ describe('Test external auth plugins', function () {
|
||||||
username: 'cyan',
|
username: 'cyan',
|
||||||
statusCodeExpected: 404
|
statusCodeExpected: 404
|
||||||
})
|
})
|
||||||
|
|
||||||
|
await userLogin(server, { username: 'cyan', password: null }, 400)
|
||||||
|
await userLogin(server, { username: 'cyan', password: '' }, 400)
|
||||||
|
await userLogin(server, { username: 'cyan', password: 'fake' }, 400)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('Should not login kefka with another plugin', async function () {
|
||||||
|
await loginExternal({
|
||||||
|
server,
|
||||||
|
npmName: 'test-external-auth-two',
|
||||||
|
authName: 'external-auth-4',
|
||||||
|
username: 'kefka2',
|
||||||
|
statusCodeExpectedStep2: 400
|
||||||
|
})
|
||||||
|
|
||||||
|
await loginExternal({
|
||||||
|
server,
|
||||||
|
npmName: 'test-external-auth-two',
|
||||||
|
authName: 'external-auth-4',
|
||||||
|
username: 'kefka',
|
||||||
|
statusCodeExpectedStep2: 400
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
it('Should not login an existing user', async function () {
|
||||||
|
await createUser({
|
||||||
|
url: server.url,
|
||||||
|
accessToken: server.accessToken,
|
||||||
|
username: 'existing_user',
|
||||||
|
password: 'super_password'
|
||||||
|
})
|
||||||
|
|
||||||
|
await loginExternal({
|
||||||
|
server,
|
||||||
|
npmName: 'test-external-auth-two',
|
||||||
|
authName: 'external-auth-6',
|
||||||
|
username: 'existing_user',
|
||||||
|
statusCodeExpectedStep2: 400
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
it('Should display the correct configuration', async function () {
|
it('Should display the correct configuration', async function () {
|
||||||
|
@ -319,7 +361,7 @@ describe('Test external auth plugins', function () {
|
||||||
const config: ServerConfig = res.body
|
const config: ServerConfig = res.body
|
||||||
|
|
||||||
const auths = config.plugin.registeredExternalAuths
|
const auths = config.plugin.registeredExternalAuths
|
||||||
expect(auths).to.have.lengthOf(1)
|
expect(auths).to.have.lengthOf(4)
|
||||||
|
|
||||||
const auth2 = auths.find((a) => a.authName === 'external-auth-2')
|
const auth2 = auths.find((a) => a.authName === 'external-auth-2')
|
||||||
expect(auth2).to.not.exist
|
expect(auth2).to.not.exist
|
||||||
|
|
Loading…
Reference in New Issue