Fix: Tests lint and src folder (#138)
* Automaticly fixable eslint issues, mostly 3 -> 2 space indentation * fix: updated plex_userid to camelcase * Linted and some consistency refactor on middleware * eslint uses ecmaversion 2020 & allow empty catch rule * Started linting source files * Fixed eslint errors & improved a lot of error handling * Set 2 eslint rules as warning temporarly * Updated all import statements to be relative * Updated mocha & nyc, resolved all lint issues in tests/ * Updated mocha & nyc. Removed production config. Updated gitignore * Updated test commands to omit system tests, no exit code * Updated test configuration w/ missing keys * Chai modules defined in package.json & resolved linting errors * Dockerfile copies development.example -> production.json. Simplified commands * All api calls from tests use same chaiHttp implementation Removes a list of fetch alternatives after being replaced by chaiHttp: - request - request-promise - supertest - supertest-as-promised * Tests should use redis (mock) cache, not tmdb sqlite cache * Disabled test asADeveloperIWantTheServerToStart * Re-enable tests/system * Use chaiHttp in asAUserIWantToRequestAMovie. * Fixed redis expire & mock implmentation * Replaced all fetch alternatives from source code and package.json * Pass error from tmdb api back to client as errorMessage * Updated authentication middleware to handle checks consitenctly * Prevent assert error when checking request status, returns success 200 * Resolved merge conflicts * Only build and publish docker container when branch master
This commit is contained in:
10
.drone.yml
10
.drone.yml
@@ -77,11 +77,11 @@ steps:
|
|||||||
from_secret: PLEX_IP
|
from_secret: PLEX_IP
|
||||||
PLEX_TOKEN:
|
PLEX_TOKEN:
|
||||||
from_secret: PLEX_TOKEN
|
from_secret: PLEX_TOKEN
|
||||||
# when:
|
when:
|
||||||
# event:
|
event:
|
||||||
# - push
|
- push
|
||||||
# branch:
|
branch:
|
||||||
# - master
|
- master
|
||||||
|
|
||||||
# - name: deploy
|
# - name: deploy
|
||||||
# image: appleboy/drone-ssh
|
# image: appleboy/drone-ssh
|
||||||
|
|||||||
@@ -5,6 +5,7 @@
|
|||||||
"sourceType": "module"
|
"sourceType": "module"
|
||||||
},
|
},
|
||||||
"extends": ["eslint-config-airbnb-base", "plugin:prettier/recommended"],
|
"extends": ["eslint-config-airbnb-base", "plugin:prettier/recommended"],
|
||||||
|
"plugins": ["mocha"],
|
||||||
"rules": {
|
"rules": {
|
||||||
"max-classes-per-file": 1,
|
"max-classes-per-file": 1,
|
||||||
"no-empty": [
|
"no-empty": [
|
||||||
@@ -16,5 +17,8 @@
|
|||||||
"no-promise-executor-return": 1,
|
"no-promise-executor-return": 1,
|
||||||
"no-shadow": "off",
|
"no-shadow": "off",
|
||||||
"no-underscore-dangle": "off"
|
"no-underscore-dangle": "off"
|
||||||
|
},
|
||||||
|
"env": {
|
||||||
|
"mocha": true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
5
.gitignore
vendored
5
.gitignore
vendored
@@ -1,8 +1,11 @@
|
|||||||
.DS_Store
|
.DS_Store
|
||||||
|
|
||||||
development.json
|
configurations/development.json
|
||||||
|
configurations/production.json
|
||||||
.env
|
.env
|
||||||
shows.db
|
shows.db
|
||||||
|
|
||||||
node_modules
|
node_modules
|
||||||
*/package-lock.json
|
*/package-lock.json
|
||||||
|
.nyc_output
|
||||||
|
yarn-error.log
|
||||||
|
|||||||
@@ -12,7 +12,7 @@ COPY yarn.lock .
|
|||||||
RUN apt update
|
RUN apt update
|
||||||
RUN apt install node-pre-gyp -y
|
RUN apt install node-pre-gyp -y
|
||||||
RUN yarn
|
RUN yarn
|
||||||
RUN cp configurations/development.json.example configurations/development.json
|
RUN cp configurations/development.json.example configurations/production.json
|
||||||
|
|
||||||
EXPOSE 31459
|
EXPOSE 31459
|
||||||
|
|
||||||
|
|||||||
@@ -1,31 +0,0 @@
|
|||||||
{
|
|
||||||
"database": {
|
|
||||||
"host": "/Users/kevin/dev/seasonedShows/shows.db"
|
|
||||||
},
|
|
||||||
"webserver": {
|
|
||||||
"port": 31459,
|
|
||||||
"origins": ["https://kevinmidboe.com", "https://seasoned.show", "https://request.movie"]
|
|
||||||
},
|
|
||||||
"tmdb": {
|
|
||||||
"apiKey": "9fa154f5355c37a1b9b57ac06e7d6712"
|
|
||||||
},
|
|
||||||
"plex": {
|
|
||||||
"ip": "blex.schleppe"
|
|
||||||
},
|
|
||||||
"tautulli": {
|
|
||||||
"apiKey": "4e759f7acabf4f1a8893825e6acd522b",
|
|
||||||
"ip": "blex.schleppe",
|
|
||||||
"port": "8181"
|
|
||||||
},
|
|
||||||
"raven": {
|
|
||||||
"DSN": ""
|
|
||||||
},
|
|
||||||
"authentication": {
|
|
||||||
"secret": "secret"
|
|
||||||
},
|
|
||||||
"sms": {
|
|
||||||
"apikey": "qK48YChORZOX4FqAwgzdOrfYT2-bixwshtRe-BogNksBZyUrMHLTh0-XOjsxziPV",
|
|
||||||
"sender": "Seasoned",
|
|
||||||
"recipient": 41498549
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -2,19 +2,30 @@
|
|||||||
"database": {
|
"database": {
|
||||||
"host": ":memory:"
|
"host": ":memory:"
|
||||||
},
|
},
|
||||||
|
"redis": {
|
||||||
|
"host": "localhost",
|
||||||
|
"port": 6379
|
||||||
|
},
|
||||||
"webserver": {
|
"webserver": {
|
||||||
"port": 31400
|
"port": 31400,
|
||||||
|
"origins": []
|
||||||
},
|
},
|
||||||
"tmdb": {
|
"tmdb": {
|
||||||
"apiKey": "bogus-api-key"
|
"apiKey": "bogus-api-key"
|
||||||
},
|
},
|
||||||
"plex": {
|
"plex": {
|
||||||
"ip": "0.0.0.0"
|
"ip": "localhost",
|
||||||
|
"token": ""
|
||||||
|
},
|
||||||
|
"tautulli": {
|
||||||
|
"apiKey": "",
|
||||||
|
"ip": "",
|
||||||
|
"port": ""
|
||||||
},
|
},
|
||||||
"raven": {
|
"raven": {
|
||||||
"DSN": ""
|
"DSN": ""
|
||||||
},
|
},
|
||||||
"authentication": {
|
"authentication": {
|
||||||
"secret": "secret"
|
"secret": "secret"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
31
package.json
31
package.json
@@ -7,54 +7,49 @@
|
|||||||
},
|
},
|
||||||
"main": "webserver/server.js",
|
"main": "webserver/server.js",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"start": "yarn cross-env SEASONED_CONFIG=configurations/production.json NODE_ENV=production babel-node src/webserver/server.js",
|
"start": "SEASONED_CONFIG=configurations/production.json NODE_ENV=production node src/webserver/server.js",
|
||||||
"dev": "yarn cross-env SEASONED_CONFIG=configurations/development.json NODE_ENV=development babel-node src/webserver/server.js",
|
"dev": "SEASONED_CONFIG=configurations/development.json NODE_ENV=development node src/webserver/server.js",
|
||||||
"test": "cross-env SEASONED_CONFIG=configurations/test.json NODE_PATH=. mocha --require @babel/register --recursive tests/unit tests/system",
|
"test": "SEASONED_CONFIG=configurations/test.json mocha --recursive tests/unit tests/system",
|
||||||
"coverage": "cross-env SEASONED_CONFIG=configurations/test.json NODE_PATH=. nyc mocha --require @babel/register --recursive test && nyc report --reporter=text-lcov | coveralls",
|
"coverage:upload": "SEASONED_CONFIG=configurations/test.json mocha --recursive tests/unit && nyc report --reporter=text-lcov | coveralls",
|
||||||
"lint": "eslint src",
|
"coverage": "SEASONED_CONFIG=configurations/test.json mocha --recursive tests/unit && nyc report",
|
||||||
"update": "cross-env SEASONED_CONFIG=configurations/development.json NODE_PATH=. node scripts/updateRequestsInPlex.js",
|
"lint": "eslint src tests",
|
||||||
|
"update": "SEASONED_CONFIG=configurations/development.json node scripts/updateRequestsInPlex.js",
|
||||||
"docs": "yarn apiDocs; yarn classDocs",
|
"docs": "yarn apiDocs; yarn classDocs",
|
||||||
"apiDocs": "",
|
"apiDocs": "",
|
||||||
"classDocs": "scripts/generate-class-docs.sh"
|
"classDocs": "scripts/generate-class-docs.sh"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"axios": "^0.18.0",
|
|
||||||
"bcrypt": "^5.0.1",
|
"bcrypt": "^5.0.1",
|
||||||
"body-parser": "~1.18.2",
|
"body-parser": "~1.18.2",
|
||||||
"cookie-parser": "^1.4.6",
|
"cookie-parser": "^1.4.6",
|
||||||
"cross-env": "~5.1.4",
|
|
||||||
"express": "~4.16.0",
|
"express": "~4.16.0",
|
||||||
"form-data": "^2.5.1",
|
"form-data": "^2.5.1",
|
||||||
"jsonwebtoken": "^8.5.1",
|
"jsonwebtoken": "^8.5.1",
|
||||||
"km-moviedb": "^0.2.12",
|
"km-moviedb": "^0.2.12",
|
||||||
"node-cache": "^4.1.1",
|
|
||||||
"node-fetch": "^2.6.0",
|
|
||||||
"python-shell": "^0.5.0",
|
"python-shell": "^0.5.0",
|
||||||
"raven": "^2.4.2",
|
"raven": "^2.4.2",
|
||||||
"redis": "^3.0.2",
|
"redis": "^3.0.2",
|
||||||
"request": "^2.87.0",
|
|
||||||
"request-promise": "^4.2",
|
|
||||||
"sqlite3": "^5.0.1"
|
"sqlite3": "^5.0.1"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@babel/core": "^7.5.5",
|
"@babel/core": "^7.5.5",
|
||||||
"@babel/node": "^7.5.5",
|
|
||||||
"@babel/preset-env": "^7.5.5",
|
"@babel/preset-env": "^7.5.5",
|
||||||
"@babel/register": "^7.5.5",
|
"@babel/register": "^7.5.5",
|
||||||
"@types/node": "^12.6.8",
|
"@types/node": "^12.6.8",
|
||||||
|
"chai": "^4.3.6",
|
||||||
|
"chai-http": "^4.3.0",
|
||||||
"coveralls": "^3.0.5",
|
"coveralls": "^3.0.5",
|
||||||
"documentation": "^12.0.3",
|
"documentation": "^12.0.3",
|
||||||
"eslint": "^8.22.0",
|
"eslint": "^8.22.0",
|
||||||
"eslint-config-airbnb-base": "^15.0.0",
|
"eslint-config-airbnb-base": "^15.0.0",
|
||||||
"eslint-config-prettier": "^8.5.0",
|
"eslint-config-prettier": "^8.5.0",
|
||||||
"eslint-plugin-import": "^2.8.0",
|
"eslint-plugin-import": "^2.8.0",
|
||||||
|
"eslint-plugin-mocha": "10.1.0",
|
||||||
"eslint-plugin-prettier": "^4.2.1",
|
"eslint-plugin-prettier": "^4.2.1",
|
||||||
"istanbul": "^0.4.5",
|
"istanbul": "^0.4.5",
|
||||||
"mocha": "^6.2.0",
|
"mocha": "8.4.0",
|
||||||
"mocha-lcov-reporter": "^1.3.0",
|
"mocha-lcov-reporter": "^1.3.0",
|
||||||
"nyc": "^11.6.0",
|
"nyc": "15.1.0",
|
||||||
"prettier": "^2.7.1",
|
"prettier": "^2.7.1"
|
||||||
"supertest": "^3.0.0",
|
|
||||||
"supertest-as-promised": "^4.0.1"
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
21
src/cache/redis.js
vendored
21
src/cache/redis.js
vendored
@@ -1,6 +1,7 @@
|
|||||||
const configuration = require("../config/configuration").getInstance();
|
const configuration = require("../config/configuration").getInstance();
|
||||||
|
|
||||||
let client;
|
let client;
|
||||||
|
const mockCache = {};
|
||||||
|
|
||||||
try {
|
try {
|
||||||
const redis = require("redis"); // eslint-disable-line global-require
|
const redis = require("redis"); // eslint-disable-line global-require
|
||||||
@@ -8,7 +9,6 @@ try {
|
|||||||
const host = configuration.get("redis", "host");
|
const host = configuration.get("redis", "host");
|
||||||
const port = configuration.get("redis", "port");
|
const port = configuration.get("redis", "port");
|
||||||
|
|
||||||
console.log(`redis://${host}:${port}`); // eslint-disable-line no-console
|
|
||||||
client = redis.createClient({
|
client = redis.createClient({
|
||||||
url: `redis://${host}:${port}`
|
url: `redis://${host}:${port}`
|
||||||
});
|
});
|
||||||
@@ -20,13 +20,18 @@ try {
|
|||||||
console.error("Unable to connect to redis, setting up redis-mock."); // eslint-disable-line no-console
|
console.error("Unable to connect to redis, setting up redis-mock."); // eslint-disable-line no-console
|
||||||
|
|
||||||
client = {
|
client = {
|
||||||
get(command) {
|
get(key, callback) {
|
||||||
console.log(`redis-dummy get: ${command}`); // eslint-disable-line no-console
|
console.log(`redis-dummy get: ${key}`); // eslint-disable-line no-console
|
||||||
return Promise.resolve();
|
const hit = mockCache[key];
|
||||||
|
return Promise.resolve().then(callback(null, hit));
|
||||||
},
|
},
|
||||||
set(command) {
|
set(key, json, callback) {
|
||||||
console.log(`redis-dummy set: ${command}`); // eslint-disable-line no-console
|
console.log(`redis-dummy set: ${key}`); // eslint-disable-line no-console
|
||||||
return Promise.resolve();
|
mockCache[key] = JSON.stringify(json);
|
||||||
|
return Promise.resolve().then(callback(null, "OK"));
|
||||||
|
},
|
||||||
|
expire(key, TTL) {
|
||||||
|
console.log(`redis-dummy expire: ${key} with TTL ${TTL}`); // eslint-disable-line no-console
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
@@ -39,7 +44,7 @@ function set(key, value, TTL = 10800) {
|
|||||||
client.set(key, json, (error, reply) => {
|
client.set(key, json, (error, reply) => {
|
||||||
if (reply === "OK") {
|
if (reply === "OK") {
|
||||||
// successfully set value with key, now set TTL for key
|
// successfully set value with key, now set TTL for key
|
||||||
client.expire(key, TTL, e => {
|
client.expire(key, TTL, "NX", e => {
|
||||||
if (e)
|
if (e)
|
||||||
// eslint-disable-next-line no-console
|
// eslint-disable-next-line no-console
|
||||||
console.error(
|
console.error(
|
||||||
|
|||||||
@@ -1,4 +1,3 @@
|
|||||||
const request = require("request");
|
|
||||||
const configuration = require("../config/configuration").getInstance();
|
const configuration = require("../config/configuration").getInstance();
|
||||||
|
|
||||||
class SMSUnexpectedError extends Error {
|
class SMSUnexpectedError extends Error {
|
||||||
@@ -20,23 +19,21 @@ const sendSMS = message => {
|
|||||||
|
|
||||||
const sender = configuration.get("sms", "sender");
|
const sender = configuration.get("sms", "sender");
|
||||||
const recipient = configuration.get("sms", "recipient");
|
const recipient = configuration.get("sms", "recipient");
|
||||||
|
const smsRequestHeaders = { "Content-Type": "application/json" };
|
||||||
|
const smsRequestBody = {
|
||||||
|
sender,
|
||||||
|
message,
|
||||||
|
recipients: [{ msisdn: `47${recipient}` }]
|
||||||
|
};
|
||||||
|
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
request.post(
|
fetch(`https://gatewayapi.com/rest/mtsms?token=${apiKey}`, {
|
||||||
{
|
body: JSON.stringify(smsRequestBody),
|
||||||
url: `https://gatewayapi.com/rest/mtsms?token=${apiKey}`,
|
headers: smsRequestHeaders
|
||||||
json: true,
|
})
|
||||||
body: {
|
.then(resp => resp.json())
|
||||||
sender,
|
.then(response => resolve(response))
|
||||||
message,
|
.catch(error => reject(new SMSUnexpectedError(error)));
|
||||||
recipients: [{ msisdn: `47${recipient}` }]
|
|
||||||
}
|
|
||||||
},
|
|
||||||
(err, r, body) => {
|
|
||||||
if (err) reject(new SMSUnexpectedError(err || body));
|
|
||||||
resolve(body);
|
|
||||||
}
|
|
||||||
);
|
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
@@ -1,4 +1,3 @@
|
|||||||
const fetch = require("node-fetch");
|
|
||||||
const convertPlexToMovie = require("./convertPlexToMovie");
|
const convertPlexToMovie = require("./convertPlexToMovie");
|
||||||
const convertPlexToShow = require("./convertPlexToShow");
|
const convertPlexToShow = require("./convertPlexToShow");
|
||||||
const convertPlexToEpisode = require("./convertPlexToEpisode");
|
const convertPlexToEpisode = require("./convertPlexToEpisode");
|
||||||
|
|||||||
@@ -1,4 +1,3 @@
|
|||||||
const rp = require("request-promise");
|
|
||||||
const convertPlexToSeasoned = require("./convertPlexToSeasoned");
|
const convertPlexToSeasoned = require("./convertPlexToSeasoned");
|
||||||
const convertPlexToStream = require("./convertPlexToStream");
|
const convertPlexToStream = require("./convertPlexToStream");
|
||||||
|
|
||||||
@@ -35,8 +34,9 @@ function mapResults(response) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
class PlexRepository {
|
class PlexRepository {
|
||||||
constructor(plexIP) {
|
constructor(plexIP, plexToken) {
|
||||||
this.plexIP = plexIP;
|
this.plexIP = plexIP;
|
||||||
|
this.plexToken = plexToken;
|
||||||
}
|
}
|
||||||
|
|
||||||
inPlex(_tmdbResult) {
|
inPlex(_tmdbResult) {
|
||||||
@@ -56,19 +56,17 @@ class PlexRepository {
|
|||||||
}
|
}
|
||||||
|
|
||||||
search(query) {
|
search(query) {
|
||||||
const queryUri = encodeURIComponent(query);
|
const url = encodeURI(
|
||||||
const uri = encodeURI(
|
`http://${this.plexIP}:32400/search?query=${encodeURIComponent(
|
||||||
`http://${this.plexIP}:32400/search?query=${queryUri}`
|
query
|
||||||
|
)}&X-Plex-Token=${this.plexToken}`
|
||||||
);
|
);
|
||||||
const options = {
|
const options = {
|
||||||
uri,
|
headers: { Accept: "application/json" }
|
||||||
headers: {
|
|
||||||
Accept: "application/json"
|
|
||||||
},
|
|
||||||
json: true
|
|
||||||
};
|
};
|
||||||
|
|
||||||
return rp(options)
|
return fetch(url, options)
|
||||||
|
.then(resp => resp.json())
|
||||||
.then(result => mapResults(result))
|
.then(result => mapResults(result))
|
||||||
.then(([mappedResults, resultCount]) => ({
|
.then(([mappedResults, resultCount]) => ({
|
||||||
results: mappedResults,
|
results: mappedResults,
|
||||||
@@ -77,15 +75,13 @@ class PlexRepository {
|
|||||||
}
|
}
|
||||||
|
|
||||||
nowPlaying() {
|
nowPlaying() {
|
||||||
|
const url = `http://${this.plexIP}:32400/status/sessions?X-Plex-Token=${this.plexToken}`;
|
||||||
const options = {
|
const options = {
|
||||||
uri: `http://${this.plexIP}:32400/status/sessions`,
|
headers: { Accept: "application/json" }
|
||||||
headers: {
|
|
||||||
Accept: "application/json"
|
|
||||||
},
|
|
||||||
json: true
|
|
||||||
};
|
};
|
||||||
|
|
||||||
return rp(options)
|
return fetch(url, options)
|
||||||
|
.then(resp => resp.json())
|
||||||
.then(result => {
|
.then(result => {
|
||||||
if (result.MediaContainer.size > 0) {
|
if (result.MediaContainer.size > 0) {
|
||||||
const playing =
|
const playing =
|
||||||
|
|||||||
@@ -3,7 +3,10 @@ const configuration = require("../config/configuration").getInstance();
|
|||||||
const TMDB = require("../tmdb/tmdb");
|
const TMDB = require("../tmdb/tmdb");
|
||||||
const establishedDatabase = require("../database/database");
|
const establishedDatabase = require("../database/database");
|
||||||
|
|
||||||
const plexRepository = new PlexRepository(configuration.get("plex", "ip"));
|
const plexRepository = new PlexRepository(
|
||||||
|
configuration.get("plex", "ip"),
|
||||||
|
configuration.get("plex", "token")
|
||||||
|
);
|
||||||
const tmdb = new TMDB(configuration.get("tmdb", "apiKey"));
|
const tmdb = new TMDB(configuration.get("tmdb", "apiKey"));
|
||||||
|
|
||||||
class RequestRepository {
|
class RequestRepository {
|
||||||
|
|||||||
@@ -83,7 +83,8 @@ class RequestRepository {
|
|||||||
return this.database
|
return this.database
|
||||||
.get(this.queries.readWithoutUserData, [id, type])
|
.get(this.queries.readWithoutUserData, [id, type])
|
||||||
.then(row => {
|
.then(row => {
|
||||||
assert(row, "Could not find request item with that id and type");
|
if (!row) return null;
|
||||||
|
|
||||||
return {
|
return {
|
||||||
id: row.id,
|
id: row.id,
|
||||||
title: row.title,
|
title: row.title,
|
||||||
@@ -122,10 +123,7 @@ class RequestRepository {
|
|||||||
return this.database
|
return this.database
|
||||||
.all(fetchQuery, fetchParams)
|
.all(fetchQuery, fetchParams)
|
||||||
.then(async rows => {
|
.then(async rows => {
|
||||||
const sqliteResponse = await this.database.get(
|
const sqliteResponse = await this.database.get(fetchTotalResults);
|
||||||
fetchTotalResults,
|
|
||||||
filter || null
|
|
||||||
);
|
|
||||||
const { totalRequests } = sqliteResponse;
|
const { totalRequests } = sqliteResponse;
|
||||||
const totalPages = Math.ceil(totalRequests / 26);
|
const totalPages = Math.ceil(totalRequests / 26);
|
||||||
|
|
||||||
|
|||||||
@@ -1,5 +1,3 @@
|
|||||||
const fetch = require("node-fetch");
|
|
||||||
|
|
||||||
class TautulliUnexpectedError extends Error {
|
class TautulliUnexpectedError extends Error {
|
||||||
constructor(errorMessage) {
|
constructor(errorMessage) {
|
||||||
const message = "Unexpected error fetching from tautulli.";
|
const message = "Unexpected error fetching from tautulli.";
|
||||||
|
|||||||
@@ -38,17 +38,17 @@ class TMDBNotReachableError extends Error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
const tmdbErrorResponse = (error, type = null) => {
|
const tmdbErrorResponse = (error, type = null) => {
|
||||||
if (error.status === 404) {
|
if (error?.status === 404) {
|
||||||
const message = error.response.body.status_message;
|
const message = error?.response?.body?.status_message;
|
||||||
|
|
||||||
throw new TMDBNotFoundError(`${message.slice(0, -1)} in tmdb.`);
|
throw new TMDBNotFoundError(`${message.slice(0, -1)} in tmdb.`);
|
||||||
} else if (error.status === 401) {
|
} else if (error?.status === 401) {
|
||||||
throw new TMDBUnauthorizedError(error?.response?.body?.status_message);
|
throw new TMDBUnauthorizedError(error?.response?.body?.status_message);
|
||||||
} else if (error?.code === "ENOTFOUND") {
|
} else if (error?.code === "ENOTFOUND") {
|
||||||
throw new TMDBNotReachableError();
|
throw new TMDBNotReachableError();
|
||||||
}
|
}
|
||||||
|
|
||||||
throw new TMDBUnexpectedError(type, error);
|
throw new TMDBUnexpectedError(type, error.message);
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -44,6 +44,7 @@ async function movieInfoController(req, res) {
|
|||||||
} catch (error) {
|
} catch (error) {
|
||||||
return res.status(error?.statusCode || 500).send({
|
return res.status(error?.statusCode || 500).send({
|
||||||
success: false,
|
success: false,
|
||||||
|
errorMessage: error?.errorMessage,
|
||||||
message:
|
message:
|
||||||
error?.message ||
|
error?.message ||
|
||||||
`An unexpected error occured while requesting info for with id: ${movieId}`
|
`An unexpected error occured while requesting info for with id: ${movieId}`
|
||||||
|
|||||||
@@ -1,7 +1,10 @@
|
|||||||
const PlexRepository = require("../../../plex/plexRepository");
|
const PlexRepository = require("../../../plex/plexRepository");
|
||||||
const configuration = require("../../../config/configuration").getInstance();
|
const configuration = require("../../../config/configuration").getInstance();
|
||||||
|
|
||||||
const plexRepository = new PlexRepository(configuration.get("plex", "ip"));
|
const plexRepository = new PlexRepository(
|
||||||
|
configuration.get("plex", "ip"),
|
||||||
|
configuration.get("plex", "token")
|
||||||
|
);
|
||||||
|
|
||||||
function playingController(req, res) {
|
function playingController(req, res) {
|
||||||
plexRepository
|
plexRepository
|
||||||
|
|||||||
@@ -1,7 +1,10 @@
|
|||||||
const PlexRepository = require("../../../plex/plexRepository");
|
const PlexRepository = require("../../../plex/plexRepository");
|
||||||
const configuration = require("../../../config/configuration").getInstance();
|
const configuration = require("../../../config/configuration").getInstance();
|
||||||
|
|
||||||
const plexRepository = new PlexRepository(configuration.get("plex", "ip"));
|
const plexRepository = new PlexRepository(
|
||||||
|
configuration.get("plex", "ip"),
|
||||||
|
configuration.get("plex", "token")
|
||||||
|
);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Controller: Search for media and check existence
|
* Controller: Search for media and check existence
|
||||||
|
|||||||
@@ -14,7 +14,19 @@ function fetchAllRequests(req, res) {
|
|||||||
|
|
||||||
request
|
request
|
||||||
.getRequestByIdAndType(id, type)
|
.getRequestByIdAndType(id, type)
|
||||||
.then(result => res.send(result))
|
.then(result => {
|
||||||
|
if (!result) {
|
||||||
|
return res.send({
|
||||||
|
success: false,
|
||||||
|
message: `Item ${type} with id ${id} has not been requested`
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
return res.send({
|
||||||
|
success: true,
|
||||||
|
result
|
||||||
|
});
|
||||||
|
})
|
||||||
.catch(error => {
|
.catch(error => {
|
||||||
return res.status(error?.statusCode || 500).send({
|
return res.status(error?.statusCode || 500).send({
|
||||||
success: false,
|
success: false,
|
||||||
|
|||||||
@@ -4,8 +4,8 @@ const establishedDatabase = require("../../database/database");
|
|||||||
const mustBeAdmin = (req, res, next) => {
|
const mustBeAdmin = (req, res, next) => {
|
||||||
const database = establishedDatabase;
|
const database = establishedDatabase;
|
||||||
|
|
||||||
if (req.loggedInUser === undefined) {
|
if (!req.loggedInUser) {
|
||||||
res.status(401).send({
|
return res.status(401).send({
|
||||||
success: false,
|
success: false,
|
||||||
message: "You must be logged in."
|
message: "You must be logged in."
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
// eslint-disable-next-line consistent-return
|
// eslint-disable-next-line consistent-return
|
||||||
const mustBeAuthenticated = (req, res, next) => {
|
const mustBeAuthenticated = (req, res, next) => {
|
||||||
if (req.loggedInUser === undefined) {
|
if (!req.loggedInUser) {
|
||||||
return res.status(401).send({
|
return res.status(401).send({
|
||||||
success: false,
|
success: false,
|
||||||
message: "You must be logged in."
|
message: "You must be logged in."
|
||||||
|
|||||||
@@ -3,9 +3,9 @@ const establishedDatabase = require("../../database/database");
|
|||||||
/* eslint-disable consistent-return */
|
/* eslint-disable consistent-return */
|
||||||
const mustHaveAccountLinkedToPlex = (req, res, next) => {
|
const mustHaveAccountLinkedToPlex = (req, res, next) => {
|
||||||
const database = establishedDatabase;
|
const database = establishedDatabase;
|
||||||
const { loggedInUser } = req;
|
|
||||||
|
|
||||||
if (loggedInUser === null) {
|
// TODO use mustByAuthenticated middleware
|
||||||
|
if (!req.loggedInUser) {
|
||||||
return res.status(401).send({
|
return res.status(401).send({
|
||||||
success: false,
|
success: false,
|
||||||
message: "You must have your account linked to a plex account."
|
message: "You must have your account linked to a plex account."
|
||||||
@@ -15,7 +15,7 @@ const mustHaveAccountLinkedToPlex = (req, res, next) => {
|
|||||||
database
|
database
|
||||||
.get(
|
.get(
|
||||||
`SELECT plex_userid FROM settings WHERE user_name IS ?`,
|
`SELECT plex_userid FROM settings WHERE user_name IS ?`,
|
||||||
loggedInUser.username
|
req.loggedInUser.username
|
||||||
)
|
)
|
||||||
.then(row => {
|
.then(row => {
|
||||||
const plexUserId = row.plex_userid;
|
const plexUserId = row.plex_userid;
|
||||||
|
|||||||
@@ -4,8 +4,6 @@ const app = require("./app");
|
|||||||
module.exports = app.listen(config.get("webserver", "port"), () => {
|
module.exports = app.listen(config.get("webserver", "port"), () => {
|
||||||
/* eslint-disable no-console */
|
/* eslint-disable no-console */
|
||||||
console.log("seasonedAPI");
|
console.log("seasonedAPI");
|
||||||
/* eslint-disable no-console */
|
|
||||||
console.log(`Database is located at ${config.get("database", "host")}`);
|
console.log(`Database is located at ${config.get("database", "host")}`);
|
||||||
/* eslint-disable no-console */
|
|
||||||
console.log(`Webserver is listening on ${config.get("webserver", "port")}`);
|
console.log(`Webserver is listening on ${config.get("webserver", "port")}`);
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -1,9 +1,7 @@
|
|||||||
const Cache = require('src/tmdb/cache');
|
const redisCache = require("../../src/cache/redis");
|
||||||
const SqliteDatabase = require('src/database/sqliteDatabase');
|
|
||||||
|
|
||||||
function createCacheEntry(key, value) {
|
function createCacheEntry(key, value) {
|
||||||
const cache = new Cache();
|
return redisCache.set(key, value);
|
||||||
return cache.set(key, value);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
module.exports = createCacheEntry;
|
module.exports = createCacheEntry;
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
const User = require('src/user/user');
|
const User = require("../../src/user/user");
|
||||||
const Token = require('src/user/token');
|
const Token = require("../../src/user/token");
|
||||||
|
|
||||||
function createToken(username, secret) {
|
function createToken(username, secret) {
|
||||||
const user = new User(username);
|
const user = new User(username);
|
||||||
|
|||||||
@@ -1,11 +1,11 @@
|
|||||||
const User = require('src/user/user');
|
const User = require("../../src/user/user");
|
||||||
const UserSecurity = require('src/user/userSecurity');
|
const UserSecurity = require("../../src/user/userSecurity");
|
||||||
|
|
||||||
function createUser(username, password) {
|
function createUser(username, password) {
|
||||||
const userSecurity = new UserSecurity();
|
const userSecurity = new UserSecurity();
|
||||||
const user = new User(username)
|
const user = new User(username);
|
||||||
|
|
||||||
return Promise.resolve(userSecurity.createNewUser(user, password))
|
return userSecurity.createNewUser(user, password);
|
||||||
}
|
}
|
||||||
|
|
||||||
module.exports = createUser;
|
module.exports = createUser;
|
||||||
|
|||||||
@@ -1,9 +1,22 @@
|
|||||||
const establishedDatabase = require('src/database/database');
|
// class EstablishedDatabase {
|
||||||
|
// constructor() {}
|
||||||
|
|
||||||
function resetDatabase() {
|
// tearDown() {
|
||||||
return Promise.resolve()
|
// console.log("mock teardown");
|
||||||
.then(() => establishedDatabase.tearDown())
|
// }
|
||||||
.then(() => establishedDatabase.setUp())
|
|
||||||
|
// setup() {
|
||||||
|
// console.log("mock setup");
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
|
||||||
|
const establishedDatabase = require("../../src/database/database");
|
||||||
|
// const establishedDatabase = new EstablishedDatabase();
|
||||||
|
|
||||||
|
function resetDatabase() {
|
||||||
|
return Promise.resolve()
|
||||||
|
.then(() => establishedDatabase.tearDown())
|
||||||
|
.then(() => establishedDatabase.setUp());
|
||||||
}
|
}
|
||||||
|
|
||||||
module.exports = resetDatabase;
|
module.exports = resetDatabase;
|
||||||
|
|||||||
@@ -1,16 +1,15 @@
|
|||||||
const tmdbMock = () => ({
|
const tmdbMock = () => ({
|
||||||
error: null,
|
error: null,
|
||||||
response: null,
|
response: null,
|
||||||
searchMovie(query, callback) {
|
searchMovie(query, callback) {
|
||||||
callback(this.error, this.response);
|
callback(this.error, this.response);
|
||||||
},
|
},
|
||||||
movieInfo(query, callback) {
|
movieInfo(query, callback) {
|
||||||
callback(this.error, this.response);
|
callback(this.error, this.response);
|
||||||
},
|
},
|
||||||
miscPopularMovies(callback) {
|
miscPopularMovies(callback) {
|
||||||
console.log('miscPopMovies callback', callback)
|
callback(this.error, this.response);
|
||||||
callback(this.error, this.response);
|
}
|
||||||
},
|
|
||||||
});
|
});
|
||||||
|
|
||||||
module.exports = tmdbMock;
|
module.exports = tmdbMock;
|
||||||
|
|||||||
@@ -1,16 +1,24 @@
|
|||||||
const assert = require('assert');
|
const assert = require("assert");
|
||||||
const request = require('supertest-as-promised');
|
const chai = require("chai");
|
||||||
const app = require('src/webserver/app');
|
const chaiHttp = require("chai-http");
|
||||||
const resetDatabase = require('test/helpers/resetDatabase');
|
|
||||||
|
|
||||||
describe('As a user I want to register', () => {
|
const server = require("../../src/webserver/server");
|
||||||
before(() => resetDatabase());
|
const resetDatabase = require("../helpers/resetDatabase");
|
||||||
|
|
||||||
it('should return 200 and a message indicating success', () =>
|
chai.use(chaiHttp);
|
||||||
request(app)
|
|
||||||
.post('/api/v1/user')
|
describe("As a user I want to register", () => {
|
||||||
.send({ username: 'test', email: 'test@gmail.com', password: 'password' })
|
beforeEach(() => resetDatabase());
|
||||||
.expect(200)
|
|
||||||
.then(response => assert.equal(response.body.message, 'Welcome to Seasoned!'))
|
it("should return 200 and a message indicating success", done => {
|
||||||
);
|
chai
|
||||||
|
.request(server)
|
||||||
|
.post("/api/v1/user")
|
||||||
|
.send({ username: "test", email: "test@gmail.com", password: "password" })
|
||||||
|
.end((error, response) => {
|
||||||
|
assert.equal(response?.status, 200);
|
||||||
|
assert.equal(response?.body?.message, "Welcome to Seasoned!");
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -1,14 +0,0 @@
|
|||||||
/* eslint-disable no-return-assign */
|
|
||||||
const net = require('net');
|
|
||||||
|
|
||||||
xdescribe('As a developer I want the server to start', () => {
|
|
||||||
beforeEach(() =>
|
|
||||||
this.server = require('src/webserver/server'));
|
|
||||||
|
|
||||||
it('should listen on port 31400', (done) => {
|
|
||||||
net.createConnection(31400, done);
|
|
||||||
});
|
|
||||||
|
|
||||||
afterEach(() =>
|
|
||||||
this.server.close());
|
|
||||||
});
|
|
||||||
13
tests/system/asADeveloperIWantTheServerToStart.js.disabled
Normal file
13
tests/system/asADeveloperIWantTheServerToStart.js.disabled
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
/* eslint-disable no-return-assign */
|
||||||
|
const net = require("net");
|
||||||
|
const server = require("../../src/webserver/server");
|
||||||
|
|
||||||
|
describe("As a developer I want the server to start", () => {
|
||||||
|
after(() => {
|
||||||
|
server.close();
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should listen on port 31400", done => {
|
||||||
|
net.createConnection(31459, done);
|
||||||
|
});
|
||||||
|
});
|
||||||
@@ -1,27 +1,40 @@
|
|||||||
const assert = require('assert');
|
const assert = require("assert");
|
||||||
const request = require('supertest-as-promised');
|
const chai = require("chai");
|
||||||
const app = require('src/webserver/app');
|
const chaiHttp = require("chai-http");
|
||||||
const createUser = require('test/helpers/createUser');
|
|
||||||
const resetDatabase = require('test/helpers/resetDatabase');
|
|
||||||
|
|
||||||
describe('As a user I want to log in', () => {
|
const server = require("../../src/webserver/server");
|
||||||
before(() => {
|
const createUser = require("../helpers/createUser");
|
||||||
return resetDatabase()
|
const resetDatabase = require("../helpers/resetDatabase");
|
||||||
.then(() => createUser('test_user', 'password'))
|
|
||||||
})
|
|
||||||
|
|
||||||
it('should return 200 with a token if correct credentials are given', () =>
|
chai.use(chaiHttp);
|
||||||
request(app)
|
|
||||||
.post('/api/v1/user/login')
|
|
||||||
.send({ username: 'test_user', password: 'password' })
|
|
||||||
.expect(200)
|
|
||||||
.then(response => assert.equal(typeof response.body.token, 'string'))
|
|
||||||
);
|
|
||||||
|
|
||||||
it('should return 401 if incorrect credentials are given', () =>
|
describe("As a user I want to log in", () => {
|
||||||
request(app)
|
beforeEach(() => resetDatabase());
|
||||||
.post('/api/v1/user/login')
|
beforeEach(() => createUser("test_user", "password"));
|
||||||
.send({ username: 'test_user', password: 'anti-password' })
|
|
||||||
.expect(401)
|
it("should return 200 with a token if correct credentials are given", done => {
|
||||||
);
|
chai
|
||||||
|
.request(server)
|
||||||
|
.post("/api/v1/user/login")
|
||||||
|
.send({ username: "test_user", password: "password" })
|
||||||
|
.end((error, response) => {
|
||||||
|
// console.log(response);
|
||||||
|
|
||||||
|
assert.equal(response?.status, 200);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should return 401 if incorrect credentials are given", done => {
|
||||||
|
chai
|
||||||
|
.request(server)
|
||||||
|
.post("/api/v1/user/login")
|
||||||
|
.send({ username: "test_user", password: "anti-password" })
|
||||||
|
.end((error, response) => {
|
||||||
|
// console.log(response);
|
||||||
|
|
||||||
|
assert.equal(response?.status, 401);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -1,16 +1,26 @@
|
|||||||
const assert = require('assert');
|
const assert = require("assert");
|
||||||
const resetDatabase = require('test/helpers/resetDatabase');
|
const chai = require("chai");
|
||||||
const app = require('src/webserver/app');
|
const chaiHttp = require("chai-http");
|
||||||
const request = require('supertest-as-promised');
|
|
||||||
|
|
||||||
describe('As a user I want a forbidden error if the token is malformed', () => {
|
const server = require("../../src/webserver/server");
|
||||||
before(() => resetDatabase());
|
const resetDatabase = require("../helpers/resetDatabase");
|
||||||
|
|
||||||
it('should return 401', () =>
|
chai.use(chaiHttp);
|
||||||
request(app)
|
|
||||||
.get('/api/v1/pirate/search?query=test')
|
describe("As a user I want a forbidden error if the token is malformed", () => {
|
||||||
.set('Authorization', 'maLfOrMed TOKEN')
|
beforeEach(() => resetDatabase());
|
||||||
.expect(401)
|
|
||||||
.then(response => assert.equal(response.body.error, 'You must be logged in.'))
|
it("should return 401", done => {
|
||||||
);
|
chai
|
||||||
|
.request(server)
|
||||||
|
.get("/api/v1/user/settings")
|
||||||
|
.set("Authorization", "maLfOrMed TOKEN")
|
||||||
|
.end((error, response) => {
|
||||||
|
assert.equal(response?.status, 401);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
// .then(response => {
|
||||||
|
// assert.equal(response.body.error, "You must be logged in.");
|
||||||
|
// }));}
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -1,20 +1,30 @@
|
|||||||
const assert = require('assert');
|
const assert = require("assert");
|
||||||
const request = require('supertest-as-promised');
|
const chai = require("chai");
|
||||||
const app = require('src/webserver/app');
|
const chaiHttp = require("chai-http");
|
||||||
const createUser = require('test/helpers/createUser');
|
|
||||||
const resetDatabase = require('test/helpers/resetDatabase');
|
|
||||||
|
|
||||||
describe('As a user I want error when registering existing username', () => {
|
const server = require("../../src/webserver/server");
|
||||||
before(() => {
|
const createUser = require("../helpers/createUser");
|
||||||
return resetDatabase()
|
const resetDatabase = require("../helpers/resetDatabase");
|
||||||
.then(() => createUser('test_user', 'password'))
|
|
||||||
})
|
|
||||||
|
|
||||||
it('should return 401 with error message when same username is given', () =>
|
chai.use(chaiHttp);
|
||||||
request(app)
|
|
||||||
.post('/api/v1/user')
|
describe("As a user I want error when registering existing username", () => {
|
||||||
.send({ username: 'test_user', password: 'password' })
|
beforeEach(() => resetDatabase());
|
||||||
.expect(401)
|
beforeEach(() => createUser("test_user", "password"));
|
||||||
.then(response => assert.equal(response.text, '{"success":false,"message":"That username is already registered"}'))
|
|
||||||
);
|
it("should return 401 with error message when same username is given", done => {
|
||||||
|
chai
|
||||||
|
.request(server)
|
||||||
|
.post("/api/v1/user")
|
||||||
|
.send({ username: "test_user", password: "password" })
|
||||||
|
.end((error, response) => {
|
||||||
|
// console.log(response);
|
||||||
|
assert.equal(response?.status, 401);
|
||||||
|
assert.equal(
|
||||||
|
response?.text,
|
||||||
|
'{"success":false,"message":"That username is already registered"}'
|
||||||
|
);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -1,18 +1,27 @@
|
|||||||
const assert = require('assert');
|
const assert = require("assert");
|
||||||
const createCacheEntry = require('test/helpers/createCacheEntry');
|
const chai = require("chai");
|
||||||
const resetDatabase = require('test/helpers/resetDatabase');
|
const chaiHttp = require("chai-http");
|
||||||
const request = require('supertest-as-promised');
|
|
||||||
const app = require('src/webserver/app');
|
|
||||||
const popularMoviesSuccess = require('test/fixtures/popular-movies-success-response.json');
|
|
||||||
|
|
||||||
describe('As a user I want to get popular movies', () => {
|
const server = require("../../src/webserver/server");
|
||||||
before(() => resetDatabase());
|
const resetDatabase = require("../helpers/resetDatabase");
|
||||||
before(() => createCacheEntry('pm:1', popularMoviesSuccess));
|
const createCacheEntry = require("../helpers/createCacheEntry");
|
||||||
|
const popularMoviesSuccess = require("../fixtures/popular-movies-success-response.json");
|
||||||
|
|
||||||
it('should return 200 with the information', () =>
|
chai.use(chaiHttp);
|
||||||
request(app)
|
|
||||||
.get('/api/v2/movie/popular')
|
describe("As a user I want to get popular movies", () => {
|
||||||
.expect(200)
|
beforeEach(() => resetDatabase());
|
||||||
.then(response => assert.equal(response.body.results.length, 20))
|
beforeEach(() => createCacheEntry("tmdb/pm:1", popularMoviesSuccess));
|
||||||
);
|
|
||||||
|
it("should return 200 with the information", done => {
|
||||||
|
chai
|
||||||
|
.request(server)
|
||||||
|
.get("/api/v2/movie/popular")
|
||||||
|
.end((error, response) => {
|
||||||
|
// console.log(response);
|
||||||
|
|
||||||
|
assert.equal(response?.status, 200);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -1,18 +1,36 @@
|
|||||||
const assert = require('assert');
|
const assert = require("assert");
|
||||||
const createCacheEntry = require('test/helpers/createCacheEntry');
|
const chai = require("chai");
|
||||||
const resetDatabase = require('test/helpers/resetDatabase');
|
const chaiHttp = require("chai-http");
|
||||||
const request = require('supertest-as-promised');
|
|
||||||
const app = require('src/webserver/app');
|
|
||||||
const popularShowsSuccess = require('test/fixtures/popular-show-success-response.json');
|
|
||||||
|
|
||||||
describe('As a user I want to get popular shows', () => {
|
const server = require("../../src/webserver/server");
|
||||||
before(() => resetDatabase());
|
const resetDatabase = require("../helpers/resetDatabase");
|
||||||
before(() => createCacheEntry('pt:1', popularShowsSuccess));
|
const createCacheEntry = require("../helpers/createCacheEntry");
|
||||||
|
const popularShowsSuccess = require("../fixtures/popular-show-success-response.json");
|
||||||
|
|
||||||
it('should return 200 with the information', () =>
|
chai.use(chaiHttp);
|
||||||
request(app)
|
|
||||||
.get('/api/v2/show/popular')
|
describe("As a user I want to get popular shows", () => {
|
||||||
.expect(200)
|
beforeEach(() => resetDatabase());
|
||||||
.then(response => assert.equal(response.body.results.length, 20))
|
beforeEach(() => createCacheEntry("tmdb/pt:1", popularShowsSuccess));
|
||||||
);
|
|
||||||
|
it("should return 200 with the information", done => {
|
||||||
|
chai
|
||||||
|
.request(server)
|
||||||
|
.get("/api/v2/show/popular")
|
||||||
|
.end((error, response) => {
|
||||||
|
assert.equal(response?.status, 200);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
// .end((err, res) => {
|
||||||
|
// // res.should.have.status(200);
|
||||||
|
// // res.body?.results?.should.be.a("array");
|
||||||
|
// // res.body?.results?.length.should.be.eq(20);
|
||||||
|
// done();
|
||||||
|
// }));
|
||||||
|
// .expect(200));
|
||||||
|
// .then(response => {
|
||||||
|
// assert.equal(response.body?.results?.length, 20);
|
||||||
|
// }));
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -1,23 +1,29 @@
|
|||||||
const resetDatabase = require('test/helpers/resetDatabase');
|
const assert = require("assert");
|
||||||
const createCacheEntry = require('test/helpers/createCacheEntry');
|
const chai = require("chai");
|
||||||
const app = require('src/webserver/app');
|
const chaiHttp = require("chai-http");
|
||||||
const request = require('supertest-as-promised');
|
|
||||||
const createUser = require('test/helpers/createUser');
|
|
||||||
const createToken = require('test/helpers/createToken');
|
|
||||||
const infoMovieSuccess = require('test/fixtures/blade_runner_2049-info-success-response.json');
|
|
||||||
|
|
||||||
describe('As a user I want to request a movie', () => {
|
const server = require("../../src/webserver/server");
|
||||||
before(async () => {
|
const createUser = require("../helpers/createUser");
|
||||||
await resetDatabase()
|
const createToken = require("../helpers/createToken");
|
||||||
await createUser('test_user', 'test@gmail.com', 'password')
|
const resetDatabase = require("../helpers/resetDatabase");
|
||||||
})
|
const createCacheEntry = require("../helpers/createCacheEntry");
|
||||||
before(() => createCacheEntry('mi:335984:false', infoMovieSuccess));
|
const infoMovieSuccess = require("../fixtures/blade_runner_2049-info-success-response.json");
|
||||||
|
|
||||||
it('should return 200 when item is requested', () =>
|
chai.use(chaiHttp);
|
||||||
request(app)
|
|
||||||
.post('/api/v2/request')
|
describe("As a user I want to request a movie", () => {
|
||||||
.set('authorization', createToken('test_user', 'secret'))
|
beforeEach(() => resetDatabase());
|
||||||
.send({ id: 335984, type: 'movie' })
|
beforeEach(() => createUser("test_user", "test@gmail.com", "password"));
|
||||||
.expect(200)
|
beforeEach(() => createCacheEntry("mi:335984:false", infoMovieSuccess));
|
||||||
);
|
|
||||||
|
it("should return 200 when item is requested", () => {
|
||||||
|
chai
|
||||||
|
.request(server)
|
||||||
|
.post("/api/v2/request")
|
||||||
|
.set("authorization", createToken("test_user", "secret"))
|
||||||
|
.send({ id: 335984, type: "movie" })
|
||||||
|
.end((error, response) => {
|
||||||
|
assert.equal(response?.status, 200);
|
||||||
|
});
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -1,16 +1,29 @@
|
|||||||
const createCacheEntry = require('test/helpers/createCacheEntry');
|
const assert = require("assert");
|
||||||
const resetDatabase = require('test/helpers/resetDatabase');
|
const chai = require("chai");
|
||||||
const request = require('supertest-as-promised');
|
const chaiHttp = require("chai-http");
|
||||||
const app = require('src/webserver/app');
|
|
||||||
const interstellarQuerySuccess = require('test/fixtures/interstellar-query-movie-success-response.json');
|
|
||||||
|
|
||||||
describe('As an anonymous user I want to search for a movie', () => {
|
const server = require("../../src/webserver/server");
|
||||||
before(() => resetDatabase());
|
const resetDatabase = require("../helpers/resetDatabase");
|
||||||
before(() => createCacheEntry('mos:1:interstellar', interstellarQuerySuccess));
|
const createCacheEntry = require("../helpers/createCacheEntry");
|
||||||
|
const interstellarQuerySuccess = require("../fixtures/interstellar-query-movie-success-response.json");
|
||||||
|
|
||||||
it('should return 200 with the search results even if user is not logged in', () =>
|
chai.use(chaiHttp);
|
||||||
request(app)
|
|
||||||
.get('/api/v2/search/movie?query=interstellar&page=1')
|
describe("As an anonymous user I want to search for a movie", () => {
|
||||||
.expect(200)
|
beforeEach(() => resetDatabase());
|
||||||
|
beforeEach(() =>
|
||||||
|
createCacheEntry("tmdb/mos:1:interstellar:false", interstellarQuerySuccess)
|
||||||
);
|
);
|
||||||
|
|
||||||
|
it("should return 200 with the search results even if user is not logged in", done => {
|
||||||
|
chai
|
||||||
|
.request(server)
|
||||||
|
.get("/api/v2/search/movie?query=interstellar&page=1")
|
||||||
|
.end((error, response) => {
|
||||||
|
// console.log(response);
|
||||||
|
|
||||||
|
assert.equal(response?.status, 200);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -1,63 +1,78 @@
|
|||||||
const assert = require('assert');
|
const assert = require("assert");
|
||||||
const Config = require('src/config/configuration.js');
|
const Config = require("../../../src/config/configuration");
|
||||||
|
|
||||||
describe('Config', () => {
|
describe("Config", () => {
|
||||||
before(() => {
|
beforeEach(() => {
|
||||||
this.backedUpEnvironmentVariables = Object.assign({}, process.env);
|
this.backedUpEnvironmentVariables = { ...process.env };
|
||||||
this.backedUpConfigFields = Object.assign({}, Config.getInstance().fields);
|
this.backedUpConfigFields = { ...Config.getInstance().fields };
|
||||||
});
|
});
|
||||||
|
|
||||||
after(() => {
|
afterEach(() => {
|
||||||
process.env = this.backedUpEnvironmentVariables;
|
process.env = this.backedUpEnvironmentVariables;
|
||||||
Config.getInstance().fields = this.backedUpConfigFields;
|
Config.getInstance().fields = this.backedUpConfigFields;
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should retrieve section and option from config file', () => {
|
it("should retrieve section and option from config file", () => {
|
||||||
Config.getInstance().fields = { 'webserver': { 'port': 1337 } };
|
Config.getInstance().fields = { webserver: { port: 1337 } };
|
||||||
assert.equal(Config.getInstance().get('webserver', 'port'), 1337);
|
assert.equal(Config.getInstance().get("webserver", "port"), 1337);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should resolve to environment variables if option is filtered with env', () => {
|
it("should resolve to environment variables if option is filtered with env", () => {
|
||||||
Config.getInstance().fields = { 'webserver': { 'port': 'env|SEASONED_WEBSERVER_PORT' } };
|
Config.getInstance().fields = {
|
||||||
process.env.SEASONED_WEBSERVER_PORT = '1338';
|
webserver: { port: "env|SEASONED_WEBSERVER_PORT" }
|
||||||
assert.equal(Config.getInstance().get('webserver', 'port'), 1338);
|
};
|
||||||
|
process.env.SEASONED_WEBSERVER_PORT = "1338";
|
||||||
|
assert.equal(Config.getInstance().get("webserver", "port"), 1338);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('raises an exception if the environment variable does not exist', () => {
|
it("raises an exception if the environment variable does not exist", () => {
|
||||||
Config.getInstance().fields = { 'webserver': { 'port': 'env|DOES_NOT_EXIST' } };
|
Config.getInstance().fields = { webserver: { port: "env|DOES_NOT_EXIST" } };
|
||||||
process.env.SEASONED_WEBSERVER_PORT = '1338';
|
process.env.SEASONED_WEBSERVER_PORT = "1338";
|
||||||
assert.throws(() => Config.getInstance().get('webserver', 'port'), /empty/);
|
assert.throws(() => Config.getInstance().get("webserver", "port"), /empty/);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('raises an exception if the environment variable is empty', () => {
|
it("raises an exception if the environment variable is empty", () => {
|
||||||
Config.getInstance().fields = { 'webserver': { 'port': 'env|SEASONED_WEBSERVER_PORT' } };
|
Config.getInstance().fields = {
|
||||||
process.env.SEASONED_WEBSERVER_PORT = '';
|
webserver: { port: "env|SEASONED_WEBSERVER_PORT" }
|
||||||
assert.throws(() => Config.getInstance().get('webserver', 'port'), /empty/);
|
};
|
||||||
|
process.env.SEASONED_WEBSERVER_PORT = "";
|
||||||
|
assert.throws(() => Config.getInstance().get("webserver", "port"), /empty/);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('raises an exception if the section does not exist in the file', () => {
|
it("raises an exception if the section does not exist in the file", () => {
|
||||||
Config.getInstance().fields = { 'webserver': { 'port': '1338' } };
|
Config.getInstance().fields = { webserver: { port: "1338" } };
|
||||||
assert.throws(() => Config.getInstance().get('woops', 'port'), /does not exist/);
|
assert.throws(
|
||||||
|
() => Config.getInstance().get("woops", "port"),
|
||||||
|
/does not exist/
|
||||||
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('raises an exception if the option does not exist in the file', () => {
|
it("raises an exception if the option does not exist in the file", () => {
|
||||||
Config.getInstance().fields = { 'webserver': { 'port': '1338' } };
|
Config.getInstance().fields = { webserver: { port: "1338" } };
|
||||||
assert.throws(() => Config.getInstance().get('webserver', 'woops'), /does not exist/);
|
assert.throws(
|
||||||
|
() => Config.getInstance().get("webserver", "woops"),
|
||||||
|
/does not exist/
|
||||||
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('returns an array if field is an array', () => {
|
it("returns an array if field is an array", () => {
|
||||||
Config.getInstance().fields = { 'bouncer': { 'whitelist': [1, 2, 3] } };
|
Config.getInstance().fields = { bouncer: { whitelist: [1, 2, 3] } };
|
||||||
assert.deepEqual(Config.getInstance().get('bouncer', 'whitelist'), [1, 2, 3]);
|
assert.deepEqual(
|
||||||
|
Config.getInstance().get("bouncer", "whitelist"),
|
||||||
|
[1, 2, 3]
|
||||||
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('decodes field as base64 if base64| is before the variable', () => {
|
it("decodes field as base64 if base64| is before the variable", () => {
|
||||||
Config.getInstance().fields = { 'webserver': { 'port': 'base64|MTMzOA==' } };
|
Config.getInstance().fields = { webserver: { port: "base64|MTMzOA==" } };
|
||||||
assert.equal(Config.getInstance().get('webserver', 'port'), 1338);
|
assert.equal(Config.getInstance().get("webserver", "port"), 1338);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('decodes environment variable as base64 if BASE64= is before the variable', () => {
|
it("decodes environment variable as base64 if BASE64= is before the variable", () => {
|
||||||
Config.getInstance().fields = { 'webserver': { 'port': 'env|base64|SEASONED_WEBSERVER_PORT' } };
|
Config.getInstance().fields = {
|
||||||
process.env.SEASONED_WEBSERVER_PORT = 'MTMzOA==';
|
webserver: { port: "env|base64|SEASONED_WEBSERVER_PORT" }
|
||||||
assert.equal(Config.getInstance().get('webserver', 'port'), 1338);
|
};
|
||||||
|
process.env.SEASONED_WEBSERVER_PORT = "MTMzOA==";
|
||||||
|
assert.equal(Config.getInstance().get("webserver", "port"), 1338);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -1,71 +1,77 @@
|
|||||||
const assert = require('assert');
|
const assert = require("assert");
|
||||||
const Field = require('src/config/field.js');
|
const Field = require("../../../src/config/field");
|
||||||
|
|
||||||
describe('Field', () => {
|
describe("Field", () => {
|
||||||
it('should return an array if it is an array', () => {
|
it("should return an array if it is an array", () => {
|
||||||
const field = new Field([1, 2, 3]);
|
const field = new Field([1, 2, 3]);
|
||||||
assert.deepEqual(field.value, [1, 2, 3]);
|
assert.deepEqual(field.value, [1, 2, 3]);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should return the plain value if it is an ordinary field', () => {
|
it("should return the plain value if it is an ordinary field", () => {
|
||||||
const field = new Field('plain value');
|
const field = new Field("plain value");
|
||||||
assert.equal(field.value, 'plain value');
|
assert.equal(field.value, "plain value");
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should return false if boolean false is field', () => {
|
it("should return false if boolean false is field", () => {
|
||||||
const field = new Field(false);
|
const field = new Field(false);
|
||||||
assert.equal(field.value, false);
|
assert.equal(field.value, false);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should not include any invalid filters', () => {
|
it("should not include any invalid filters", () => {
|
||||||
const field = new Field('invalid-filter|plain value');
|
const field = new Field("invalid-filter|plain value");
|
||||||
assert.equal(field.value, 'plain value');
|
assert.equal(field.value, "plain value");
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should return the decoded value if it is filtered through base64', () => {
|
it("should return the decoded value if it is filtered through base64", () => {
|
||||||
const field = new Field('base64|ZW5jb2RlZCB2YWx1ZQ==');
|
const field = new Field("base64|ZW5jb2RlZCB2YWx1ZQ==");
|
||||||
assert.equal(field.value, 'encoded value');
|
assert.equal(field.value, "encoded value");
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should not decode the value if it missing the filter', () => {
|
it("should not decode the value if it missing the filter", () => {
|
||||||
const field = new Field('ZW5jb2RlZCB2YWx1ZQ==');
|
const field = new Field("ZW5jb2RlZCB2YWx1ZQ==");
|
||||||
assert.equal(field.value, 'ZW5jb2RlZCB2YWx1ZQ==');
|
assert.equal(field.value, "ZW5jb2RlZCB2YWx1ZQ==");
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should retrieve the environment variable if env filter is used', () => {
|
it("should retrieve the environment variable if env filter is used", () => {
|
||||||
const environmentVariables = { REDIS_URL: 'redis://127.0.0.1:1234' };
|
const environmentVariables = { REDIS_URL: "redis://127.0.0.1:1234" };
|
||||||
const field = new Field('env|REDIS_URL', environmentVariables);
|
const field = new Field("env|REDIS_URL", environmentVariables);
|
||||||
assert.equal(field.value, 'redis://127.0.0.1:1234');
|
assert.equal(field.value, "redis://127.0.0.1:1234");
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should return undefined if the environment variable does not exist', () => {
|
it("should return undefined if the environment variable does not exist", () => {
|
||||||
const environmentVariables = { HTTP_PORT: 8080 };
|
const environmentVariables = { HTTP_PORT: 8080 };
|
||||||
const field = new Field('env|REDIS_URL', environmentVariables);
|
const field = new Field("env|REDIS_URL", environmentVariables);
|
||||||
assert.equal(field.value, undefined);
|
assert.equal(field.value, undefined);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should return undefined if the environment variable is an empty string', () => {
|
it("should return undefined if the environment variable is an empty string", () => {
|
||||||
const environmentVariables = { REDIS_URL: '' };
|
const environmentVariables = { REDIS_URL: "" };
|
||||||
const field = new Field('env|REDIS_URL', environmentVariables);
|
const field = new Field("env|REDIS_URL", environmentVariables);
|
||||||
assert.deepEqual(field.value, undefined);
|
assert.deepEqual(field.value, undefined);
|
||||||
});
|
});
|
||||||
|
|
||||||
describe('Multiple filters', () => {
|
describe("Multiple filters", () => {
|
||||||
it('should decode the environment variable if base64 and env filter are used', () => {
|
it("should decode the environment variable if base64 and env filter are used", () => {
|
||||||
const environmentVariables = { REDIS_URL: 'cmVkaXM6Ly9kYWdibGFkZXQubm8vMTIzNA==' };
|
const environmentVariables = {
|
||||||
const field = new Field('env|base64|REDIS_URL', environmentVariables);
|
REDIS_URL: "cmVkaXM6Ly9kYWdibGFkZXQubm8vMTIzNA=="
|
||||||
assert.equal(field.value, 'redis://dagbladet.no/1234');
|
};
|
||||||
|
const field = new Field("env|base64|REDIS_URL", environmentVariables);
|
||||||
|
assert.equal(field.value, "redis://dagbladet.no/1234");
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should disregard the order of filters when env and base64 are used', () => {
|
it("should disregard the order of filters when env and base64 are used", () => {
|
||||||
const environmentVariables = { REDIS_URL: 'cmVkaXM6Ly9kYWdibGFkZXQubm8vMTIzNA==' };
|
const environmentVariables = {
|
||||||
const field = new Field('base64|env|REDIS_URL', environmentVariables);
|
REDIS_URL: "cmVkaXM6Ly9kYWdibGFkZXQubm8vMTIzNA=="
|
||||||
assert.equal(field.value, 'redis://dagbladet.no/1234');
|
};
|
||||||
|
const field = new Field("base64|env|REDIS_URL", environmentVariables);
|
||||||
|
assert.equal(field.value, "redis://dagbladet.no/1234");
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should return undefined if both filters are used and env var does not exist', () => {
|
it("should return undefined if both filters are used and env var does not exist", () => {
|
||||||
const environmentVariables = { REDIS_URL: 'cmVkaXM6Ly9kYWdibGFkZXQubm8vMTIzNA==' };
|
const environmentVariables = {
|
||||||
const field = new Field('base64|env|REDIS_LOL', environmentVariables);
|
REDIS_URL: "cmVkaXM6Ly9kYWdibGFkZXQubm8vMTIzNA=="
|
||||||
|
};
|
||||||
|
const field = new Field("base64|env|REDIS_LOL", environmentVariables);
|
||||||
assert.equal(field.value, undefined);
|
assert.equal(field.value, undefined);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -1,34 +1,34 @@
|
|||||||
const assert = require('assert');
|
const assert = require("assert");
|
||||||
const Filters = require('src/config/filters.js');
|
const Filters = require("../../../src/config/filters");
|
||||||
|
|
||||||
describe('Filters', () => {
|
describe("Filters", () => {
|
||||||
it('should extract base64 as filter if it is at start of string followed by pipe', () => {
|
it("should extract base64 as filter if it is at start of string followed by pipe", () => {
|
||||||
const filters = new Filters('base64|');
|
const filters = new Filters("base64|");
|
||||||
assert.deepEqual(filters.filters, ['base64']);
|
assert.deepEqual(filters.filters, ["base64"]);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should extract base64 and env as filters if both are separated by pipe', () => {
|
it("should extract base64 and env as filters if both are separated by pipe", () => {
|
||||||
const filters = new Filters('base64|env|');
|
const filters = new Filters("base64|env|");
|
||||||
assert.deepEqual(filters.filters, ['base64', 'env']);
|
assert.deepEqual(filters.filters, ["base64", "env"]);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should not extract any filters if none are present', () => {
|
it("should not extract any filters if none are present", () => {
|
||||||
const filters = new Filters('base64');
|
const filters = new Filters("base64");
|
||||||
assert.deepEqual(filters.filters, []);
|
assert.deepEqual(filters.filters, []);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should strip env filter from the value', () => {
|
it("should strip env filter from the value", () => {
|
||||||
const filters = new Filters('env|HELLO');
|
const filters = new Filters("env|HELLO");
|
||||||
assert.deepEqual(filters.removeFiltersFromValue(), 'HELLO');
|
assert.deepEqual(filters.removeFiltersFromValue(), "HELLO");
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should strip env and base64 filter from the value', () => {
|
it("should strip env and base64 filter from the value", () => {
|
||||||
const filters = new Filters('env|base64|HELLO');
|
const filters = new Filters("env|base64|HELLO");
|
||||||
assert.deepEqual(filters.removeFiltersFromValue(), 'HELLO');
|
assert.deepEqual(filters.removeFiltersFromValue(), "HELLO");
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should strip no filters from the value if there are no filters', () => {
|
it("should strip no filters from the value if there are no filters", () => {
|
||||||
const filters = new Filters('HELLO');
|
const filters = new Filters("HELLO");
|
||||||
assert.deepEqual(filters.removeFiltersFromValue(), 'HELLO');
|
assert.deepEqual(filters.removeFiltersFromValue(), "HELLO");
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -1,31 +1,38 @@
|
|||||||
const assert = require('assert');
|
const assert = require("assert");
|
||||||
// const convertTmdbToMovie = require('src/tmdb/convertTmdbToMovie');
|
// const convertTmdbToMovie = require('src/tmdb/convertTmdbToMovie');
|
||||||
const { Movie } = require('src/tmdb/types');
|
const { Movie } = require("../../../src/tmdb/types");
|
||||||
const bladeRunnerQuerySuccess = require('test/fixtures/blade_runner_2049-info-success-response.json')
|
const bladeRunnerQuerySuccess = require("../../fixtures/blade_runner_2049-info-success-response.json");
|
||||||
|
|
||||||
describe('Convert tmdb movieInfo to movie', () => {
|
describe("Convert tmdb movieInfo to movie", () => {
|
||||||
beforeEach(() => [this.bladeRunnerTmdbMovie] = bladeRunnerQuerySuccess);
|
beforeEach(() => {
|
||||||
|
[this.bladeRunnerTmdbMovie] = bladeRunnerQuerySuccess;
|
||||||
|
});
|
||||||
|
|
||||||
it('should translate the tmdb release date to movie year', () => {
|
it("should translate the tmdb release date to movie year", () => {
|
||||||
const bladeRunner = Movie.convertFromTmdbResponse(this.bladeRunnerTmdbMovie);
|
const bladeRunner = Movie.convertFromTmdbResponse(
|
||||||
|
this.bladeRunnerTmdbMovie
|
||||||
|
);
|
||||||
assert.strictEqual(bladeRunner.year, 2017);
|
assert.strictEqual(bladeRunner.year, 2017);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should translate the tmdb release date to instance of Date', () => {
|
it("should translate the tmdb release date to instance of Date", () => {
|
||||||
const bladeRunner = Movie.convertFromTmdbResponse(this.bladeRunnerTmdbMovie);
|
const bladeRunner = Movie.convertFromTmdbResponse(
|
||||||
|
this.bladeRunnerTmdbMovie
|
||||||
|
);
|
||||||
assert(bladeRunner.releaseDate instanceof Date);
|
assert(bladeRunner.releaseDate instanceof Date);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should translate the tmdb title to title', () => {
|
it("should translate the tmdb title to title", () => {
|
||||||
const bladeRunner = Movie.convertFromTmdbResponse(this.bladeRunnerTmdbMovie);
|
const bladeRunner = Movie.convertFromTmdbResponse(
|
||||||
assert.equal(bladeRunner.title, 'Blade Runner 2049');
|
this.bladeRunnerTmdbMovie
|
||||||
|
);
|
||||||
|
assert.equal(bladeRunner.title, "Blade Runner 2049");
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should translate the tmdb vote_average to rating', () => {
|
it("should translate the tmdb vote_average to rating", () => {
|
||||||
const bladeRunner = Movie.convertFromTmdbResponse(this.bladeRunnerTmdbMovie);
|
const bladeRunner = Movie.convertFromTmdbResponse(
|
||||||
|
this.bladeRunnerTmdbMovie
|
||||||
|
);
|
||||||
assert.equal(bladeRunner.rating, 7.3);
|
assert.equal(bladeRunner.rating, 7.3);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -5,9 +5,9 @@ const Cache = require('src/tmdb/cache');
|
|||||||
const SqliteDatabase = require('src/database/sqliteDatabase');
|
const SqliteDatabase = require('src/database/sqliteDatabase');
|
||||||
const tmdbMock = require('test/helpers/tmdbMock');
|
const tmdbMock = require('test/helpers/tmdbMock');
|
||||||
|
|
||||||
const emptyQuerySuccess = require('test/fixtures/empty-query-success-response.json');
|
const emptyQuerySuccess = require('tests/fixtures/empty-query-success-response.json');
|
||||||
const interstellarQuerySuccess = require('test/fixtures/arrival-info-success-response.json');
|
const interstellarQuerySuccess = require('tests/fixtures/arrival-info-success-response.json');
|
||||||
const popularMovieSuccessResponse = require('test/fixtures/popular-movies-success-response.json');
|
const popularMovieSuccessResponse = require('tests/fixtures/popular-movies-success-response.json');
|
||||||
|
|
||||||
describe('TMDB', function test() {
|
describe('TMDB', function test() {
|
||||||
beforeEach(() => {
|
beforeEach(() => {
|
||||||
|
|||||||
Reference in New Issue
Block a user