* Adds flow types / Configuration interfaces * Lets call it options * Use a single interface to generate the configurations * Translates options to definitions only if comments are set * improves logic * Moves objects around * Fixes issue affecting logging of circular objects * fixes undefined env * Moves all defaults to defaults * Adds back CLI defaults * Restored defaults in commander.js * Merge provided defaults and platform defaults * Addresses visual nits * Improves Config.js code * Adds ability to pass the default value in trailing comments * Load platform defaults from the definitions file * proper default values on various options * Adds ParseServer.start and server.start(options) as quick startup methods * Moves creating liveQueryServer http into ParseServer.js * removes dead code * Adds tests to guarantee we can start a LQ Server from main module * Fixes incorrect code regading liveQuery init port * Start a http server for LQ if port is specified * ensure we dont fail if config.port is not set * Specify port * ignore other path skipped in tests * Adds test for custom middleware setting * Refactors new Config into Config.get - Hides AppCache from ParseServer.js, use Config.put which validates * Extracts controller creation into Controllers/index.js - This makes the ParseServer init way simpler * Move serverURL inference into ParseServer * review nits
66 lines
2.3 KiB
JavaScript
66 lines
2.3 KiB
JavaScript
const LoggerController = require('../src/Controllers/LoggerController').LoggerController;
|
|
const WinstonLoggerAdapter = require('../src/Adapters/Logger/WinstonLoggerAdapter').WinstonLoggerAdapter;
|
|
const GridStoreAdapter = require("../src/Adapters/Files/GridStoreAdapter").GridStoreAdapter;
|
|
const Config = require("../src/Config");
|
|
const FilesController = require('../src/Controllers/FilesController').default;
|
|
|
|
const mockAdapter = {
|
|
createFile: () => {
|
|
return Parse.Promise.reject(new Error('it failed'));
|
|
},
|
|
deleteFile: () => { },
|
|
getFileData: () => { },
|
|
getFileLocation: () => 'xyz'
|
|
}
|
|
|
|
// Small additional tests to improve overall coverage
|
|
describe("FilesController",() =>{
|
|
it("should properly expand objects", (done) => {
|
|
|
|
var config = Config.get(Parse.applicationId);
|
|
var gridStoreAdapter = new GridStoreAdapter('mongodb://localhost:27017/parse');
|
|
var filesController = new FilesController(gridStoreAdapter)
|
|
var result = filesController.expandFilesInObject(config, function(){});
|
|
|
|
expect(result).toBeUndefined();
|
|
|
|
var fullFile = {
|
|
type: '__type',
|
|
url: "http://an.url"
|
|
}
|
|
|
|
var anObject = {
|
|
aFile: fullFile
|
|
}
|
|
filesController.expandFilesInObject(config, anObject);
|
|
expect(anObject.aFile.url).toEqual("http://an.url");
|
|
|
|
done();
|
|
});
|
|
|
|
it('should create a server log on failure', done => {
|
|
const logController = new LoggerController(new WinstonLoggerAdapter());
|
|
|
|
reconfigureServer({ filesAdapter: mockAdapter })
|
|
.then(() => new Promise(resolve => setTimeout(resolve, 1000)))
|
|
.then(() => new Parse.File("yolo.txt", [1,2,3], "text/plain").save())
|
|
.then(
|
|
() => done.fail('should not succeed'),
|
|
() => setImmediate(() => Parse.Promise.as('done'))
|
|
)
|
|
.then(() => logController.getLogs({ from: Date.now() - 500, size: 1000 }))
|
|
.then((logs) => {
|
|
// we get two logs here: 1. the source of the failure to save the file
|
|
// and 2 the message that will be sent back to the client.
|
|
const log1 = logs.pop();
|
|
expect(log1.level).toBe('error');
|
|
expect(log1.message).toBe('it failed');
|
|
const log2 = logs.pop();
|
|
expect(log2.level).toBe('error');
|
|
expect(log2.code).toBe(130);
|
|
expect(log2.message).toBe('Could not store file.');
|
|
done();
|
|
});
|
|
});
|
|
});
|