2021-07-19 19:22:29 -07:00
|
|
|
const { test } = require('@jest/globals');
|
|
|
|
var request = require('supertest');
|
|
|
|
request = request('http://127.0.0.1:8080');
|
2021-08-12 16:49:40 -07:00
|
|
|
const WebSocket = require('ws');
|
|
|
|
const fs = require('fs');
|
2021-07-19 19:22:29 -07:00
|
|
|
|
|
|
|
const registerChat = require('./lib/chat').registerChat;
|
|
|
|
const sendChatMessage = require('./lib/chat').sendChatMessage;
|
|
|
|
|
2022-03-06 20:34:49 -08:00
|
|
|
const localIPAddress = '127.0.0.1';
|
|
|
|
|
2021-07-19 19:22:29 -07:00
|
|
|
const testVisibilityMessage = {
|
2021-08-12 16:49:40 -07:00
|
|
|
body: 'message ' + Math.floor(Math.random() * 100),
|
|
|
|
type: 'CHAT',
|
2021-07-19 19:22:29 -07:00
|
|
|
};
|
|
|
|
|
2021-08-12 16:49:40 -07:00
|
|
|
var userId;
|
|
|
|
var accessToken;
|
2021-07-19 19:22:29 -07:00
|
|
|
test('can register a user', async (done) => {
|
2021-08-12 16:49:40 -07:00
|
|
|
const registration = await registerChat();
|
|
|
|
userId = registration.id;
|
|
|
|
accessToken = registration.accessToken;
|
|
|
|
done();
|
2021-07-19 19:22:29 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
test('can send a chat message', async (done) => {
|
2021-08-12 16:49:40 -07:00
|
|
|
sendChatMessage(testVisibilityMessage, accessToken, done);
|
2021-07-19 19:22:29 -07:00
|
|
|
});
|
|
|
|
|
2022-03-06 20:34:49 -08:00
|
|
|
test('can set the user as moderator', async (done) => {
|
|
|
|
await request
|
|
|
|
.post('/api/admin/chat/users/setmoderator')
|
|
|
|
.send({ userId: userId, isModerator: true })
|
|
|
|
.auth('admin', 'abc123')
|
|
|
|
.expect(200);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
|
|
|
|
test('verify user is a moderator', async (done) => {
|
|
|
|
const response = await request
|
|
|
|
.get('/api/admin/chat/users/moderators')
|
|
|
|
.auth('admin', 'abc123')
|
|
|
|
.expect(200);
|
|
|
|
const tokenCheck = response.body.filter((user) => user.id === userId);
|
|
|
|
expect(tokenCheck).toHaveLength(1);
|
|
|
|
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
|
|
|
|
test('verify user list is populated', async (done) => {
|
|
|
|
const ws = new WebSocket(
|
|
|
|
`ws://localhost:8080/ws?accessToken=${accessToken}`,
|
|
|
|
{
|
|
|
|
origin: 'http://localhost:8080',
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
|
|
|
ws.on('open', async function open() {
|
|
|
|
const response = await request
|
|
|
|
.get('/api/admin/chat/clients')
|
|
|
|
.auth('admin', 'abc123')
|
|
|
|
.expect(200);
|
|
|
|
|
|
|
|
expect(response.body.length).toBeGreaterThan(0);
|
|
|
|
|
|
|
|
// Optionally, if GeoIP is configured, check the location property.
|
|
|
|
if (fs.existsSync('../../../data/GeoLite2-City.mmdb')) {
|
|
|
|
expect(response.body[0].geo.regionName).toBe('Localhost');
|
|
|
|
}
|
|
|
|
|
|
|
|
ws.close();
|
|
|
|
});
|
|
|
|
|
|
|
|
ws.on('error', function incoming(data) {
|
|
|
|
console.error(data);
|
|
|
|
ws.close();
|
|
|
|
});
|
|
|
|
|
|
|
|
ws.on('close', function incoming(data) {
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2021-07-19 19:22:29 -07:00
|
|
|
test('can disable a user', async (done) => {
|
2021-11-11 12:43:21 -08:00
|
|
|
// To allow for visually being able to see the test hiding the
|
|
|
|
// message add a short delay.
|
|
|
|
await new Promise((r) => setTimeout(r, 1500));
|
|
|
|
|
2022-03-06 20:34:49 -08:00
|
|
|
const ws = new WebSocket(
|
|
|
|
`ws://localhost:8080/ws?accessToken=${accessToken}`,
|
|
|
|
{
|
|
|
|
origin: 'http://localhost:8080',
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
2021-11-11 12:43:21 -08:00
|
|
|
await request
|
|
|
|
.post('/api/admin/chat/users/setenabled')
|
|
|
|
.send({ userId: userId, enabled: false })
|
|
|
|
.auth('admin', 'abc123')
|
|
|
|
.expect(200);
|
2022-03-06 20:34:49 -08:00
|
|
|
|
|
|
|
await new Promise((r) => setTimeout(r, 1500));
|
2021-11-11 12:43:21 -08:00
|
|
|
done();
|
|
|
|
});
|
2021-07-19 19:22:29 -07:00
|
|
|
|
|
|
|
test('verify user is disabled', async (done) => {
|
2021-08-12 16:49:40 -07:00
|
|
|
const response = await request
|
|
|
|
.get('/api/admin/chat/users/disabled')
|
|
|
|
.auth('admin', 'abc123')
|
|
|
|
.expect(200);
|
|
|
|
const tokenCheck = response.body.filter((user) => user.id === userId);
|
|
|
|
expect(tokenCheck).toHaveLength(1);
|
|
|
|
done();
|
2021-07-19 19:22:29 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
test('verify messages from user are hidden', async (done) => {
|
2021-08-12 16:49:40 -07:00
|
|
|
const response = await request
|
|
|
|
.get('/api/admin/chat/messages')
|
2021-07-19 19:22:29 -07:00
|
|
|
.auth('admin', 'abc123')
|
|
|
|
.expect(200);
|
2021-08-12 16:49:40 -07:00
|
|
|
const message = response.body.filter((obj) => {
|
|
|
|
return obj.user.id === userId;
|
|
|
|
});
|
2022-01-12 13:53:10 -08:00
|
|
|
expect(message[0].user.disabledAt).toBeTruthy();
|
2021-08-12 16:49:40 -07:00
|
|
|
done();
|
2021-07-19 19:22:29 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
test('can re-enable a user', async (done) => {
|
2021-08-12 16:49:40 -07:00
|
|
|
await request
|
|
|
|
.post('/api/admin/chat/users/setenabled')
|
|
|
|
.send({ userId: userId, enabled: true })
|
|
|
|
.auth('admin', 'abc123')
|
|
|
|
.expect(200);
|
|
|
|
done();
|
2021-07-19 19:22:29 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
test('verify user is enabled', async (done) => {
|
2021-08-12 16:49:40 -07:00
|
|
|
const response = await request
|
|
|
|
.get('/api/admin/chat/users/disabled')
|
|
|
|
.auth('admin', 'abc123')
|
|
|
|
.expect(200);
|
|
|
|
const tokenCheck = response.body.filter((user) => user.id === userId);
|
|
|
|
expect(tokenCheck).toHaveLength(0);
|
|
|
|
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
|
2022-03-06 20:34:49 -08:00
|
|
|
test('ban an ip address', async (done) => {
|
2021-11-02 19:27:41 -07:00
|
|
|
await request
|
2022-03-06 20:34:49 -08:00
|
|
|
.post('/api/admin/chat/users/ipbans/create')
|
|
|
|
.send({ value: localIPAddress })
|
2021-11-02 19:27:41 -07:00
|
|
|
.auth('admin', 'abc123')
|
|
|
|
.expect(200);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
|
2022-03-06 20:34:49 -08:00
|
|
|
// Note: This test expects the local address to be 127.0.0.1.
|
|
|
|
// If it's running on an ipv6-only network, for example, things will
|
|
|
|
// probably fail.
|
|
|
|
test('verify IP address is blocked from the ban', async (done) => {
|
2021-11-02 19:27:41 -07:00
|
|
|
const response = await request
|
2022-03-06 20:34:49 -08:00
|
|
|
.get(`/api/admin/chat/users/ipbans`)
|
2021-11-02 19:27:41 -07:00
|
|
|
.auth('admin', 'abc123')
|
|
|
|
.expect(200);
|
|
|
|
|
2022-03-06 20:34:49 -08:00
|
|
|
expect(response.body).toHaveLength(1);
|
|
|
|
expect(response.body[0].ipAddress).toBe(localIPAddress);
|
2021-11-02 19:27:41 -07:00
|
|
|
done();
|
|
|
|
});
|
|
|
|
|
2022-03-06 20:34:49 -08:00
|
|
|
test('verify access is denied', async (done) => {
|
|
|
|
await request.get(`/api/chat?accessToken=${accessToken}`).expect(401);
|
|
|
|
done();
|
|
|
|
});
|
2021-08-12 16:49:40 -07:00
|
|
|
|
2022-03-06 20:34:49 -08:00
|
|
|
test('remove an ip address ban', async (done) => {
|
|
|
|
await request
|
|
|
|
.post('/api/admin/chat/users/ipbans/remove')
|
|
|
|
.send({ value: localIPAddress })
|
|
|
|
.auth('admin', 'abc123')
|
|
|
|
.expect(200);
|
|
|
|
done();
|
|
|
|
});
|
2021-08-12 16:49:40 -07:00
|
|
|
|
2022-03-06 20:34:49 -08:00
|
|
|
test('verify IP address is no longer banned', async (done) => {
|
|
|
|
const response = await request
|
|
|
|
.get(`/api/admin/chat/users/ipbans`)
|
|
|
|
.auth('admin', 'abc123')
|
|
|
|
.expect(200);
|
2021-08-12 16:49:40 -07:00
|
|
|
|
2022-03-06 20:34:49 -08:00
|
|
|
expect(response.body).toHaveLength(0);
|
|
|
|
done();
|
|
|
|
});
|
2021-08-12 16:49:40 -07:00
|
|
|
|
2022-03-06 20:34:49 -08:00
|
|
|
test('verify access is again allowed', async (done) => {
|
|
|
|
await request.get(`/api/chat?accessToken=${accessToken}`).expect(200);
|
|
|
|
done();
|
2021-07-19 19:22:29 -07:00
|
|
|
});
|