auto(agent): enhance auth tests with duplicate email handling
This commit is contained in:
parent
e8f533fbe3
commit
f831cf4290
2 changed files with 40 additions and 2 deletions
|
|
@ -107,5 +107,43 @@ test('login should reject invalid credentials', async () => {
|
||||||
assert.strictEqual(res.statusCode, 401);
|
assert.strictEqual(res.statusCode, 401);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
test('register should handle duplicate email', async () => {
|
||||||
|
const mockPoolWithDup = {
|
||||||
|
query: (sql, params) => {
|
||||||
|
if (sql.includes('INSERT INTO users')) {
|
||||||
|
const err = new Error('Duplicate entry');
|
||||||
|
err.code = 'ER_DUP_ENTRY';
|
||||||
|
throw err;
|
||||||
|
}
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
pool.query = mockPoolWithDup.query;
|
||||||
|
|
||||||
|
const req = {
|
||||||
|
body: {
|
||||||
|
email: 'test@example.com',
|
||||||
|
password: 'password123',
|
||||||
|
displayName: 'Test User'
|
||||||
|
}
|
||||||
|
};
|
||||||
|
const res = {
|
||||||
|
status: (code) => {
|
||||||
|
res.statusCode = code;
|
||||||
|
return res;
|
||||||
|
},
|
||||||
|
json: (data) => {
|
||||||
|
res.data = data;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
await require('../routes/auth').default.post('/register', req, res);
|
||||||
|
assert.strictEqual(res.statusCode, 409);
|
||||||
|
|
||||||
|
// Restore the original pool
|
||||||
|
pool.query = originalPool.query;
|
||||||
|
});
|
||||||
|
|
||||||
// Restore the original pool
|
// Restore the original pool
|
||||||
pool.query = originalPool;
|
pool.query = originalPool;
|
||||||
|
|
@ -1,2 +1,2 @@
|
||||||
LAST_ROUTE=offers.js
|
LAST_ROUTE=auth.js
|
||||||
UPDATED_AT=2026-03-06T19:56:59Z
|
UPDATED_AT=2026-03-06T20:10:38Z
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue