mirror of
https://github.com/ajayyy/SponsorBlockServer.git
synced 2024-11-10 09:07:47 +01:00
105 lines
3.5 KiB
TypeScript
105 lines
3.5 KiB
TypeScript
import fetch from 'node-fetch';
|
|
import {Done, getbaseURL} from '../utils';
|
|
import {db} from '../../src/databases/databases';
|
|
import {getHash} from '../../src/utils/getHash';
|
|
import assert from 'assert';
|
|
|
|
describe('postWarning', () => {
|
|
before(async () => {
|
|
await db.prepare("run", `INSERT INTO "vipUsers" ("userID") VALUES (?)`, [getHash("warning-vip")]);
|
|
});
|
|
|
|
it('Should be able to create warning if vip (exp 200)', (done: Done) => {
|
|
const json = {
|
|
issuerUserID: 'warning-vip',
|
|
userID: 'warning-0',
|
|
reason: 'warning-reason-0'
|
|
};
|
|
fetch(getbaseURL()
|
|
+ "/api/warnUser", {
|
|
method: 'POST',
|
|
headers: {
|
|
'Content-Type': 'application/json',
|
|
},
|
|
body: JSON.stringify(json),
|
|
})
|
|
.then(async res => {
|
|
assert.strictEqual(res.status, 200);
|
|
const row = await db.prepare('get', `SELECT "userID", "issueTime", "issuerUserID", enabled, "reason" FROM warnings WHERE "userID" = ?`, [json.userID]);
|
|
assert.strictEqual(row.enabled, 1);
|
|
assert.strictEqual(row.issuerUserID, getHash(json.issuerUserID));
|
|
assert.strictEqual(row.reason, json.reason);
|
|
done();
|
|
})
|
|
.catch(err => done(err));
|
|
});
|
|
|
|
it('Should be not be able to create a duplicate warning if vip', (done: Done) => {
|
|
const json = {
|
|
issuerUserID: 'warning-vip',
|
|
userID: 'warning-0',
|
|
};
|
|
|
|
fetch(getbaseURL()
|
|
+ "/api/warnUser", {
|
|
method: 'POST',
|
|
headers: {
|
|
'Content-Type': 'application/json',
|
|
},
|
|
body: JSON.stringify(json),
|
|
})
|
|
.then(async res => {
|
|
assert.strictEqual(res.status, 409);
|
|
const row = await db.prepare('get', `SELECT "userID", "issueTime", "issuerUserID", enabled FROM warnings WHERE "userID" = ?`, [json.userID]);
|
|
assert.strictEqual(row.enabled, 1);
|
|
assert.strictEqual(row.issuerUserID, getHash(json.issuerUserID));
|
|
done();
|
|
})
|
|
.catch(err => done(err));
|
|
});
|
|
|
|
it('Should be able to remove warning if vip', (done: Done) => {
|
|
const json = {
|
|
issuerUserID: 'warning-vip',
|
|
userID: 'warning-0',
|
|
enabled: false
|
|
};
|
|
|
|
fetch(getbaseURL()
|
|
+ "/api/warnUser", {
|
|
method: 'POST',
|
|
headers: {
|
|
'Content-Type': 'application/json',
|
|
},
|
|
body: JSON.stringify(json),
|
|
})
|
|
.then(async res => {
|
|
assert.strictEqual(res.status, 200);
|
|
const row = await db.prepare('get', `SELECT "userID", "issueTime", "issuerUserID", enabled FROM warnings WHERE "userID" = ?`, [json.userID]);
|
|
assert.strictEqual(row.enabled, 0);
|
|
done();
|
|
})
|
|
.catch(err => done(err));
|
|
});
|
|
|
|
it('Should not be able to create warning if not vip (exp 403)', (done: Done) => {
|
|
const json = {
|
|
issuerUserID: 'warning-not-vip',
|
|
userID: 'warning-1',
|
|
};
|
|
|
|
fetch(getbaseURL()
|
|
+ "/api/warnUser", {
|
|
method: 'POST',
|
|
headers: {
|
|
'Content-Type': 'application/json',
|
|
},
|
|
body: JSON.stringify(json),
|
|
})
|
|
.then(res => {
|
|
assert.strictEqual(res.status, 403);
|
|
done();
|
|
})
|
|
.catch(err => done(err));
|
|
});
|
|
});
|