2021-06-24 07:27:21 +02:00
|
|
|
import fetch from 'node-fetch';
|
|
|
|
import {Done, getbaseURL} from '../utils';
|
|
|
|
import {db} from '../../src/databases/databases';
|
|
|
|
import {getHash} from '../../src/utils/getHash';
|
|
|
|
import {IDatabase} from '../../src/databases/IDatabase';
|
2021-07-07 09:47:08 +02:00
|
|
|
import assert from 'assert';
|
2021-06-24 07:27:21 +02:00
|
|
|
|
|
|
|
async function dbSponsorTimesAdd(db: IDatabase, videoID: string, startTime: number, endTime: number, UUID: string, category: string) {
|
|
|
|
const votes = 0,
|
|
|
|
userID = 0,
|
|
|
|
timeSubmitted = 0,
|
|
|
|
views = 0,
|
|
|
|
shadowHidden = 0,
|
|
|
|
hidden = 0,
|
|
|
|
hashedVideoID = `hash_${UUID}`;
|
|
|
|
await db.prepare("run", `INSERT INTO
|
|
|
|
"sponsorTimes" ("videoID", "startTime", "endTime", "votes", "UUID",
|
|
|
|
"userID", "timeSubmitted", "views", "category", "shadowHidden", "hashedVideoID", "hidden")
|
|
|
|
VALUES(?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`,
|
|
|
|
[videoID, startTime, endTime, votes, UUID, userID, timeSubmitted, views, category, shadowHidden, hashedVideoID, hidden]);
|
|
|
|
}
|
|
|
|
|
2021-06-24 07:36:54 +02:00
|
|
|
async function dbSponsorTimesCompareExpect(db: IDatabase, videoId: string, expectdHidden: number) {
|
2021-07-04 07:34:31 +02:00
|
|
|
const seg = await db.prepare('get', `SELECT "hidden", "UUID" FROM "sponsorTimes" WHERE "videoID" = ?`, [videoId]);
|
2021-06-24 07:27:21 +02:00
|
|
|
for (let i = 0, len = seg.length; i < len; i++) {
|
2021-06-24 07:36:54 +02:00
|
|
|
if (seg.hidden !== expectdHidden) {
|
|
|
|
return `${seg.UUID} hidden expected to be ${expectdHidden} but found ${seg.hidden}`;
|
2021-06-24 07:27:21 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
describe('postPurgeAllSegments', function () {
|
|
|
|
const privateVipUserID = 'VIPUser-purgeAll';
|
|
|
|
const route = '/api/purgeAllSegments';
|
|
|
|
const vipUserID = getHash(privateVipUserID);
|
|
|
|
const baseURL = getbaseURL();
|
|
|
|
|
|
|
|
before(async function () {
|
|
|
|
// startTime and endTime get set in beforeEach for consistency
|
2021-06-24 07:36:54 +02:00
|
|
|
await dbSponsorTimesAdd(db, 'vsegpurge01', 0, 1, 'vsegpurgetest01uuid01', 'intro');
|
|
|
|
await dbSponsorTimesAdd(db, 'vsegpurge01', 0, 2, 'vsegpurgetest01uuid02', 'sponsor');
|
|
|
|
await dbSponsorTimesAdd(db, 'vsegpurge01', 0, 3, 'vsegpurgetest01uuid03', 'interaction');
|
|
|
|
await dbSponsorTimesAdd(db, 'vsegpurge01', 0, 4, 'vsegpurgetest01uuid04', 'outro');
|
|
|
|
await dbSponsorTimesAdd(db, 'vseg-not-purged01', 0, 5, 'vsegpurgetest01uuid05', 'outro');
|
2021-06-24 07:27:21 +02:00
|
|
|
await db.prepare("run", `INSERT INTO "vipUsers" ("userID") VALUES (?)`, [vipUserID]);
|
|
|
|
});
|
|
|
|
|
2021-06-24 07:36:54 +02:00
|
|
|
it('Reject non-VIP user', function (done: Done) {
|
2021-06-24 07:27:21 +02:00
|
|
|
fetch(`${baseURL}${route}`, {
|
|
|
|
method: 'POST',
|
|
|
|
headers: {
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
},
|
|
|
|
body: JSON.stringify({
|
|
|
|
videoID: 'vsegpurge01',
|
|
|
|
userID: 'segshift_randomuser001',
|
|
|
|
}),
|
|
|
|
})
|
|
|
|
.then(async res => {
|
2021-07-07 09:47:08 +02:00
|
|
|
assert.strictEqual(res.status, 403);
|
|
|
|
done();
|
2021-06-24 07:27:21 +02:00
|
|
|
})
|
|
|
|
.catch(err => done(err));
|
|
|
|
});
|
|
|
|
|
|
|
|
it('Purge all segments success', function (done: Done) {
|
|
|
|
fetch(`${baseURL}${route}`, {
|
|
|
|
method: 'POST',
|
|
|
|
headers: {
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
},
|
|
|
|
body: JSON.stringify({
|
|
|
|
videoID: 'vsegpurge01',
|
|
|
|
userID: privateVipUserID,
|
|
|
|
}),
|
|
|
|
})
|
|
|
|
.then(async res => {
|
2021-07-07 09:47:08 +02:00
|
|
|
assert.strictEqual(res.status, 200);
|
2021-06-24 07:36:54 +02:00
|
|
|
done(await dbSponsorTimesCompareExpect(db, 'vsegpurge01', 1) || await dbSponsorTimesCompareExpect(db, 'vseg-not-purged01', 0));
|
2021-06-24 07:27:21 +02:00
|
|
|
})
|
|
|
|
.catch(err => done(err));
|
|
|
|
});
|
|
|
|
});
|