filestack-js
Version:
Official JavaScript library for Filestack
248 lines (246 loc) • 27.9 kB
JavaScript
/*
* Copyright (c) 2018 by Filestack.
* Some rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the 'License');
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an 'AS IS' BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
Object.defineProperty(exports, "__esModule", { value: true });
var tslib_1 = require("tslib");
// import { config } from './../../config';
var nock_1 = tslib_1.__importDefault(require("nock"));
var prefetch_1 = require("./prefetch");
var request_1 = require("../request");
var testApiKey = 'AHv2222222222444444uez';
var testSecurity = {
policy: 'examplePolicy',
signature: 'exampleSignature',
};
var testURL = {
fileApiUrl: '',
uploadApiUrl: 'https://uploadtesturl-fs.com',
cloudApiUrl: '',
cdnUrl: '',
pickerUrl: '',
processUrl: '',
};
var testSession = {
apikey: testApiKey,
urls: testURL,
};
var scope = (0, nock_1.default)(testURL.uploadApiUrl);
// mock cors responses for all request for browser tests
scope.defaultReplyHeaders({
'access-control-allow-origin': function (req) { var _a; return (_a = req.getHeader('origin')) === null || _a === void 0 ? void 0 : _a.toString(); },
'access-control-allow-methods': function (req) { var _a; return (_a = req.getHeader('access-control-request-method')) === null || _a === void 0 ? void 0 : _a.toString(); },
'access-control-allow-headers': function (req) { var _a; return (_a = req.getHeader('access-control-request-headers')) === null || _a === void 0 ? void 0 : _a.toString(); },
'content-type': 'application/json',
});
describe('Prefetch', function () {
beforeEach(function () {
scope
.options(/.*/)
.reply(204);
});
it('should make correct request to prefetch and return new config', function () { return tslib_1.__awaiter(void 0, void 0, void 0, function () {
var sessionCopy, serverResponse, test, prefetch, res;
return tslib_1.__generator(this, function (_a) {
switch (_a.label) {
case 0:
sessionCopy = tslib_1.__assign({}, testSession);
serverResponse = {
blocked: false,
settings: {
customsource: false,
inapp_browser: false,
},
permissions: {
transforms_ui: false,
},
updated_config: {
fromSources: ['googledrive'],
},
};
scope.post('/prefetch').once().reply(200, serverResponse);
test = function () { return 2; };
prefetch = new prefetch_1.Prefetch(sessionCopy);
return [4 /*yield*/, prefetch.getConfig({
pickerOptions: {
// @ts-ignore
onFileSelected: test,
fromSources: ['googledrive', 'test'],
},
})];
case 1:
res = _a.sent();
expect(res.pickerOptions.onFileSelected).toEqual(test);
expect(res.pickerOptions.fromSources).toEqual(['googledrive']);
scope.done();
return [2 /*return*/];
}
});
}); });
it('should set correct params to sessions (prefetch)', function () { return tslib_1.__awaiter(void 0, void 0, void 0, function () {
var sessionCopy, serverResponse, prefetch, res;
return tslib_1.__generator(this, function (_a) {
switch (_a.label) {
case 0:
sessionCopy = tslib_1.__assign({}, testSession);
serverResponse = {
blocked: false,
settings: {
customsource: false,
inapp_browser: true,
},
permissions: {
transforms_ui: true,
},
updated_config: {
fromSources: ['googledrive'],
},
};
scope.post('/prefetch').once().reply(200, serverResponse);
prefetch = new prefetch_1.Prefetch(sessionCopy);
return [4 /*yield*/, prefetch.getConfig({
pickerOptions: {
fromSources: ['facebook', 'test'],
},
})];
case 1:
res = _a.sent();
expect(sessionCopy.prefetch).toEqual(expect.any(Object));
expect(sessionCopy.prefetch.settings.inapp_browser).toEqual(true);
expect(sessionCopy.prefetch.permissions.transforms_ui).toEqual(true);
scope.done();
return [2 /*return*/];
}
});
}); });
it('should throw error when response code is other thant 200', function () { return tslib_1.__awaiter(void 0, void 0, void 0, function () {
var sessionCopy, prefetch, err_1;
return tslib_1.__generator(this, function (_a) {
switch (_a.label) {
case 0:
_a.trys.push([0, 2, , 3]);
sessionCopy = tslib_1.__assign({}, testSession);
prefetch = new prefetch_1.Prefetch(sessionCopy);
scope.post('/prefetch').once().reply(500);
return [4 /*yield*/, prefetch.getConfig({})];
case 1:
_a.sent();
return [3 /*break*/, 3];
case 2:
err_1 = _a.sent();
expect(err_1.code).toEqual(request_1.FsRequestErrorCode.SERVER);
return [3 /*break*/, 3];
case 3:
scope.done();
return [2 /*return*/];
}
});
}); });
it('should add security to request when provided', function () { return tslib_1.__awaiter(void 0, void 0, void 0, function () {
var sessionCopy, mockPref, prefetch, res;
return tslib_1.__generator(this, function (_a) {
switch (_a.label) {
case 0:
sessionCopy = tslib_1.__assign(tslib_1.__assign({}, testSession), { signature: testSecurity.signature, policy: testSecurity.policy });
mockPref = jest.fn().mockImplementation(function () { return ({}); });
scope.post('/prefetch').once().reply(200, function (_, data) { return mockPref(data); });
prefetch = new prefetch_1.Prefetch(sessionCopy);
return [4 /*yield*/, prefetch.getConfig({
pickerOptions: {},
})];
case 1:
res = _a.sent();
expect(mockPref).toHaveBeenCalledWith({
apikey: testApiKey,
settings: ['inapp_browser'],
security: {
signature: testSecurity.signature,
policy: testSecurity.policy,
},
});
scope.done();
return [2 /*return*/];
}
});
}); });
it('should always add inapp browser setting to request', function () { return tslib_1.__awaiter(void 0, void 0, void 0, function () {
var mockPref, prefetch;
return tslib_1.__generator(this, function (_a) {
switch (_a.label) {
case 0:
mockPref = jest.fn().mockImplementation(function () { return ({}); });
scope.post('/prefetch').once().reply(200, function (_, data) { return mockPref(data); });
prefetch = new prefetch_1.Prefetch(tslib_1.__assign({}, testSession));
return [4 /*yield*/, prefetch.getConfig({})];
case 1:
_a.sent();
expect(mockPref).toHaveBeenCalledWith({
apikey: testApiKey,
settings: ['inapp_browser'],
});
scope.done();
return [2 /*return*/];
}
});
}); });
it('should always add inapp browser setting to request event if some settings are provided', function () { return tslib_1.__awaiter(void 0, void 0, void 0, function () {
var mockPref, prefetch;
return tslib_1.__generator(this, function (_a) {
switch (_a.label) {
case 0:
mockPref = jest.fn().mockImplementation(function () { return ({}); });
scope.post('/prefetch').once().reply(200, function (_, data) { return mockPref(data); });
prefetch = new prefetch_1.Prefetch(tslib_1.__assign({}, testSession));
return [4 /*yield*/, prefetch.getConfig({ settings: ['inapp_browser'] })];
case 1:
_a.sent();
expect(mockPref).toHaveBeenCalledWith({
apikey: testApiKey,
settings: ['inapp_browser'],
});
scope.done();
return [2 /*return*/];
}
});
}); });
it('should return old config when updated_config is missing in response', function () { return tslib_1.__awaiter(void 0, void 0, void 0, function () {
var sessionCopy, pickerOptions, prefetch, res;
return tslib_1.__generator(this, function (_a) {
switch (_a.label) {
case 0:
sessionCopy = tslib_1.__assign(tslib_1.__assign({}, testSession), { signature: testSecurity.signature, policy: testSecurity.policy });
scope.post('/prefetch').once().reply(200, {
blocked: true,
});
pickerOptions = {
uploadInBackground: true,
onUploadDone: function () { return console.log; },
storeTo: {
location: 'asd',
},
};
prefetch = new prefetch_1.Prefetch(sessionCopy);
return [4 /*yield*/, prefetch.getConfig({ pickerOptions: pickerOptions })];
case 1:
res = _a.sent();
expect(res.pickerOptions).toEqual(pickerOptions);
scope.done();
return [2 /*return*/];
}
});
}); });
});
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../../src/lib/api/prefetch.spec.browser.ts"],"names":[],"mappings":"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","file":"lib/api/prefetch.spec.browser.js","sourcesContent":["/*\n * Copyright (c) 2018 by Filestack.\n * Some rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the 'License');\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an 'AS IS' BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n// import { config } from './../../config';\nimport nock from 'nock';\nimport { Prefetch, PrefetchEvents } from './prefetch';\nimport { Session, Security } from './../client';\nimport { FsRequestErrorCode } from '../request';\n\nconst testApiKey = 'AHv2222222222444444uez';\nconst testSecurity: Security = {\n  policy: 'examplePolicy',\n  signature: 'exampleSignature',\n};\n\nconst testURL = {\n  fileApiUrl: '',\n  uploadApiUrl: 'https://uploadtesturl-fs.com',\n  cloudApiUrl: '',\n  cdnUrl: '',\n  pickerUrl: '',\n  processUrl: '',\n};\n\nconst testSession: Session = {\n  apikey: testApiKey,\n  urls: testURL,\n};\n\nlet scope = nock(testURL.uploadApiUrl);\n\n// mock cors responses for all request for browser tests\nscope.defaultReplyHeaders({\n  'access-control-allow-origin': function (req) { return req.getHeader('origin')?.toString(); },\n  'access-control-allow-methods': function (req) { return req.getHeader('access-control-request-method')?.toString(); },\n  'access-control-allow-headers': function (req) { return req.getHeader('access-control-request-headers')?.toString(); },\n  'content-type': 'application/json',\n});\n\ndescribe('Prefetch', () => {\n  beforeEach(() => {\n    scope\n    .options(/.*/)\n    .reply(204);\n  });\n\n  it('should make correct request to prefetch and return new config', async () => {\n    const sessionCopy =  { ...testSession };\n\n    const serverResponse = {\n      blocked: false,\n      settings: {\n        customsource: false,\n        inapp_browser: false,\n      },\n      permissions: {\n        transforms_ui: false,\n      },\n      updated_config: {\n        fromSources: ['googledrive'],\n      },\n    };\n\n    scope.post('/prefetch').once().reply(200, serverResponse);\n\n    const test = () => 2;\n\n    const prefetch = new Prefetch(sessionCopy);\n    const res = await prefetch.getConfig({\n      pickerOptions: {\n        // @ts-ignore\n        onFileSelected: test,\n        fromSources: ['googledrive', 'test'],\n      },\n    });\n\n    expect(res.pickerOptions.onFileSelected).toEqual(test);\n    expect(res.pickerOptions.fromSources).toEqual(['googledrive']);\n\n    scope.done();\n  });\n\n  it('should set correct params to sessions (prefetch)', async () => {\n    const sessionCopy =  { ...testSession };\n    const serverResponse = {\n      blocked: false,\n      settings: {\n        customsource: false,\n        inapp_browser: true,\n      },\n      permissions: {\n        transforms_ui: true,\n      },\n      updated_config: {\n        fromSources: ['googledrive'],\n      },\n    };\n\n    scope.post('/prefetch').once().reply(200, serverResponse);\n\n    const prefetch = new Prefetch(sessionCopy);\n    const res = await prefetch.getConfig({\n      pickerOptions: {\n        fromSources: ['facebook', 'test'],\n      },\n    });\n\n    expect(sessionCopy.prefetch).toEqual(expect.any(Object));\n    expect(sessionCopy.prefetch.settings.inapp_browser).toEqual(true);\n    expect(sessionCopy.prefetch.permissions.transforms_ui).toEqual(true);\n\n    scope.done();\n  });\n\n  it('should throw error when response code is other thant 200', async () => {\n    try {\n      const sessionCopy =  { ...testSession };\n      const prefetch = new Prefetch(sessionCopy);\n\n      scope.post('/prefetch').once().reply(500);\n\n      await prefetch.getConfig({});\n    } catch (err) {\n      expect(err.code).toEqual(FsRequestErrorCode.SERVER);\n    }\n\n    scope.done();\n  });\n\n  it('should add security to request when provided', async () => {\n    const sessionCopy =  {\n      ...testSession,\n      signature: testSecurity.signature,\n      policy: testSecurity.policy,\n    };\n\n    const mockPref = jest.fn() .mockImplementation(() => ({}));\n\n    scope.post('/prefetch').once().reply(200, (_, data) => mockPref(data));\n\n    const prefetch = new Prefetch(sessionCopy);\n    const res = await prefetch.getConfig({\n      pickerOptions: {},\n    });\n\n    expect(mockPref).toHaveBeenCalledWith({\n      apikey: testApiKey,\n      settings: ['inapp_browser'],\n      security: {\n        signature: testSecurity.signature,\n        policy: testSecurity.policy,\n      },\n    });\n\n    scope.done();\n  });\n\n  it('should always add inapp browser setting to request', async () => {\n    const mockPref = jest.fn() .mockImplementation(() => ({}));\n    scope.post('/prefetch').once().reply(200, (_, data) => mockPref(data));\n\n    const prefetch = new Prefetch({ ...testSession });\n    await prefetch.getConfig({});\n\n    expect(mockPref).toHaveBeenCalledWith({\n      apikey: testApiKey,\n      settings: ['inapp_browser'],\n    });\n\n    scope.done();\n  });\n\n  it('should always add inapp browser setting to request event if some settings are provided', async () => {\n    const mockPref = jest.fn() .mockImplementation(() => ({}));\n    scope.post('/prefetch').once().reply(200, (_, data) => mockPref(data));\n\n    const prefetch = new Prefetch({ ...testSession });\n    await prefetch.getConfig({ settings: ['inapp_browser'] });\n\n    expect(mockPref).toHaveBeenCalledWith({\n      apikey: testApiKey,\n      settings: ['inapp_browser'],\n    });\n\n    scope.done();\n  });\n\n  it('should return old config when updated_config is missing in response', async () => {\n    const sessionCopy =  {\n      ...testSession,\n      signature: testSecurity.signature,\n      policy: testSecurity.policy,\n    };\n\n    scope.post('/prefetch').once().reply(200, {\n      blocked: true,\n    });\n\n    const pickerOptions = {\n      uploadInBackground: true,\n      onUploadDone: () => console.log,\n      storeTo: {\n        location: 'asd',\n      },\n    };\n\n    const prefetch = new Prefetch(sessionCopy);\n    const res = await prefetch.getConfig({ pickerOptions });\n\n    expect(res.pickerOptions).toEqual(pickerOptions);\n\n    scope.done();\n  });\n});\n"]}
;