Skip to content

Commit

Permalink
Fixing mocha tests and broken password change status codes (#50704)
Browse files Browse the repository at this point in the history
* Fixing mocha tests and broken password change status codes

* Updating API integration test
  • Loading branch information
kobelb committed Nov 15, 2019
1 parent 69431b5 commit 18cb01a
Show file tree
Hide file tree
Showing 4 changed files with 12 additions and 16 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ describe('Authentication routes', () => {

initAuthenticateApi({
authc: { login: loginStub, logout: logoutStub },
config: { authc: { providers: ['basic'] } },
__legacyCompat: { config: { authc: { providers: ['basic'] } } },
}, serverStub);
});

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ describe('User routes', () => {
clusterStub = sinon.stub({ callWithRequest() {} });
sandbox.stub(ClientShield, 'getClient').returns(clusterStub);

initUsersApi({ authc: { login: loginStub }, config: { authc: { providers: ['basic'] } } }, serverStub);
initUsersApi({ authc: { login: loginStub }, __legacyCompat: { config: { authc: { providers: ['basic'] } } } }, serverStub);
});

afterEach(() => sandbox.restore());
Expand Down Expand Up @@ -90,7 +90,7 @@ describe('User routes', () => {
expect(response.isBoom).to.be(true);
expect(response.output.payload).to.eql({
statusCode: 403,
error: 'Unauthorized',
error: 'Forbidden',
message: 'Something went wrong.'
});
});
Expand Down
20 changes: 8 additions & 12 deletions x-pack/legacy/plugins/security/server/routes/api/v1/users.js
Original file line number Diff line number Diff line change
Expand Up @@ -96,19 +96,15 @@ export function initUsersApi({ authc: { login }, __legacyCompat: { config } }, s
// If user tries to change own password, let's check if old password is valid first by trying
// to login.
if (isCurrentUser) {
try {
const authenticationResult = await login(KibanaRequest.from(request), {
provider: providerToLoginWith,
value: { username, password },
// We shouldn't alter authentication state just yet.
stateless: true,
});
const authenticationResult = await login(KibanaRequest.from(request), {
provider: providerToLoginWith,
value: { username, password },
// We shouldn't alter authentication state just yet.
stateless: true,
});

if (!authenticationResult.succeeded()) {
return Boom.unauthorized(authenticationResult.error);
}
} catch(err) {
throw Boom.forbidden(err);
if (!authenticationResult.succeeded()) {
return Boom.forbidden(authenticationResult.error);
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ export default function({ getService }: FtrProviderContext) {
.set('kbn-xsrf', 'xxx')
.set('Cookie', sessionCookie.cookieString())
.send({ password: wrongPassword, newPassword })
.expect(401);
.expect(403);

// Let's check that we can't login with wrong password, just in case.
await supertest
Expand Down

0 comments on commit 18cb01a

Please sign in to comment.